首页 > 编程知识 正文

云服务器mysql远程访问(mysql连接远程服务器)

时间:2023-12-15 08:46:15 阅读:315927 作者:PLOD

本文目录一览:

如何设置mysql 允许远程连接

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无法远程访问怎么呢,但能使用localhost来进行方法,下面来给各位介绍一下解决办法,需要的朋友可以参考下

可能是IP没设置好

问题:MySQL权限设置正确,但仍无法远程访问。通过telnet发现3306端口未打开。

分析:MySQL默认只绑定127.0.0.1,即:只有在本机才能访问3306端口。

解决:找到MySQL配置文件,搜索“bind-address”,找到这一行:

bind-address = 127.0.0.1 在前面加一个#,注释掉这一行,保存,重启MySQL。再通过远程访问就可以了,telnet可以发现端口也打开了。

例我们配置

1. 确保skip-networking被删除或者屏蔽,否则不支持TCP/IP 访问

2. 增加行bind-address = 65.55.55.2,替代65.55.55.2 为你的服务器地址

修改后,配置为:

复制代码代码如下:

[mysqld]

user = mysql

pid-file = /var/run/mysqld/mysqld.pid

socket = /var/run/mysqld/mysqld.sock

port = 3306

basedir = /usr

datadir = /var/lib/mysql

tmpdir = /tmp

language = /usr/share/mysql/English

bind-address = 65.55.55.2

# skip-networking

....

..

保存并关闭配置文件

重启mysql服务器:# /etc/init.d/mysql restart

如果上面办法没有用我们可以通用mysql命令模式进行设置

1。 改表法。

可能是你的帐号不允许从远程登陆,只能在localhost。这个时候只要在localhost的那台电脑,登入mysql后,更改 "mysql" 数据库里的 "user" 表里的 "host" 项,从"localhost"改称"%"

复制代码代码如下:

CODE:mysql -u root -p123

mysqluse mysql;

mysqlupdate user set host = '%' where user = 'root';

mysqlselect host, user from user;

2. 授权法。

例如,你想kevin使用mypassword从任何主机连接到mysql服务器的话。

复制代码代码如下:

GRANT ALL PRIVILEGES ON *.* TO 'kevin'@'%' IDENTIFIED BY 'mypassword' WITH GRANT OPTION;

如果你想允许用户kevin从ip为192.168.101.234的主机连接到mysql服务器,并使用mypassword作为密码

复制代码代码如下:

GRANT ALL PRIVILEGES ON *.* TO 'kevin'@'192.168.101.234' IDENTIFIED BY 'mypassword' WITH GRANT OPTION;

注意了,如果是linux系统防火墙也很重要哦

复制代码代码如下:

/* 关闭防火墙 */

service iptables stop

/* 开启防火墙 */

service iptables start

/* 默认关闭防火墙 */

chkconfig iptables off

想知道云数据库MySql,是存放在独立的服务器上吗?购买后我们如何查看数据库数据,是登录远程还是通

移动云MySQL是基于物理机进行的容器化部署,通过容器提供的数据库服务。目前实例规格族,包括通用型、独享型和通用入门型。其中通用型和通用入门型是与同一物理机上其他通用版实例共享CPU⌄磁盘和I/O资源,独享被分配的内存资源。独享型是完全独享被分配的CPU、内存、磁盘和I/O资源。购买成功的MySQL需要下载适配版本的MySQL客户端程序进行远程访问。

了解移动云云数据库MySql更多详情,欢迎注册登录移动云官网→

腾讯云服务器怎么开启远程mysql服务

查看Centos版本

[root@VM_0_7_centos ~]# cat /etc/redhat-release

CentOS Linux release 7.3.1611 (Core) 12

查看当前 Ubuntu Server版本

ubuntu@VM-15-131-ubuntu:~$ sudo lsb_release -a

No LSB modules are available.

Distributor ID: Ubuntu

Description: Ubuntu 16.04.1 LTS

Release: 16.04

Codename: xenial123456

修改user表里面的host项

登入mysql后,更改 “mysql” 数据库里的 “user” 表里的 “host” 项,从”localhost”改称”%”

mysql -uroot -proot

mysqluse mysql;

mysqlupdate user set host = '%' where user = 'root';

mysqlselect host, user from user;

怎么解决mysql远程连接报10038的错误

1/11

先看报错窗口。

2/11

通过百度,最终找到的原因是:远程3306端口未对外开放。于是下面进行远程3306端口开放操作。

3/11

首先远程连接服务器,点击“开始”-“管理工具”-“高级安全Windows防火墙”。

4/11

在打开的窗口中,左边选中“入站规则”,右边点击“新规则”来新建一个入站规则。

5/11

在“规则类型”中选择“端口”,然后下一步。

6/11

选中“特定本地端口”,输入3306,然后下一步。

7/11

选中“允许连接”,然后下一步。

8/11

这一步默认都选中就行,,然后下一步。

9/11

最后输入新增的入站规则名称,随便填,自己明白即可。

10/11

完成后可以在入站规则列表中可以看到新增的入站规则。

11/11

现在再次在本地连接mysql远程数据库时,发现已经能正常访问了。

问题解决。

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。