本文将带您了解关于远程连接阿里云的mysql数据库的新内容,同时我们还将为您解释远程连接阿里云的mysql数据库怎么用的相关知识,另外,我们还将为您提供关于.net连接阿里云上的mysql数据库一直报
本文将带您了解关于远程连接阿里云的mysql数据库的新内容,同时我们还将为您解释远程连接阿里云的mysql数据库怎么用的相关知识,另外,我们还将为您提供关于.net 连接阿里云上的mysql数据库一直报错、DataGrip连接阿里云的MySQL、Mysql实例NaviCat连接时提示"不支持远程连接的MySql数据库"解决方法、Mysql应用解析远程连接管理其他机器上的MYSQL数据库的实用信息。
本文目录一览:- 远程连接阿里云的mysql数据库(远程连接阿里云的mysql数据库怎么用)
- .net 连接阿里云上的mysql数据库一直报错
- DataGrip连接阿里云的MySQL
- Mysql实例NaviCat连接时提示"不支持远程连接的MySql数据库"解决方法
- Mysql应用解析远程连接管理其他机器上的MYSQL数据库
远程连接阿里云的mysql数据库(远程连接阿里云的mysql数据库怎么用)
第一步
由于MysqL版本问题
先尝试打开
sudo vim /etc/MysqL/my.cnf
如空,再尝试打开
sudo vim /etc/MysqL/MysqL.conf.d/MysqLd.cnf
# 号 注释该行
第二步
进入MysqL
MysqL -uroot -p
授权
刷新
退出
第三步
重启MysqL服务
service MysqL restart
如还不行
检查阿里云是否开放3306端口
额外
切换MysqL数据库
use MysqL;
查看用户表 (localhost只允许本地访问,%可远程访问)
select host,user from user;
更新用户表
update user set 'host' = '%' where 'user' = 'root' LIMIT 1;
.net 连接阿里云上的mysql数据库一直报错
mysqlnet阿里云
代码如下:
using mysql.data;
using mysql.data.mysqlclient;
static void main(string[] args)
{
string str = "database=chu;data source=rdsja29d3bs0j0z1jg55.mysql.rds.aliyuncs.com;port=3306;user id=xxx;password=xxx;charset=utf8";
mysqlconnection conn = new mysqlconnection(str);
conn.open();
}
每次在conn.open()这里都会提示:
Unable to connect to any of the specified MySQL hosts.
换了好几个DLL都不行。
DataGrip连接阿里云的MySQL
参考:https://www.cnblogs.com/i6010/articles/7723503.html
第一步:在/etc/mysql/my.cnf下找到bind-address = 127.0.0.1
在这行前加个"#"进行注释,或者改为: bind-address = 0.0.0.0
允许任意IP访问;或者指定自己需要远程访问的IP地址。
然后重启mysql:sudo /etc/init.d/mysql restart
第二步:授权用户能进行远程连接
grant all privileges on *.* to root@"%" identified by "password" with grant option;
flush privileges;
第一行命令解释如下,*.*:第一个*代表数据库名;第二个*代表表名。这里的意思是所有数据库里的所有表都授权给用户,如果只是授权某数据库或数据库下某张表,则把*替换成你所需的数据库名和表明即可。root:授予root账号。“%”:表示授权的用户IP可以指定,这里代表任意的IP地址都能访问MySQL数据库。“password”:分配账号对应的密码,这里密码自己替换成你的 root帐号密码
第二行命令是刷新权限信息,让我们设置的权限马上生效。
但是最终还是不能访问,此时考虑有可能是防火墙及mysql的3306端口问题.
通过命令netstar -a查询所有端口没看到3306,通过命令netstat -an|grep 3306,什么都不显示,可以确定是3306端口不存在。
登录阿里云控制台,在云服务安全组新增规则,克隆一个规则出来并把端口号修改成mysql的3306,再次远程连接还是失败。
重启实例。
Mysql实例NaviCat连接时提示"不支持远程连接的MySql数据库"解决方法
《MysqL实例NaviCat连接时提示不支持远程连接的MysqL数据库解决方法》要点:
本文介绍了MysqL实例NaviCat连接时提示不支持远程连接的MysqL数据库解决方法,希望对您有用。如果有疑问,可以联系我们。
首先到NaviCat官网(www.NaviCat.com.cn)上下载最新版本的NaviCat
安装完成后,打开NaviCat,如下图所示:
然后点击左上角的连接,弹出新键连接信息,如下图所示:
在主机名IP地址那里填写LocalHost
用户名与密码一栏则填写你所在的数据库用户名与密码.
这时候还不能连接数据库的,需要通过Http通道的形式进行数据库连接.
点击连接属性标签栏中的Http,如下图所示:
勾选使用Http通道后,在通道地址一栏输入你的网址与后台文件地址.
例如:http://www.google.cn/database.PHP
这里说明一下通道地址,前半部份:http://www.google.cn/是指你的服务器的域名,后半部份:database.PHP是指NaviCat客户端后台连接地址.这里Database.PHP可以根据你自己的喜好去重命名.那么,这个database.PHP文件在哪里找呢?
这个database.PHP文件在你点击确定保存了连接信息后,会自动生成一个PHP文件于NaviCat的文件根目录下,但它并不为DataBase.PHP文件,而是统一命名为ntunnel_MysqL.PHP文件,如下图所示:
我们可以通过重命名,即可修改成为我们刚才连接主机的Http通道的后台文件.
重命名该文件完毕后,我们利用FlashFxp工具把该文件上传到我们的网站根目录下.然后测试一下看看:
这过程有点慢,由于他要通过PHP文件连到网站服务器并且要返回信息所以需要稍等一下.
上图是成功连接到网站所在的MysqL数据库.
备注:
上图网址:www.google.cn为实例虚拟网址.
配置好连接信息后,千万不要忘了把NaviCat文件目录下的PHP文件上传到你的网站根目录下.
上传到网站根目录下的NaviCat生成的PHP文件一定要与你的连接信息的文件名一致,否则是连不上了.
欢迎参与《MysqL实例NaviCat连接时提示不支持远程连接的MysqL数据库解决方法》讨论,分享您的想法,小编 jb51.cc为您提供专业教程。
Mysql应用解析远程连接管理其他机器上的MYSQL数据库
《MysqL应用解析远程连接管理其他机器上的MysqL数据库》要点:
本文介绍了MysqL应用解析远程连接管理其他机器上的MysqL数据库,希望对您有用。如果有疑问,可以联系我们。
MysqL数据库在开发过程中,有时候需要远程连接并管理别的机器上的MysqL数据库,在实现的过程中会遇到一系列的问题,现在以远程访问我自己安装在Ubuntu上的MysqL数据为例(端口为默认端口3306),说明一下配置步骤及每一步中遇到的问题及相应解决方法:
远程连接管理MysqL,总体上来说有三步:(A为主操作机器,B为远程机器(MysqL安装在B上,由A访问B)
1,在被连接的MysqL中创建专门的远程连接用户wow;
2,修改被连接的MysqL的配置文件my.cnf,使此MysqL不仅仅支持本地IP127.0.0.1的监听,也支持其他IP的监听,并重启MysqL服务,使配置生效.
3,验证A中MysqL的配置端口是否与B中的一致(都是3306?),如果一致,通过 MysqL -h B的ip -u wow --port=3306 -p,来远程连接.
下面,就每一步详细说明一下:
一,在被连接的MysqL中创建专门的远程连接用户wow;
之所以要创建专门的用户,是因为MysqL在最初安装的时候,默认的root帐号以及其他的帐号是仅限于在localhost连接使用的.在远程机器上即使你用同样的用户名及暗码登录,都无法正常连接.比如你在远程机器192.168.83.56上用root帐号登录192.168.11.12机器上的MysqL:
MysqL -h 192.168.11.12 -u root -p,是无法正常登录的.此时,需要登录192.168.11.12机器,进入MysqL中的MysqL数据库查看user表,确认具体的root权限,特别是它的host是localhost还是你对应的IP,还是%.
MysqL数据库解决方法:
A,(在192.168.11.12机器中的MysqL中创建专门的远程用户root或者wow),创建用户与赋予权限有两种方法:
1)改表法.可能是你的帐号不允许从远程登陆,只能在localhost.这个时候只要在localhost的那台电脑,登入MysqL后,更改 "MysqL" 数据库里的 "user" 表里的 "host" 项,把"localhost"改为"%".“%”的意思就是所有host都可以访问.
MysqL -u root -p vmware MysqL>use MysqL; MysqL>update user set host = '%' where user = 'root';MysqL>select host,user from user;
2)授权法.例如,你想wow使用mypassword从任何主机连接到MysqL服务器的话.
GRANT ALL PRIVILEGES ON *.* TO 'wow'@'%' IDENTIFIED BY 'mypassword' WITH GRANT OPTION;
如果你想只允许用户wow从ip为192.168.83.56的主机连接到192.168.11.12的MysqL服务器,并使用mypassword作为暗码
GRANT ALL PRIVILEGES ON *.* TO 'wow'@'192.168.83.56' IDENTIFIED BY 'mypassword' WITH GRANT OPTION;
FLUSH PRIVILEGES
第二句表示从MysqL数据库的grant表中重新加载权限数据.因为MysqL把权限都放在了cache中,所以在做完更改后需要重新加载.
B,在用GRANT授权法创建完用户wow并赋予权限以后,是不是就可以用了?不可以吗?我们可以简单验证一下.先在远程机器192.168.83.56上 MysqL -h 192.168.11.12 -u root -p,是无法正常登录.报2003的错:
ERROR 2003 (HY000): Can't connect to MysqL server on '192.168.11.12' (111)
什么原因?是账户没有建立成功?权限设置问题,还是网络配置防火墙等的问题?还是MysqL的其他配置问题没有解决?
先排除帐号与权限的问题:在localhost(192.168.11.12)机器中,尝试用wow用户进入数据库.MysqL -u wow -p mypassword,报1045的错:
ERROR 1045 (28000): Access denied for user 'wow'@'localhost' (using password: YES),
为啥呢?怎么创建的新用户在本机上都无法登录MysqL,难道真是用户wow没有创建成功?再查看user表,wow确实已经有了啊.一顿纠结,最后找到原因,原来是安装配置MysqL的过程中没有删除匿名账户,删除匿名账户:
MysqL -u root -p
MysqL>use MysqL
MysqL>delete from user where User=' ';
MysqL>quit;
再尝试 MysqL -u wow -p mypassword,wow用户可以在本机正常登录了,看来帐号wow是没有问题的,那再试一下远程连接:
MysqL -h 192.168.11.12 -u root -p,是无法正常登录.还报2003的错:
ERROR 2003 (HY000): Can't connect to MysqL server on '192.168.11.12' (111),
查看一下errorCode来排查问题:
[MysqL@vvmvcs0 ~]$ perror 111
OS error code 111: Connection refused
那难道是网络的问题?ping xxx.xxx.xxx.12,可以PING通,那机器是没问题的.看来要看看MysqL的配置文件my.cnf中关于远程连接的配置了,这就进入了我们的第二步..
MysqL数据库2,使配置生效.
主要是两个配置项:skip_networking或者bind_address,为了取消本地监听,需要在my.cnf中注释掉关于这两项的配置:
正常情况下,MysqL占用的3306端口只是在IP 127.0.0.1上监听,拒绝了其他IP的拜访(通过netstat可以查看到).取消本地监听需要修改 my.cnf 文件:
sudo vim /etc/MysqL/my.cnf
//找到如下内容,并注释
bind-address = 127.0.0.1
然后需要重启 MysqL (可最后再重启).sudo MysqL stop
现在我们再试一试,在远程机器192.168.83.56上用如下命令登录一下192.168.11.12的数据库:MysqL -h 192.168.11.12 -u root -p,还是无法正常登录.还是报2003的错.又是什么原因呢?哦,是MysqL端口配置是否统一的问题!
MysqL数据库3,来远程连接.
192.168.83.56上的MysqL监听端口配置的不是3306,是3308,而192.168.11.12的端口是默认的3306,二者不匹配,如果仅仅在192.168.83.56上用MysqL -h 192.168.11.12 -u root -p来登录的话,就是去拜访192.168.11.12的3308端口啦,当然无法拜访了.我们还需要指定正确的被拜访MysqL的端口号:MysqL -h 192.168.11.12 -u wow --port=3306 -p.
小编PHP培训学院每天发布《MysqL应用解析远程连接管理其他机器上的MysqL数据库》等实战技能,PHP、MysqL、LINUX、APP、JS,CSS全面培养人才。
我们今天的关于远程连接阿里云的mysql数据库和远程连接阿里云的mysql数据库怎么用的分享已经告一段落,感谢您的关注,如果您想了解更多关于.net 连接阿里云上的mysql数据库一直报错、DataGrip连接阿里云的MySQL、Mysql实例NaviCat连接时提示"不支持远程连接的MySql数据库"解决方法、Mysql应用解析远程连接管理其他机器上的MYSQL数据库的相关信息,请在本站查询。
本文标签: