,bind-address = 192.168.1.100,
`,,这样设置后,只有192.168.1.100这个IP地址可以访问MySQL服务器。如果要允许多个IP地址访问,可以使用逗号分隔,如:,,
`,bind-address = 192.168.1.100,192.168.1.101,
`,,如果需要允许整个网段访问,可以使用通配符%,如:,,
`,bind-address = 192.168.1.%,
“,,这样设置后,192.168.1.x(x为0-255之间的任意整数)这个网段的IP地址都可以访问MySQL服务器。 MySQL限制外部访问设置,保障数据库数据安全
为了保障MySQL数据库的数据安全,我们需要对外部访问进行限制,以下是一些建议的设置方法:
1. 修改MySQL配置文件
编辑MySQL的配置文件my.cnf
(通常位于/etc/mysql/
或/etc/mysql/mysql.conf.d/
目录下),在[mysqld]
部分添加以下内容:
bindaddress = 127.0.0.1
这将限制MySQL只允许本地访问,保存文件后,重启MySQL服务使更改生效。
2. 创建专用用户并授权
为了避免使用root用户进行远程连接,可以创建一个专用的用户并授权访问特定数据库,以下是创建用户并授权的步骤:
1. 登录到MySQL:
mysql u root p
2. 创建新用户(将your_username
替换为实际用户名):
CREATE USER 'your_username'@'localhost' IDENTIFIED BY 'your_password';
3. 授权访问特定数据库(将your_database
替换为实际数据库名):
GRANT ALL PRIVILEGES ON your_database.* TO 'your_username'@'localhost';
4. 刷新权限:
FLUSH PRIVILEGES;
5. 退出MySQL:
EXIT;
现在,新创建的用户只能访问授权的数据库。
3. 限制远程访问
如果需要允许某些IP地址进行远程访问,可以按照以下步骤操作:
1. 登录到MySQL:
mysql u root p
2. 创建新用户并授权访问特定数据库(将your_username
、your_password
和your_database
替换为实际值,将your_remote_ip
替换为实际远程IP地址):
CREATE USER 'your_username'@'your_remote_ip' IDENTIFIED BY 'your_password'; GRANT ALL PRIVILEGES ON your_database.* TO 'your_username'@'your_remote_ip';
3. 刷新权限:
FLUSH PRIVILEGES;
4. 退出MySQL:
EXIT;
现在,新创建的用户只能从指定的远程IP地址访问授权的数据库。
4. 使用防火墙限制访问
为了进一步保护MySQL数据库,可以使用防火墙限制访问,以下是使用ufw
防火墙的示例:
1. 安装ufw
(如果尚未安装):
对于Debian/Ubuntu系统:
sudo aptget install ufw
对于CentOS/RHEL系统:
sudo yum install ufw
2. 启用ufw
防火墙:
sudo ufw enable
3. 添加规则以允许来自特定IP地址的访问(将your_remote_ip
替换为实际远程IP地址):
sudo ufw allow from your_remote_ip to any port 3306
现在,只有指定的远程IP地址可以访问MySQL数据库。
最新评论
本站CDN与莫名CDN同款、亚太CDN、速度还不错,值得推荐。
感谢推荐我们公司产品、有什么活动会第一时间公布!
我在用这类站群服务器、还可以. 用很多年了。