1.使用myqldump备份出错:(--opt快速导出)

mysqldump -u root -p --database mysql --opt -h127.0.0.1 > mysql.sql
Enter password:
-- Warning: Skipping the data of table mysql.event. Specify the --events option explicitly.

  ###因为mysqldump默认是不备份事件表的,只有加了--events 才会解决加上--events --ignore-table=mysql.events参数即可:

mysqldump  -u root -p  --database mysql --opt -h127.0.0.1 --events --ignore-table=mysql.events > mysql.sql

2.mysql登陆忘记密码 或者密码正确却登录不了

mysql -u root -p -h127.0.0.1  -P 42056(在mysql多实例的情况下,一定要加-P端口号的方式登录,否则即使密码再怎么对都无法登陆哟~!)
Enter password:
ERROR 2003 (HY000): Can't connect to MySQL server on '127.0.0.1' (111)

###在my.cnf中加入参数skip-grant-tables

mysql即可进入修改密码。

mysql> update user set password=PASSWORD('123') where user='root';

mysql> flush privileges;

GRANT ALL PRIVILEGES ON *.* TO root@"%" IDENTIFIED BY "123";
ERROR 1290 (HY000): The MySQL server is running with the --skip-grant-tables option so it cannot execute this statement

###授权的时候报错:执行flush privileges后再次授权就可以了。

 

3.基于安全考虑root账户一般只能本地访问,但是在开发过程中可能需要打开root的远程访问权限。下面是基本的步骤:

登录到mysql中,为root进行远程访问的授权,执行下面的命令:
mysql> GRANT ALL PRIVILEGES ON *.* TO root@"%" IDENTIFIED BY "root";
mysql> flush privileges;
"%"表示任何主机都可以远程登录到该服务器上访问。如果要限制只有某台机器可以访问,将其换成相应的IP即可,如:
GRANT ALL PRIVILEGES ON *.* TO root@"172.168.193.25" IDENTIFIED BY "root";

mysqldump: Couldn't execute 'SHOW FUNCTION STATUS WHERE Db = 's14_50hero'': Column count of mysql.proc is wrong. Expected 20, found 16. The table is probably corrupted (1547)
错误原因:
是由于曾经升级过mysql,或用不同的MySQL版本进行备份迁移恢复。升级和迁移完后未使用mysql_upgrade升级数据结构造成的。
mysql.proc:
是MySQL的系统表,用来记录存储过程或函数的信息。使用desc mysql.proc 查看上面不同版本的MySQL的mysql.proc,果然出错的MySQL的mysql.proc只有16列。
解决办法:
使用命令:mysql_upgrade -udbaroot -pdbaroot20070508 -h127.0.0.1 --datadir=/usr/local/mysql/var --force (mysql_upgrade修复)

做好mysql AB复制后,master总报:
[Warning] Statement may not be safe to log in statement format.……
每更新一条数据就出现一次,导致日志太多,而且淹没了重要的日志。意思应该是statement 格式不安全。
statement format 应该是 binlog的一种格式,进入mysql查看一下
  show global variables like 'binlog_format';
  果然当前的格式为statement
  需要把格式改为 mixed格式
  修改slave的 my.cnf
  在[mysqld]下面加入下面这行
  binlog_format=mixed

 4.mysql登录报错:

mysql -udbaroot -pdbaroot20170315 -h127.0.0.1 -P3306
mysql: relocation error: mysql: symbol strmov, version libmysqlclient_16 not defined in file libmysqlclient.so.16 with link time reference

原来是以前的文件/usr/bin/mysql没替换的原因   安装源码包mysql时候一定要先卸载rpm包的mysql
用以下二条命令搞定了。
cd /usr/bin
mv mysql mysql.rpmbak
ln -s /usr/local/mysql/bin/mysql /usr/bin/mysql

5.mysql宕机起不来

查看mysql日志:
170921 8:48:44 InnoDB: Database was not shut down normally!
InnoDB: Error: tried to read 16384 bytes at offset 0 43909120.
InnoDB: Fatal error: cannot read from file. OS error number 17.
判断是mysql非正常关闭导致innodb数据表损坏,因是SDB,解决方法是:备份原先的var目录,重新初始化,使用mysql_online_repair.sh在线重导 MDB数据库并修复了主从同步

