中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

mysql中innodb_force_recovery參數分析

發布時間:2021-11-10 11:50:02 來源:億速云 閱讀:173 作者:iii 欄目:MySQL數據庫

這篇文章主要講解了“mysql中innodb_force_recovery參數分析”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“mysql中innodb_force_recovery參數分析”吧!

一、問題描述

今天在線運行的一個mysql崩潰了。
查看錯誤日志,如下:

-----------------------------------------
 
161108 11:36:45 mysqld_safe Starting mysqld daemon with databases from /usr/local/mysql/var
 
2017-08-15 11:36:46 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see documentation for more details).
 
2017-08-15 11:36:46 5497 [Note] Plugin 'FEDERATED' is disabled.
 
2017-08-15 11:36:46 7f11c48e1720 InnoDB: Warning: Using innodb_additional_mem_pool_size is DEPRECATED. This option may be removed in future releases, together with the option innodb_use_sys_malloc and with the InnoDB's internal memory allocator.
2017-08-15 11:36:46 5497 [Note] InnoDB: Using atomics to ref count buffer pool pages
2017-08-15 11:36:46 5497 [Note] InnoDB: The InnoDB memory heap is disabled
2017-08-15 11:36:46 5497 [Note] InnoDB: Mutexes and rw_locks use GCC atomic builtins
2017-08-15 11:36:46 5497 [Note] InnoDB: Memory barrier is not used
2017-08-15 11:36:46 5497 [Note] InnoDB: Compressed tables use zlib 1.2.3
2017-08-15 11:36:46 5497 [Note] InnoDB: Using CPU crc32 instructions
2017-08-15 11:36:46 5497 [Note] InnoDB: Initializing buffer pool, size = 16.0M
2017-08-15 11:36:46 5497 [Note] InnoDB: Completed initialization of buffer pool
InnoDB: Database page corruption on disk or a failed
InnoDB: file read of page 5.
InnoDB: You may have to recover from a backup.
2017-08-15 11:36:46 7f11c48e1720 InnoDB: Page dump in ascii and hex (16384 bytes):
 len 16384; hex 7478d078000000050000000000000000000000000f271f4d000700000000000000000000000000000000001b4000000000000000000200f20000000000000006000000000000002d000000000000002e000000000000002f0000000000000030000000000(省略很多類似代碼)
InnoDB: End of page dump
2017-08-15 11:36:46 7f11c48e1720 InnoDB: uncompressed page, stored checksum in field1 1954074744, calculated checksums for field1: crc32 993334256, innodb 2046145943, none 3735928559, stored checksum in field2 1139795846, calculated checksums for field2: crc32 993334256, innodb 1606613742, none 3735928559, page LSN 0 254222157, low 4 bytes of LSN at page end 254221236, page number (if stored to page already) 5, space id (if created with >= MySQL-4.1.1 and stored already) 0
InnoDB: Page may be a transaction system page
InnoDB: Database page corruption on disk or a failed
InnoDB: file read of page 5.
InnoDB: You may have to recover from a backup.
InnoDB: It is also possible that your operating
InnoDB: system has corrupted its own file cache
InnoDB: and rebooting your computer removes the
InnoDB: error.
InnoDB: If the corrupt page is an index page
InnoDB: you can also try to fix the corruption
InnoDB: by dumping, dropping, and reimporting
InnoDB: the corrupt table. You can use CHECK
InnoDB: TABLE to scan your table for corruption.
InnoDB: See also http://dev.mysql.com/doc/refman/5.6/en/forcing-innodb-recovery.html
InnoDB: about forcing recovery.
InnoDB: Ending processing because of a corrupt database page.
2017-08-15 11:36:46 7f11c48e1720  InnoDB: Assertion failure in thread 139714288817952 in file buf0buf.cc line 4201
InnoDB: We intentionally generate a memory trap.
InnoDB: Submit a detailed bug report to http://bugs.mysql.com.
InnoDB: If you get repeated assertion failures or crashes, even
InnoDB: immediately after the mysqld startup, there may be
InnoDB: corruption in the InnoDB tablespace. Please refer to
InnoDB: http://dev.mysql.com/doc/refman/5.6/en/forcing-innodb-recovery.html
InnoDB: about forcing recovery.
03:36:46 UTC - mysqld got signal 6 ;
This could be because you hit a bug. It is also possible that this binary
or one of the libraries it was linked against is corrupt, improperly built,
or misconfigured. This error can also be caused by malfunctioning hardware.
We will try our best to scrape up some info that will hopefully help
diagnose the problem, but since we have already crashed, 
something is definitely wrong and this may fail.
key_buffer_size=16777216
read_buffer_size=262144
max_used_connections=0
max_threads=1000
thread_count=0
connection_count=0
It is possible that mysqld could use up to 
key_buffer_size + (read_buffer_size + sort_buffer_size)*max_threads = 798063 K  bytes of memory
Hope that's ok; if not, decrease some variables in the equation.
 
Thread pointer: 0x0
 
Attempting backtrace. You can use the following information to find out
 
where mysqld died. If you see no messages after this, something went
 
terribly wrong...
 
stack_bottom = 0 thread_stack 0x40000
 
/usr/local/mysql/bin/mysqld(my_print_stacktrace+0x35)[0x8e64b5]
 
/usr/local/mysql/bin/mysqld(handle_fatal_signal+0x41b)[0x652fbb]
 
/lib64/libpthread.so.0(+0xf7e0)[0x7f11c44c77e0]
 
/lib64/libc.so.6(gsignal+0x35)[0x7f11c315d625]
 
/lib64/libc.so.6(abort+0x175)[0x7f11c315ee05]
 
/usr/local/mysql/bin/mysqld[0xa585c5]
 
/usr/local/mysql/bin/mysqld[0xa6c7b4]
 
/usr/local/mysql/bin/mysqld[0xa6cbc7]
 
/usr/local/mysql/bin/mysqld[0xa5bce2]
 
/usr/local/mysql/bin/mysqld[0xa1e2ba]
 
/usr/local/mysql/bin/mysqld[0xa0bf60]
 
/usr/local/mysql/bin/mysqld[0x95a427]
 
/usr/local/mysql/bin/mysqld(_Z24ha_initialize_handlertonP13st_plugin_int+0x48)[0x58f788]
 
/usr/local/mysql/bin/mysqld[0x6e4a36]
 
/usr/local/mysql/bin/mysqld(_Z11plugin_initPiPPci+0xb3e)[0x6e826e]
 
/usr/local/mysql/bin/mysqld[0x582d85]
 
/usr/local/mysql/bin/mysqld(_Z11mysqld_mainiPPc+0x4d8)[0x587d18]
 
/lib64/libc.so.6(__libc_start_main+0xfd)[0x7f11c3149d5d]
 
/usr/local/mysql/bin/mysqld[0x57a019]
 
The manual page at http://dev.mysql.com/doc/mysql/en/crashing.html contains
 
information that should help you find out what is causing the crash.
 
161108 11:36:46 mysqld_safe mysqld from pid file /usr/local/mysql/var/VM_241_49_centos.pid ended
 
------------------------------------------------------------------------------

二、問題分析

從日志中可以看出是innodb引擎出了問題。日志里提示到  http://dev.mysql.com/doc/refman/5.6/en/forcing-innodb-recovery.html 查看強制恢復的方法。在mysql的配置文件my.cnf里找到 [mysqld]字段下,添加 innodb_force_recovery=1:

[mysqld]innodb_force_recovery = 1

