允许某段网络访问Linux服务器上的MariaDB

在Linux服务器上安装了MariaDB,默认情况下,只允许本机访问。在某些特殊的情况下,要允许外部访问。具体操作流程如下:

1 修改服务器配置

bash 复制代码
vi /etc/my.cnf.d/server.cnf

取消下面的注释,以便允许外来的主机访问。

bash 复制代码
bind-address=0.0.0.0

2 重启数据库

bash 复制代码
systemctl restart mysql

3 创建数据库登录用户

登录数据库

bash 复制代码
mysql -u root -p

创建用户

bash 复制代码
CREATE USER 'remote_user'@'%' IDENTIFIED BY 'remote_password';

设置密码的时候,建议在键盘上乱敲,不要有啥规律,然后记下来。

开启访问数据库的权限

bash 复制代码
GRANT SELECT ON my_database.* TO 'remote_user'@'%';

刷新权限

bash 复制代码
FLUSH PRIVILEGES;

退出数据库

bash 复制代码
exit;

4 设置防火墙

检查防火墙

bash 复制代码
sudo firewall-cmd --list-all

添加策略

bash 复制代码
sudo firewall-cmd --permanent --add-rich-rule='rule family="ipv4" source address="10.10.0.0/16" port port=3306 protocol=tcp accept'

重新加载策略

bash 复制代码
sudo firewall-cmd --reload

5 备注

这里在数据库上为remote_user设置了比较大的可访问IP范围,在防火墙上设置了比较小的范围。最终以比较小的范围为准。

如果追求完美的话,可以在数据库上为remote_user设置同样小的范围。修改方法如下:

登录数据库

bash 复制代码
mysql -u root -p

撤销之前的权限

bash 复制代码
REVOKE ALL PRIVILEGES, GRANT OPTION FROM 'remote_user'@'%';

重新设置权限

bash 复制代码
GRANT SELECT ON my_database.* TO 'remote_user'@'10.10.0.0/16';

刷新权限

bash 复制代码
FLUSH PRIVILEGES;

退出数据库

bash 复制代码
exit;

测试

远程登录

bash 复制代码
mysql -h 202.1.12.2 -u remote_user -p -P 3306

问题

备份的问题

bash 复制代码
2024/12/18 16:21:41	
[Error]	Failed to backup "my_database" database with "Full" backup type: mysqldump: 
[Warning] Using a password on the command line interface can be insecure.
mysqldump: Couldn't execute 'show create table `vw_reservation`': 
SHOW VIEW command denied to user 'remote_user'@'202.11.1.15' for table 'vw_reservation' (1142)

解决办法:

给予用户vw_reservation视图的"读"的权限

bash 复制代码
show full tables;
GRANT SHOW VIEW ON leo_spa.vw_reservation TO 'remote_user'@'%';
FLUSH PRIVILEGES;
相关推荐
万象.13 分钟前
Linux传输层TCP,UDP相关内容
linux·tcp/ip·udp
MaximusCoder33 分钟前
等保测评命令——Centos Linux
linux·运维·经验分享·python·安全·centos
万象.34 分钟前
Linux数据链路层通信原理及报文格式
linux·网络·网络协议
卷Java1 小时前
Linux服务器Docker部署OpenClaw:腾讯云/阿里云/VPS安装避坑指南
linux·运维·服务器
原来是猿3 小时前
Linux-【动静态库】
linux·运维·服务器
深圳市恒讯科技3 小时前
云服务器怎么选?从CPU、内存到IOPS的零基础选型手册
运维·服务器
victory04314 小时前
Agent 面试知识树 + 高频追问答案库
网络·面试·职场和发展
艾莉丝努力练剑4 小时前
【脉脉】AI创作者崛起:掌握核心工具,在AMA互动中共同成长
运维·服务器·c++·人工智能·安全·企业·脉脉
九皇叔叔5 小时前
CentOS 7.5/RHEL 7.x 配置 YUM 源(阿里云镜像+本地源双方案)
linux·阿里云·centos
Blurpath住宅代理5 小时前
原生IP vs 广播IP:如何从网络层判断代理IP的“真实性”?
网络·静态ip·动态ip·代理·代理ip·住宅ip·住宅代理