程序连不上mysql怎么办
程序连不上mysql的解决方法:1、肯定mysql办事可否正常,并寻运维确认网络题目;2、将“max_allowed_packet”值调大;3、将“net_read_timeout”值调大;4、将“connect_timeout”值调大等。
举荐:《mysql视频教程》
程序连不上mysql的题目总结
连不上mysql时个别有下列四种报错:
1:Can't connect to MySQL server 2:Lost connection to MySQL server 3:Sorry, due to line fault, temporarily unable to browse, we are dealing with. 4:MySQL server has gone away
一:Can't connect to MySQL server
可能的缘由:
1,mysql办事端没有启起来
2,网络欠亨(iptables,selinux,网络不不乱)
对应的解决方案:
1,dba先肯定mysql办事可否正常
2,mysql办事正常的状况下寻运维确认网络题目
二: Lost connection to MySQL server
有四种状况可能会致使这样的报错:
1,网络题目
2,查询的效果集太大,比方一个查询要返回几百万个效果
3,客户端发起数据库连贯的时候因为connect_timeout设定工夫太短而报错,要是是因为这个缘由引起的报错可以通过SHOW GLOBAL STATUS LIKE 'Aborted_connects'查看这个值可否有添加
4,查询有blob类型,超过了max_allowed_packet参数的限定
这四种状况对应的解决方案:
1,运维监控网络可否有题目
2,将 net_read_timeout值调大
3,将connect_timeout值调大
4,将max_allowed_packet值调大
三: Sorry, due to line fault, temporarily unable to browse, we are dealing with.
这个差错不是mysql原生的差错,在网上也没有寻到有相似的材料.当前发明有三种状况会有这种报错:
1,网络有题目
2,数据库连贯数过多
3,连数据库的帐号密码有误
四: MySQL server has gone away
有下列12种状况可能会致使这样的报错:
1,默许的wait_timeout值为8个小时,要是余暇连贯超过这个值会被kill
2,dba手动kill
3,客户端的帐号没有权限连贯mysql server
4,客户端TCP/IP连贯超时,如运用mysql_options(..., MYSQL_OPT_READ_TIMEOUT,...)或者mysql_options(..., MYSQL_OPT_WRITE_TIMEOUT,...)函数
5,当客户端禁用了主动重连贯( automatic reconnection)
6,查询语句不准确
7,查询语句太长,超过了max_allowed_packet的限定
8,一条insert或者replace语句更新的行数过多
9,域名解析失败
10,防火墙屏蔽了3306端口
11,一个线程fork了多个子进程,当多个子进程共用一个连贯时会致使报错
12,mysql办事端挂了
报MySQL server has gone away的差错缘由比拼多,我们可以从三个方面来应答这个题目:
1,运维
a,确认防火墙法则
b,dns办事器无异样
d,合理配置php.ini中连贯mysql的参数
connect_timeout,默许为60s
mysqli.reconnect,默许为off
2,DBA
a,肯定mysql办事和连贯数无异样
b,设定合理的wait_timeout值
c,设定在办事器端合理的max_allowed_packet值
d,确认帐号权限无误
3,开发
a,倡议运用mysqli替换mysql
b,尽量少用长连贯
c,mysqli.ping()可以在连贯断开后主动重连,mysql.ping()从mysql5.0.3后就不支撑主动重连了
d,子进程之间不要共用一个数据库连贯
以gamiss为例,我们来看一下max_allowed_packet和超时有关的参数:
>show variables like 'max_allowed_packet'; +--------------------+------------+ | Variable_name | Value | +--------------------+------------+ | max_allowed_packet | 1073741824 | +--------------------+------------+ >show variables like '%timeout%'; +-----------------------------+----------+ | Variable_name | Value | +-----------------------------+----------+ | connect_timeout | 60 | | delayed_insert_timeout | 300 | | have_statement_timeout | YES | | innodb_flush_log_at_timeout | 1 | | innodb_lock_wait_timeout | 120 | | innodb_rollback_on_timeout | OFF | | interactive_timeout | 86400 | | lock_wait_timeout | 31536000 | | net_read_timeout | 120 | | net_write_timeout | 120 | | rpl_stop_slave_timeout | 31536000 | | slave_net_timeout | 3600 | | thread_pool_idle_timeout | 60 | | wait_timeout | 86400 | +-----------------------------+----------+
来看一下这几个与连不上数据库相干的超时参数:
connect_timeout:在猎取链接时,期待握手的超不时间,个别默许即可(10s),为了不由于网络欠安致使连贯堵塞可以恰当增大这个值.线上配置为60s
wait_timeout/interactive_timeout:连贯状态延续为sleep的超不时间,默许为28800(8小时),现上调整到了24小时
net_read_timeout:办事器端期待客户端发送数据的超不时间,默许60s,线上为120s
net_write_timeout:办事器端写数据到客户端的超不时间,默许60s,线上为120s
再看一下max_allowed_packet参数:max_allowed_packet的默许值是1M(1048576),最大值是1G(1073741824),我们当前线上的值已经是上限值了.
从上面的配置可以看到这些参数的设定相对来说都很大了,数据库正常状况下程序报连不上数据库应当和数据库自身的参数配置没有关系.我们需要从其它标的目的来解决这个题目.
以上就是程序连不上mysql怎么办的细致内容,更多请关注 百分百源码网 其它相干文章!