MYSQL 的异常CRASH事件处理
检查问题的过程
******************************************************************************************
ps -ef|grep mysql
kill -9 pid值
然后才可以正常启动,要不就一直重启不停。
1、 mysql -uroot -pD*********
2、
mysql> show variables like 'log_error';
+---------------+----------------------------------------------+
| Variable_name | Value |
+---------------+----------------------------------------------+
| log_error | /usr/local/db/mysql/data/AY130805143906Z.err |
+---------------+----------------------------------------------+
1 row in set (0.00 sec)
=========================================================================================
错误日志如下:
150420 13:48:48 [ERROR] mysqld got signal 11 ;
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.
To report this bug, see http://kb.askmonty.org/en/reporting-bugs
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.
Server version: 5.5.39-MariaDB
key_buffer_size=16384
read_buffer_size=262144
max_used_connections=34
max_threads=1002
thread_count=18
It is possible that mysqld could use up to
key_buffer_size + (read_buffer_size + sort_buffer_size)*max_threads = 338517 K bytes of memory
Hope that's ok; if not, decrease some variables in the equation.
******************************************************************************************
尝试的解决办法:
1、怀疑是磁盘空间不足造成: 扩大/usr/local/db/mysql/data的磁盘空间 mount上大数据盘
2、怀疑是参数配置有问题造成:
修改/etc/my.cnf为
#拷贝 my-samll.cnf
\cp /usr/local/mysql/support-files/my-small.cnf /etc/my.cnf
#追加文本行
sed -i -e '/thread_stack = 240K/a\lower_case_table_names=1\ninnodb_file_per_table=1\nskip-grant-tables\nskip-name-resolve\nback_log = 384\nthread_stack = 256K\ntable_cache = 400\nsort_buffer_size=32M\nthread_cache_size=120\njoin_buffer_size = 8M\nmyisam_sort_buffer_size = 64M\nthread_cache_size = 64\nquery_cache_size = 0\nquery_cache_type = 0\ntmp_table_size = 256M\nmax_connections = 214\nmax_connect_errors = 1000\nwait_timeout = 31536000\nthread_concurrency = 8\ninnodb_additional_mem_pool_size=4M\ninnodb_flush_log_at_trx_commit=1\ninnodb_log_buffer_size=2M\ninnodb_thread_concurrency=8\ntmp_table_size=64M\ninteractive_timeout=31536000\nlog = /tmp/mysql.log\n' /etc/my.cnf
#执行替换
sed -i '/^key_buffer_size =/ckey_buffer_size =384M' /etc/my.cnf
#替换
sed -i '/^max_allowed_packet =/cmax_allowed_packet = 4M' /etc/my.cnf
#替换
sed -i '/^sort_buffer_size =/csort_buffer_size = 6M' /etc/my.cnf
#替换
sed -i '/^read_buffer_size =/cread_buffer_size = 4M' /etc/my.cnf
#替换
sed -i '/^read_rnd_buffer_size =/cread_rnd_buffer_size = 16M' /etc/my.cnf
3、将lxyyProduct ,zxpt , hjt,crm 四个项目从tomcat中移除,先进行稳定性测试,如果没问题再想办法处理。
4、
参考阅读:http://www.tuicool.com/articles/AB7Jfu
原来linux内核信号量默认设置太小,压测的时候,造成大量等待,
默认
# cat /proc/sys/kernel/sem
250 32000 32 128
说明:
第一列,表示每个信号集中的最大信号量数目。
第二列,表示系统范围内的最大信号量总数目。
第三列,表示每个信号发生时的最大系统操作数目。
第四列,表示系统范围内的最大信号集总数目。
将第三列调大一点,参考网上的数据
echo "kernel.sem=250 32000 100 128″>>/etc/sysctl.conf
然后sysctl -p
重启mysql
总结:
1、是不是数据库版本问题,尽量升级到最新的数据库;
http://blog.chinaunix.net/uid-10449864-id-2956923.html
2、SQL语句有问题,参考上面的链接。
3、设置的系统打开文件数太少:
http://blog.chinaunix.net/uid-20728886-id-138147.html
4、Query Cache引起的问题,办法是禁用掉:
http://www.xue163.com/exploit/163/1635340.html
http://www.php230.com/weixin1410064192.html
关闭方法很简单,有两种:
1、同时设置选项 query_cache_type = 0 和 query_cache_size = 0;
2、如果用源码编译MySQL的话,编译时增加参数 --without-query-cache 即可;
黄海采用的是方法1。
5、设置记录每条执行过的SQL语句:
#创建一个空文件
touch /usr/local/db/sql_row.log
vi /etc/my.cnf 添加在[mysqld]块中
log=/usr/local/db/sql_row.log
需要手动建立此文件,然后
chmod /usr/local/db/sql_row.log
service mysql restart
MYSQL 的异常CRASH事件处理的更多相关文章
- mysql数据库连接异常问题(总结)
mysql数据库连接异常问题(总结) 1.1 前言 最近项目由1个数据源增加至了3个数据源(连接池使用C3P0),结果各种奇葩的数据库连接问题接踵而至,为防止将来再次遇到同样的问题不犯同样错误,现 ...
- Mysql数据库异常
1. Mysql数据库异常 1.1. 数据库问题之Got error 28 from storage engine 原因首先检查磁盘是否已满,df -h一下 很可能是日志数据过大,查看该目录下文件夹和 ...
- MySQL复制异常大扫盲:快速溯源与排查错误全解
MySQL复制异常大扫盲:快速溯源与排查错误全解https://mp.weixin.qq.com/s/0Ic8BnUokyOj7m1YOrk1tA 作者介绍王松磊,现任职于UCloud,从事MySQL ...
- 诊断:记一次存储异常CRASH致数据库无法正常打开的恢复
数据库存储异常crash,首先控制文件出现问题 ORA-: ????? ???? ORA-: ???? : '/oracledata/oradata/orc11rac/orc11rac/system0 ...
- Linux下Mysql启动异常排查方案
遇到Mysql启动异常问题,可以从以下几个方面依次进行问题排查: (1)如果遇到“Can't connect to local MySQL server through socket '/tmp/my ...
- MySQL 事务 异常 事务隔离的级别
MySQL 事务 异常 事务隔离的级别 事务 在你操作数据库的同时,有可能其他用户还会不断地对数据进行增删改查操作.为了避免并行进行时出现混乱,就产生了"事务".事务就是要保证 ...
- 一则线上MySql连接异常的排查过程
Mysql作为一个常用数据库,在互联网系统应用很多.有些故障是其自身的bug,有些则不是,这里以前段时间遇到的问题举例. 问题 当时遇到的症状是这样的,我们的应用在线上测试环境,JMeter测试过程中 ...
- MySql连接异常解决
这两天遇到一个mysql连接的问题,找人弄了好几天也没弄好,先看一下报错信息: ============================================================ ...
- Dapper MySql DateTime 异常
实体类 字段类型 DateTime? ,MySQL数据库中字段类型 datetime NULL , 使用dapper扩展读取,报异常:Error Parse column: ** - Object. ...
随机推荐
- lintcode-83-落单的数 II
83-落单的数 II 给出3*n + 1 个的数字,除其中一个数字之外其他每个数字均出现三次,找到这个数字. 样例 给出 [1,1,2,3,3,3,2,2,4,1] ,返回 4 挑战 一次遍历,常数级 ...
- PAT 甲级 1015 Reversible Primes
https://pintia.cn/problem-sets/994805342720868352/problems/994805495863296000 A reversible prime in ...
- [Java] 为什么要定义接口
摘自:https://www.douban.com/note/61810488/ 通俗的讲,就是为了降低耦合度. 一个很搞笑的例子: 看看下面的程序: 一个学校里边,有两种人:学生.老师.他们都要吃饭 ...
- struts2的验证
1.原理 当浏览器向服务器提交表单数据时,在服务器端需要对表单数据的有效性进行校验. “校验方法”会在“业务方法”之前调用. 2.实现验证的两种方式 struts2校验的两种实现方法: 1. 手工编写 ...
- Netscaler的超高端口复用助力应对公网地址紧张
Netscaler的超高端口复用助力应对公网地址紧张 http://blog.51cto.com/caojin/1898351 经常会有人问一个IP只有65535(姑且不考虑预留端口),从Big-ip ...
- SPOJ Repeats(后缀数组+RMQ-ST)
REPEATS - Repeats no tags A string s is called an (k,l)-repeat if s is obtained by concatenating k& ...
- 我的emacs配置部分
考场必记8行 (global-set-key (kbd "RET") 'newline-and-indent)//换行 (global-set-key (kbd "C-a ...
- [洛谷P1407][国家集训队]稳定婚姻
题目大意:有$n$对夫妻和$m$对情人,如果一对情人中的两人都离婚了,那么他们可以结为夫妻.对于每一对夫妻,若他们离婚后所有人依然可以结婚,那么就是不安全的,否则是安全的.问每一对夫妻是否安全. 题解 ...
- BZOJ3243 [Noi2013]向量内积 【乱搞】
题目链接 BZOJ3243 题解 模数只有\(2\)或\(3\),可以大力讨论 如果模数为\(2\),乘积结果只有\(1\)或\(0\) 如果一个向量和前面所有向量乘积都为\(1\),那么其和前面向量 ...
- 洛谷 P1379 八数码难题 解题报告
P1379 八数码难题 题目描述 在3×3的棋盘上,摆有八个棋子,每个棋子上标有1至8的某一数字.棋盘中留有一个空格,空格用0来表示.空格周围的棋子可以移到空格中.要求解的问题是:给出一种初始布局(初 ...