云数据库故障排查之偶发fail to connect mysql,刷新界面恢复

描述:

客户端程序报错:PHP Fatal error:  Uncaught exception 'Exception' with message 'Connect failed: Can't connect to MySQL server on '172.16.1.134' (99)' in

排查:

服务端:

1.检查配置文件:/etc/my.cnf | grep connection 发现max_connection为300,当前与mysql实例最大的建立连接为300

2.检查配置文件:/etc/my.cnf | grep timeout 发现connection_timeout为8,当前mysql等待握手结果的时间为8s,如果长于8s,建立请求就会失败。

3.查看mysql的error_log:/data/local/mysql/var/mysql.err 没有任何相关信息

4.看RDS所在VM连接状态:netstat -anp|grep 3306 ,有大量连接处于time_wait,也就是说,根据TCP协议,服务器端主动关闭连接的一方,会处于time_wait。服务端对资源进行回收,而client没有连接回收机制(客户端不在向服务端传输数据,超过一定时间后,就会由服务端发起连接结束)

time_wait连接数

客户端:

1.应用错误日志:应用错误日志:less error.log

[31-Jul-2017 13:36:50 Etc/GMT-8] PHP Fatal error:  Uncaught exception 'Exception' with message 'Connect failed: Can't connect to MySQL server on '172.16.1.134' (99)' in /data/apps/shangzuo/www/include/library/DB.class.php:47

Stack trace:

#0 /data/apps/shangzuo/www/include/library/DB.class.php(23): DB->__construct()

#1 /data/apps/shangzuo/www/include/library/DB.class.php(82): DB::Instance()

#2 /data/apps/shangzuo/www/include/library/DB.class.php(471): DB::EscapeString('df1060b5d6aabaf...')

#3 /data/apps/shangzuo/www/include/library/DB.class.php(151): DB::BuildCondition(Array)

#4 /data/apps/shangzuo/www/include/library/Table.class.php(200): DB::LimitQuery('t_weixin_login_...', Array)

#5 /data/apps/shangzuo/www/boss/logincheck.php(10): Table::Fetch('t_weixin_login_...', 'df1060b5d6aabaf...', 'lgch_uid')

#6 {main}

thrown in /data/apps/shangzuo/www/include/library/DB.class.php on line 47

2.login逻辑检查: less  logincheck.php没有连接回收

if ($check["lgch_returnuid"]) {

if($INI['system']['brandkey'] == 'www'){

$res=array("tag" => "combine","mbuid"=>$check['lgch_returnuid']);

}

$login_waiter = checklogin($check['lgch_returnuid']);

if($login_waiter["tag"] != 'fail'){

$waiter = DB::LimitQuery("t_shop_waiter_info ta inner join t_sys_group_list tb on ta.wait_uid=tb.gpls_tguid inner join t_shop_job_info tc on tb.gpls_gpuid=tc.sjob_gpuid", array(

"condition" => "wait_uid='".$login_waiter["waiter"]['wait_uid']."' and sjob_class=1",

"order" => "order by sjob_type desc",

"one" => true

));

....

}

$res = array("tag"=>'brandchoose','htmlstr'=>$str);

}

}

}

结论

1.用户的php程序,和mysql后端的tcp连接,用户没有正常的释放,就会报“can't connect to mysql server onxxx.xxx”错误

2.由于客户端没有连接回收机制,只能借助于操作系统回收TCP连接,需要增加回收机制

处理结果:

1.客户端:

php与mysql建立完连接后,mysql.close()进行连接回收

2.服务端:

time_wait等待对端确认关闭连接,可在操作系统层面,优化tcp的time_wait,开启重启重用和回收(vim /etc/sysctl.conf 然后执行sysctl -p)

net.ipv4.tcp_syncookies = 1  //开启SYN Cookies。当出现SYN等待队列溢出时,启用cookies来处理,可防范少量SYN攻击,默认为0,表示关闭;

net.ipv4.tcp_tw_reuse = 1    //开启重用。允许将TIME-WAIT sockets重新用于新的TCP连接,默认为0,表示关闭;

net.ipv4.tcp_tw_recycle = 1  //开启TCP连接中TIME-WAIT sockets的快速回收

net.ipv4.tcp_retries2 = 5  //已建立通讯状况﹐需要进行多少次重试。默认值为15,相当于13-30分钟,这个值根据目前的网络设置,适当改小。服务端主动关闭的等待时长

net.ipv4.tcp_fin_timeout = 10 //设置链接超时时间,默认时60s,降低Time_wait占用时长

net.ipv4.tcp_syn_retries = 1  //新建连接,内核要发送多少个 SYN 连接请求才决定放弃

3.Mysql配置

修改connection_timeout时长,将timeout增大,提升三次握手因网络原因导致的建立连接异常。

规避方法:

1.养成良好的编程习惯,建立连接使用完成后,要及时回收

2.服务端要开启自动回收机制,避免过多的time_wait连接

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容