如果innodb_force_recovery = 1不生效,則可嘗試2——6幾個數字
然后重啟mysql,重啟成功。然后使用mysqldump或 pma 導出數據,執行修復操作等。修復完成后,把該參數注釋掉,還原默認值0。
配置文件的參數:innodb_force_recovery
innodb_force_recovery影響整個InnoDB存儲引擎的恢復狀況。默認為0,表示當需要恢復時執行所有的恢復操作(即校驗數據頁/purge undo/insert buffer merge/rolling back&forward),當不能進行有效的恢復操作時,mysql有可能無法啟動,并記錄錯誤日志;
innodb_force_recovery可以設置為1-6,大的數字包含前面所有數字的影響。當設置參數值大于0后,可以對表進行select,create,drop操作,但insert,update或者delete這類操作是不允許的。

  • 1(SRV_FORCE_IGNORE_CORRUPT):忽略檢查到的corrupt頁。

  • 2(SRV_FORCE_NO_BACKGROUND):阻止主線程的運行,如主線程需要執行full purge操作,會導致crash。

  • 3(SRV_FORCE_NO_TRX_UNDO):不執行事務回滾操作。

  • 4(SRV_FORCE_NO_IBUF_MERGE):不執行插入緩沖的合并操作。

  • 5(SRV_FORCE_NO_UNDO_LOG_SCAN):不查看重做日志,InnoDB存儲引擎會將未提交的事務視為已提交。

  • 6(SRV_FORCE_NO_LOG_REDO):不執行前滾的操作。

三、解析方案

一般修復方法參考:

第一種方法

建立一張新表:
create table demo_bak  #和原表結構一樣,只是把INNODB改成了MYISAM。
把數據導進去
insert into demo_bak select * from demo;
刪除掉原表:
drop table demo;
注釋掉 innodb_force_recovery 之后,重啟。
重命名:
rename table demo_bak to demo;
最后改回存儲引擎:
alter table demo engine = innodb

第二種方法

另一個方法是使用mysqldump將表格導出,然后再導回到InnoDB表中。這兩種方法的結果是相同的。 
備份導出(包括結構和數據):
mysqldump -uroot -p123 test > test.sql
還原方法1:
use test;
source test.sql
還原方法2(系統命令行):
mysql -uroot -p123 test < test.sql;
注意,CHECK TABLE命令在InnoDB數據庫中基本上是沒有用的。

第三種方法
1、配置my.cnf

配置innodb_force_recovery = 1或2——6幾個數字,重啟MySQL

2、導出數據腳本

mysqldump -uroot -p123 test > test.sql
導出SQL腳本。或者用Navicat將所有數據庫/表導入到其他服務器的數據庫中。
注意:這里的數據一定要備份成功。然后刪除原數據庫中的數據。

3、刪除ib_logfile0、ib_logfile1、ibdata1

備份MySQL數據目錄下的ib_logfile0、ib_logfile1、ibdata1三個文件,然后將這三個文件刪除

4、配置my.cnf

將my.cnf中innodb_force_recovery = 1或2——6幾個數字這行配置刪除或者配置為innodb_force_recovery = 0,重啟MySQL服務

5、將數據導入MySQL數據庫

mysql -uroot -p123 test < test.sql; 或者用Navicat將備份的數據導入到數據庫中。
此種方法下要注意的問題:
  1、ib_logfile0、ib_logfile1、ibdata1這三個文件一定要先備份后刪除;
  2、一定要確認原數據導出成功了
  3、當數據導出成功后,刪除原數據庫中的數據時,如果提示不能刪除,可在命令行進入MySQL的數據目錄,手動刪除相關數據庫的文件夾或者數據庫文件夾下的數據表文件,前提是數據一定導出或備份成功。

感謝各位的閱讀,以上就是“mysql中innodb_force_recovery參數分析”的內容了,經過本文的學習后,相信大家對mysql中innodb_force_recovery參數分析這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

眉山市| 榆社县| 嘉黎县| 怀柔区| 潢川县| 桓台县| 灵丘县| 白玉县| 靖州| 同德县| 临邑县| 团风县| 塘沽区| 兴和县| 沛县| 霍城县| 邓州市| 乌什县| 故城县| 泾川县| 抚宁县| 和顺县| 家居| 罗源县| 闽侯县| 明星| 绥中县| 和林格尔县| 海林市| 泰来县| 葫芦岛市| 屯门区| 轮台县| 南川市| 肥西县| 东海县| 伊宁县| 丰都县| 化德县| 五华县| 井陉县|