本文目录一览:
- 1、如何设置mysql 允许远程连接
- 2、怎么配置云服务器mysql远程
- 3、想知道云数据库MySql,是存放在独立的服务器上吗?购买后我们如何查看数据库数据,是登录远程还是通
- 4、腾讯云服务器怎么开启远程mysql服务
- 5、怎么解决mysql远程连接报10038的错误
如何设置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远程数据库时,发现已经能正常访问了。
问题解决。