#!/bin/sh
if (($# != 2));then
echo "Usage: sh mysql_online_repair.sh MDBIP DBSUFFIX"
exit 1
fi

. /etc/sysconfig/network-scripts/ifcfg-eth1

MDBIP=$1
HERODBSUF=$2

HEROUSER="dbauser"
HEROPWD="bUyfbxfVaCWaliQe"

ROOTPWD="dbaroot20070508"

[ ! -e "/etc/my.cnf" ] && exit
[ "$IPADDR" == "$(awk '/master-host/ {print $3}' /etc/my.cnf)" ] && exit
echo "mysqldump -h${MDBIP} -u${HEROUSER} -p${HEROPWD} -R --triggers --single-transaction --flush-logs --master-data --database ${HERODBSUF}_50hero ${HERODBSUF}_50hero_index ${HERODBSUF}_50hero_logs ${HERODBSUF}_50hero_ext0 > ${HERODBSUF}.sql"

mysqldump -h${MDBIP} -u${HEROUSER} -p${HEROPWD} -R --triggers --single-transaction --flush-logs --master-data --database ${HERODBSUF}_50hero ${HERODBSUF}_50hero_index ${HERODBSUF}_50hero_logs ${HERODBSUF}_50hero_ext0 > ${HERODBSUF}.sql

echo "mysql import ${HERODBSUF}.sql"
mysql -udbaroot -p${ROOTPWD} -h127.0.0.1 -e 'slave stop;'
mysql -udbaroot -p${ROOTPWD} -h127.0.0.1 < ${HERODBSUF}.sql
mysql -udbaroot -p${ROOTPWD} -h127.0.0.1 -e 'slave start;'

mysql -udbaroot -p${ROOTPWD} -h127.0.0.1 -e 'show slave status\G'

6.误删除数据库不要紧,binlog来帮你

首先分析什么时间出问题的,根据数据库丢失的时间处理binlog数据

直接本机导出,例如:导出 "2004-12-25 11:25:56"至"2004-12-25 11:25:56"的binlog数据:
mysqlbinlog --start-datetime="2004-12-25 11:25:56" --stop-datetime="2004-12-25 11:25:56" mysql-bin.000012 > 000012.sql

再把所有sql导入到数据库中
mysql -udbaroot -pdbaroot -h127.0.0.1 -f < 000012.sql

7.清除mysqlbinglog
#mysql -udbaroot -pdbaroot20070508 -h127.0.0.1 -e "purge binary logs to 'mysql-bin.000639';"
修改binlog过期自动清理(设为10天自动清理)
把binlog的过期时间设置为10天;
mysql -udbaroot -pdbaroot20070508 -h127.0.0.1 -e "set global expire_logs_days = 10;"
刷一下log使上面的设置生效,否则不生效。
mysql -udbaroot -pdbaroot20070508 -h127.0.0.1 -e "flush logs;"
为保证在MYSQL重启后仍然有效,在my.cnf中也加入此参数设置
expire_logs_days = 10
通过show global variables like '%expire_logs_days%';可以查看设置是否成功
mysql -udbaroot -pdbaroot20070508 -h127.0.0.1 -e "show global variables like '%expire_logs_days%';"

8.升级了mysql从5.0升级到5.1遇到的问题

(1)删除原先的mysql目录rm -rf

(2)安装5.1的rpm包

(3)mysql --version
  mysql: error while loading shared libraries: libtinfo.so.5: cannot open shared object file: No such file or directory

这是因为没有识别到ncurses-devel开发包导致的。ncurses包yum已经安装,运行某些程序时(如:fp)提示:

解决方法:找到/usr/lib/下的libncurses.so文件。

ln -s libncurses.so.5.5 /usr/lib64/libtinfo.so.5   使用源文件做个软连接即可解决问题。

mysql --version
mysql Ver 14.14 Distrib 5.1.63, for unknown-linux-gnu (x86_64) using EditLine wrapper

8.Can't locate Time/HiRes.pm in @INC (@INC contains: /usr/local/lib64/perl5 /usr/local/share/perl5 /usr/lib64/perl5/vendor_perl /usr/share/perl5/vendor_perl /usr/lib64/perl5 /usr/share/perl5 .) at /usr/bin/innobackupex line 23.
BEGIN failed--compilation aborted at /usr/bin/innobackupex line 23.

需要安装 yum install perl-Time-HiRes

9.配置了mysqld_multi启动mysql,但关闭时却关闭不了。查了一下,原来是如下原因:

在my.cnf中配置了密码:

如图改为正确的mysql登录密码即可。

mysql错误集锦的更多相关文章

  1. mysql 错误集锦

    Got fatal error 1236 from master when reading data from binary log: 'could not find next log; the fi ...

  2. MySQL错误日志总结

    MySQL错误日志是记录MySQL 运行过程中较为严重的警告和错误信息,以及MySQL每次启动和关闭的详细信息.错误日志的命名通常为hostname.err.其中,hostname表示服务器主机名. ...

  3. Mysql错误:Ignoring query to other database解决方法

    Mysql错误:Ignoring query to other database解决方法 今天登陆mysql show databases出现Ignoring query to other datab ...

  4. MySQL错误:The user specified as a definer (XXX@XXX) does not exist

    今天由于更换服务器,重新再本地备份了数据库,试运行程序报错,如下: MySQL错误:The user specified as a definer (XXX@XXX) does not exist 意 ...

  5. ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)--MySQL错误

    MySQL错误整理: 错误一: ERROR (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/my ...

  6. PHP开发者常犯的MySQL错误

    PHP开发者常犯的MySQL错误   数据库是WEB大多数应用开发的基础.如果你是用PHP,那么大多数据库用的是MYSQL也是LAMP架构的重要部分. PHP看起来很简单,一个初学者也可以几个小时内就 ...

  7. Wamp Mysql错误消息 语言设置

    Wamp Mysql错误消息 语言设置 http://my.oschina.net/wandershi/blog/264347 打开my.ini   找到 [wampmysqld] port = 33 ...

  8. EntityFramwork6连接MySql错误

    EntityFramwork6连接MySql错误 使用EF6连接MySql产生Exception: ProHub.ssdl(2,2) : 错误 0152: MySql.Data.MySqlClient ...

  9. MySQL 错误日志(Error Log)

    同大多数关系型数据库一样,日志文件是MySQL数据库的重要组成部分.MySQL有几种不同的日志文件.通常包括错误日志文件,二进制日志,通用日志,慢查询日志,等等. 这些日志能够帮助我们定位mysqld ...

随机推荐

  1. 最新的Android版本和API Level的对应关系表

    在项目开发过程中,经常会用到API Level和Android平台版本的对照,来进行一些方法的调用,现在就把对照表贴出来,供开发人员参考,并且方便自己查阅. Platform Version API ...

  2. R语言︱机器学习模型评价指标+(转)模型出错的四大原因及如何纠错

    笔者寄语:机器学习中交叉验证的方式是主要的模型评价方法,交叉验证中用到了哪些指标呢? 交叉验证将数据分为训练数据集.测试数据集,然后通过训练数据集进行训练,通过测试数据集进行测试,验证集进行验证. 模 ...

  3. VxWorks程序指南

    ******************************************* 一.任务 ******************************************* 任务状态:挂起 ...

  4. Netty的并发编程实践5:不要依赖线程优先级

    当有多个线程同时运行的时候,由线程调度器来决定哪些线程运行.哪些等待以及线程切换的时间点,由于各个操作系统的线程调度器实现大相径庭,因此,依赖JDK自带的线程优先级来设置线程优先级策略的方法是错误和非 ...

  5. (七)java类和对象

    一个类定义一个新的数据类型,也就是定义了一个逻辑框架,定义了它的成员之间的关系.可以通过这种类型来声明该类型的对象,通过new关键词来实例化对象,也就是为该类型的对象动态的分配物理内存空间,这个分配过 ...

  6. pat1111-1120

    1111 比较麻烦的最短路 #include<cmath> #include<map> #include<iostream> #include<cstring ...

  7. 使用定时器限制点击按钮发送短信(附源码)--JavaScript小案例

    不说多哈,有注释哦,直接贴代码了哈,有疑问请追评呢…… 1.禁用按钮: this.disabled = "disabled"(this指按钮)或: this.disabled = ...

  8. 【BZOJ3110】K大数查询(整体二分)

    [BZOJ3110]K大数查询(整体二分) 题面 BZOJ 题解 看了很久整体二分 一直不知道哪里写错了 ... 又把树状数组当成线段树区间加法来用了.. 整体二分还是要想清楚在干什么: 我们考虑第\ ...

  9. 【CJOJ P2110】YL杯超级篮球赛

    [CJOJ P2110]YL杯超级篮球赛 Description 一年一度的高一YL杯超级篮球赛开赛了.当然,所谓超级的意思是参赛人数可能多于5人.小三对这场篮球赛非常感兴趣,所以一场都没有落下.每天 ...

  10. LightOJ1370 Bi-shoe and Phi-shoe

    题意 给出一些数字,对于每个数字找到一个欧拉函数值大于等于这个数的数,求找到的所有数的最小和. Solution 线性筛出phi,把询问数组排序搞就行了 # include <bits/stdc ...