用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中显示出来,但会自行忽略这个错误。

相关文章
相关标签/搜索