mysql添加远程连接功能和设置最大连接数
一、为mysql服务器设置允许远程连接
有些情况,我们需要让测试服务器的本地数据库能被外部访问,方便本地数据库可视化工具对其数据的管理。
但是,这也带来了一些风险,若被黑客知道了你的服务器IP和数据库账号密码,则可能被其攻击,导致数据库数据被清除,请务必谨慎开启远程连接。
第一、修改/etc/my.conf
默认情况下,mysql只允许本地登录,如果要开启远程连接,则需要修改/etc/my.conf文件。
找到bind-address = 127.0.0.1这一行,将其注释掉。# bind-address = 127.0.0.1
如果没有这一行,则增加它:bind-address = 0.0.0.0
最后重启mysql服务器:systemctl restart mysql
第二、为用户远程连接mysql数据库赋权限
1. 新建用户admin,设置admin远程连接mysql数据库
mysql -u root -p
123456 //登录成功后会跳出来 mysql>
create user admin identified by '123456'; //admin为用户名,123456为密码
grant all privileges on *.* to 'admin'@'%' identified by '123456' with grant option;
flush privileges;
%表示允许任何ip地址的计算机,用admin帐户和密码123456来访问这个mysql server。
2、支持root用户允许远程连接mysql数据库
grant all privileges on *.* to 'root'@'%' identified by '123456' with grant option;
flush privileges;
二、为mysql服务器设置最大连接数
进入MySQL用命令行修改,但是MySQL重启后就失效了,需要重新设置。(不推荐)
命令如下:
1、show variables like ‘max_connections’;(查看当前最大连接数)
2、set global max_connections=1000;(设置最大连接数为1000,可以再次执行上面的命令查看设置是否成功)
方法二:修改MySQL配置文件,永久生效(推荐)
1、进入/etc目录,打开my.cnf文件;
2、查看max_connections=100的配置参数,修改为max_connections=1000;如果没有这个参数,直接添加max_connections=1000即可;
3、保存配置文件并退出,重启MySQL服务即可,systemctl restart mysql
查看数据库当前连接信息,
可以看到连接数据库的进程id,ip,用户名,连接的数据库,连接状态,连接时长等
命令:show full processlist;
三、解决中文乱码
在/etc/my.cnf中增加以下三行
[mysqld]
character-set-server=utf8
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通