用xtrabackup恢復到不一樣版本MySQL庫後出現沒法建立用戶的問題

1.grant方式和create user建立用戶時提示:-mysql

               Cannot load from MySQL.proc. The table is probably corruptedsql

2.但能夠用insert into mysql.user values();進行添加,centos

    密碼部分可能須要使用select password()求出密碼加密值後再插入。安全

3.須要對mysql.proc_priv表和mysql.procs表進行修復。服務器

4.修復有三種方式:ide

1.直接建立一個新的空實例,而後將沒有被破壞的表文件覆蓋到有問題的實力上。因爲mysql庫的表在5.6-5.7版本上都是myisam表。能夠直接複製表文件進行修改。加密

2.實用mysql_upgrade程序進行修復表結構spa

  [centos:]mysql_upgrade  -ulocalhost -u root -p123.net

  輸出以下:server

Enter password:

Checking if update is needed.

Checking server version.

Running queries to upgrade MySQL server.

Checking system database.

mysql.columns_priv                                 OK

mysql.db                                           OK

mysql.engine_cost                                  OK

mysql.event                                        OK

mysql.func                                         OK

mysql.general_log                                  OK

mysql.gtid_executed                                OK

mysql.help_category                                OK

mysql.help_keyword                                 OK

mysql.help_relation                                OK

mysql.help_topic                                   OK

mysql.innodb_index_stats                           OK

mysql.innodb_table_stats                           OK

mysql.mysql_recover                                OK

mysql.ndb_binlog_index                             OK

mysql.plugin                                       OK

mysql.proc                                         OK

mysql.procs_priv                                   OK

mysql.proxies_priv                                 OK

mysql.server_cost                                  OK

mysql.servers                                      OK

mysql.slave_master_info                            OK

mysql.slave_relay_log_info                         OK

mysql.slave_worker_info                            OK

mysql.slow_log                                     OK

mysql.tables_priv                                  OK

mysql.time_zone                                    OK

mysql.time_zone_leap_second                        OK

mysql.time_zone_name                               OK

mysql.time_zone_transition                         OK

mysql.time_zone_transition_type                    OK

mysql.user                                         OK

The sys schema is already up to date (version 1.5.1).

3.使用最矬可是對複製最友好的DML語句進行修改

   使用show create table語句對新的空實例和舊的損壞實例進行比較,能夠發現:某些字段上,新舊版本,perconamysql官方版本的確在某些字段的長度定義上有所不一樣。舊版本,官方版本設定的字段長度可能相對於新版本和分支版本偏短。偏短雖然在理論上能夠存放下插入的數據,可是服務器是不容許和不識別的,形成了沒法插入新用戶的問題出現。這就須要手工建立DML語句進行同步新舊版本的表結構。這樣能夠將修改同步到集羣或者從庫中,比較安全。

  

值得注意的是:雖然短於設定值,系統會認爲表損壞。可是長於設定值,或者字段名大小寫差別,系統雖然會檢查到並在error log中顯示出來,但會自行忽略這個錯誤。

相關文章
相關標籤/搜索