发布网友 发布时间:2022-04-23 04:48
共7个回答
懂视网 时间:2022-04-07 18:47
推荐:《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 | 800 | | 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 | 800 | +-----------------------------+----------+
来看一下这几个与连不上数据库相关的超时参数:
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),我们目前线上的值已经是上限值了.
从上面的配置可以看到这些参数的设置相对来说都很大了,数据库正常情况下程序报连不上数据库应该和数据库本身的参数配置没有关系.我们需要从其它方向来解决这个问题.
热心网友 时间:2022-04-07 15:55
这问题头疼,是不是要讲详细.。局域网处理方案,一般连接检查顺序:
1.查看数据库监听端口;
2.查看该监听服务启动没有;
3.查看驱动包有没有放(服务器端common->lib,开发工具common开发包[一般自带有];
4.运行jdbc连接程序,有没有出异常,出异常上面没弄好,看看异常,就可以追踪处理。
5.直接使用开发工具的链接测试平台,备好各个属性,添入驱动包,测试链接是否成功,成功你的程序有问题,没成功换驱动包。
热心网友 时间:2022-04-07 17:13
WEB方式的MySql数据库”
如果没理解错的话应该是phpmyadmin吧?
只是mysql的可视化而已
php连接mysq方式没变
使用php的数据库操作函数连接mysql即可,可以用以下代码测试是否能连接mysql:
<?php
$link
=
mysql_connect("localhost(主机)",
"root(数据库用户)",
"(数据库密码)")
or
die("Could
not
connect:
"
.
mysql_error());
print
("Connected
successfully");
mysql_close($link);
热心网友 时间:2022-04-07 18:47
D:\web\php\cs001.php
on
line
5
不能连接数据库:
Bad
handshake
你看看这一行的代码
热心网友 时间:2022-04-07 20:39
把localhost换成127.0.0.0
热心网友 时间:2022-04-07 22:47
你的PHP版本是几
支持MySQL吗
可以用
<?php
echo
phpinfo();
?>查看一下
热心网友 时间:2022-04-08 01:11
付费内容限时免费查看回答原因一:登录账号、密码、服务器名称、数据库名称登录错误导致不能连接,这个比较常见,仔细检查好所填信息是否正确,填写正确一般就可以解决。
解决方法:当正在使用的软件出现数据库不能连接时,一般就是服务器名出现问题,更改服务器名称一般可以解决问题。数据库如果是安装在本机,服务器名可以用“.”或“(local)”来代替 ;如果是安装在局域网的其它计算机上,可以用IP地址作为服务器名。
原因二:如果没能正确安装SQL服务器,也会导致数据库连接不上;安装好数据库后,如果SQL服务管理器没有启动,则要去服务那里开启。
解决方法:如果是SQL数据库未能能成功安装,再次重新安装时,可能会无法安装,提示是存在一个未完成的安装挂起。解决就方法是:打开注册表编辑器,在HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Session Manager中找到并删除PendingFileRenameOperations项目即可。
如果是更改了Windows的用户名或者密码,会导致SQL服务管理器不能启动,解决办法是去控制版面的服务那里修改启动。
提问
回答直接重新装一下系统
提问
提问怎么重装,还不能丢失里面的文件
回答直接用大白菜装就行
提问我不懂,你直接告诉我怎弄
回答直接关机
重新装
提问关机会,重新装是重新启动电脑的意思吗?
回答是了