[MySQL]记录一次线上故障处理过程--> has more than 'max_user_connections' active connections...

org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.exceptions.PersistenceException:

### Error querying database. Cause: org.springframework.transaction.CannotCreateTransactionException:Could not open JDBC Connection for transaction; nested exception is com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: User NUXUSERalready has more than 'max_user_connections' active connections

......

### Cause: org.springframework.transaction.CannotCreateTransactionException:Could not open JDBC Connection for transaction; nested exception is com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: User NUXUSER already has more than 'max_user_connections' active connections

......


以上这是email报警信息,还有应用页面报500,503,504错误信息。



1 半夜接到call之后,马上登陆db,检查128组db节点组的状况,发现有db00701和db10201的connections超过了2000次。


2 想到这2台好像是上周刚维护过ssd的db server,直接ssh进取查看 sshdb00701


3 进入db00701之后,ps -eaf|grep mysql,运行正常,查看错误日志信息,发现写入binlog频繁报错。


4 进入binlog 目录/data/binlog/,发现目录下面有100多个binlog,足够有5天以上的binlog,奇怪怎么会有这么多,不是有crontab任务每天移走2天前的binlog吗?马上crontab -l发现移走binlog的任务没有开启,突然一想到,不会binlog目录磁盘满了吧?


5 执行df -h,看到/data/binlog/确实 used 为100%了,赶紧手动移走binlog,之后3分钟过后,应用正常了,页面不报5XX的错误了,db00701和db10201的connections也正常了。


总结问题原因有二:

1 此次数据库 db server切换,山姆大叔的sa组在加监控的时候,粗心大意没有把binlog的监控给加上,所以没有及时报警通知磁盘满了。

2 我们db组也没有及时double confirmed这个monitor的事情。


看来以后还得更加仔细才行。

mysqld_exporter的配置文件中,"collect.global_variables"用于指定需要采集的全局变量,其中包括"thread_pool_size"和"max_connections"等参数。这些全局变量的值将在指定的时间间隔内被采集,并通过Prometheus进行监控和告警。 对于"thread_pool_size"和"max_connections"这两个参数,需要根据具体的MySQL服务器配置和实际情况进行设置。 - thread_pool_size:该参数指定MySQL服务器的线程池大小,即同时可以处理的客户端连接数。如果MySQL服务器经常出现"Too many connections"的错误,可以适当增加该参数的值。但是,过高的线程池大小也会导致系统资源的浪费,因此需要根据实际情况进行调整。一般来说,可以将该参数设置为CPU核心数的2~3倍。 - max_connections:该参数指定MySQL服务器允许的最大连接数。如果MySQL服务器经常出现连接数过高的问题,可以适当降低该参数的值。但是,过低的最大连接数也会导致系统无法处理更多的客户端连接请求,因此需要根据实际情况进行调整。一般来说,可以根据服务器的硬件配置和实际负载情况,将该参数设置为100~1000之间的值。 需要注意的是,调整这些参数的值可能会对MySQL服务器的性能和稳定性产生影响,因此建议在进行调整之前,先进行充分的测试和评估。同时,建议使用监控工具对MySQL服务器的运行状态进行实时监控,及时发现并解决问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值