用xtrabackup恢複到不同版本MySQL庫後出現無法建立使用者的問題

來源:互聯網
上載者:User

標籤:恢複   mysql   使用者表   procs   proc_priv   

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

               Cannotload from MySQL.proc. Thetable is probably corrupted

2.但可以用insert into mysql.user values();進行添加,

    密碼部分可能需要使用selectpassword()求出密碼加密值後再插入。

3.需要對mysql.proc_priv表和mysql.procs表進行修複。

4.修複有三種方式:

1.直接建立一個新的空執行個體,然後將沒有被破壞的表檔案覆蓋到有問題的實力上。由於mysql庫的表在5.6-5.7版本上都是myisam表。可以直接複製表檔案進行修改。

2.實用mysql_upgrade程式進行修複表結構

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

  輸出如下:

Enterpassword:

Checkingif update is needed.

Checkingserver version.

Runningqueries to upgrade MySQL server.

Checkingsystem 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

Thesys schema is already up to date (version 1.5.1).

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

   使用show create table語句對新的空執行個體和舊的損壞執行個體進行比較,可以發現:某些欄位上,新舊版本,percona和mysql官方版本的確在某些欄位的長度定義上有所不同。舊版本,官方版本設定的欄位長度可能相對於新版本和分支版本偏短。偏短雖然在理論上可以存放下插入的資料,但是伺服器是不允許和不識別的,造成了無法插入新使用者的問題出現。這就需要手工建立DML語句進行同步新舊版本的表結構。這樣可以將修改同步到叢集或者從庫中,比較安全。

  

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


本文出自 “漫漫SQL路......” 部落格,請務必保留此出處http://l0vesql.blog.51cto.com/4159433/1958927

用xtrabackup恢複到不同版本MySQL庫後出現無法建立使用者的問題

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.