如何设置mysql 允许远程连接

如何设置mysql 允许远程连接,第1张

mysql无法连接总结

1 先弄清楚mysql.user表的host和user列的含义,host列表示ip地址或者hostname,它和user列组成联合主键,host列的约束关系:比如172.%即代表只能172开头的网段才能登 陆该db;%表示任何网段都能登陆;同一user下如果既有172.%和%的host,那就取并集,即任何网段都能登陆

2 密码错误,一般报1045错误

一般是以下误 *** 作

2.0 首先明确一点,grant方式新建用户后其实不用flush privileges,而flush privileges刷新全新只对后续的连接有效,对本次连接无效

2.1 可能是update user表的方式修改了密码以后,忘记flush privileges,这时并没有生效,断开重连后沿用的还是旧密码

2.2 可能是update user表的方式修改了密码以后,忘记flush privileges,这时并没有生效,db重启以后必须用新密码才能登陆

2.3 就是简单的修改了密码,忘记了新密码,一般可以用skip-grant-tables的方式免密码登陆,修改回来,这个方法比较简单,但是需要重启db;

在云服务器中,一般都会保存一个管理账户密码,总是被客户随意修改导致备份,监控等失败,可以通过以下方法在线修改回来,无须重启db

2.3.1 copy 用户库的user表相关的文件到自己测试库

2.3.2 在测试库更改用户密码或添加用户

2.3.3 把user表相关的文件copy到用户库

2.3.4 kill -SIGHUP 用户的mysqld进程

3 是否设置了禁用dns解析,即设置了skip_name_resolve却还是用主机名称连接

4 是否设置了绑定ip访问,即设置了bind-address却还是用其他ip连接

5 确认是否是网络问题,一般直接ping ip的方式确定,这时先解决网络问题

6 确认是否能够telnet通对应ip的端口,如果不通的话,一般是以下原因

6.1 检查磁盘空间是否已经满了,即磁盘不足,这时应该无法telnet

6.2 检查mysqld进程是否存活,是否正好处于关闭中或者启动中,看错误日志即可,这时无法telnet

6.3 检查防火墙,是否开通了对应的db port

6.4 mysqld oom内存不足重启,这时会有短暂的时间连接不上,通过查看mysqld进程的启动时间或系统日志搜索oom关键字 /var/log/message

7 确认是否连接数打满了,一般报too many connections

8 确认是否是本地端口耗尽,这时一般报错 ERROR 2003 (HY000): Can't connect to MySQL server on '192.168.0.10' (99),注意最后括号的数字是99,解决方法一般是增加 local_port的范围 , /proc/sys/net/ipv4/ip_local_port_range 这里的值,两者相减 就是目前的范围

9 还有一种情况,比如敲的登陆命令为mysql -uxx -pxx -hxxx database1,这时相当于连接到mysql后还有一个use database1的 *** 作,如果卡住了一般就是卡在那不动,也不提示错误,这时需要注释掉database1登录进去查看是哪个线程卡住了它,或者本身这个db下表太多,本来就慢

您好,提问者:

是您安装MySQL的时候没有选择一个运行远程连接的选项,请安装图下重新配置,无需卸载MySQL、

最后让你输入密码的时候,下面有个框框请选中,这个就是运行远程连接的选项!

其函数原形为:

MYSQL *mysql_real_connect(MYSQL *mysql, const char *host, const char *user, const char *passwd, const char *db, unsigned int port, const char *unix_socket, unsigned int client_flag)

我要编一段程序用来远程连接一个mysql数据库。我在数据库的本机上做试验,发现mysql_real_connect()的第二个参数设为"localhost"时可以正常连接,当改写为该机器的IP地址"192.168.100.2"时就连接失败。我在程序中写的原句为:

mysql_real_connect(mysql,"192.168.100.2","root","","mydns",0,NULL,0)。

最初,我以为将"localhost"改为"192.168.100.2"之后要将第六个参数端口号写上,但还是不行。由于我是在Linux上做的,所以想也许需要将第七个参数unix_socket写上,结果还是不行。于是到google找解决方法,发现要远程连接mysql需要为mysql的指定帐号设置远程连接的权限。在我的程序中,就要为root设置这一权限。事实证明,我之前连接失败正是由于这个原因导致的。但问题是,网上被广泛转贴的方法是错误的,我照做后还不行,最后问了同学才解决的。下面我具体说一下,望大家不会再被误导。

在mysql数据库中有一个mysql库,它里面包含一个user表,里面存有所有帐号及它们的权限及特征。对应我的user表中找到User项为root的,发现有两项,其Host项分别为localhost和localhost.localdomain。我们只需要把'localhost'改为'%'就可以让所有远程机器以root帐号登陆mysql服务器。也可以将'localhost'改为某一个ip地址,这样就可以在该地址的机器上登陆mysql服务器。这些都没有问题,只是网上被广为传颂的一个更改Host项的方法是错误的。他的方法是用update语句将指定User项的Host项改过来,如果想添加一个新的用于远程访问的帐号,就用insert语句添加。事实是这根本不行,我按照作了,表是变了,但还是连不上。后来经过询问才知道,要想改,结合我的情况,必须用下面的这条语句:

grant all privileges on mydns.* to'root'@'%';来改变root帐号的权限。如果添加新帐号也是如此。想必这个表比较特殊,用普通的SQL语句不能 *** 作。如果帐号有密码,后面再加上identified by '***'(*为你帐号的密码)就可以了。

为了解决这个问题用了一下午的时间,费了不少周折,写出来也能让大家少走些弯路。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/7109077.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-01
下一篇 2023-04-01

发表评论

登录后才能评论

评论列表(0条)

保存