为Mysql Mariadb配置远程访问权限

本文详细介绍如何配置MySQL数据库以允许远程访问。包括修改配置文件、分配用户权限、刷新权限等步骤,确保从任意IP或特定IP段访问数据库。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在进行如下操作之前,要确保你的数据库配置开启了远程访问的权限:

* 注释skip-networking选项来开启远程访问. 

* 注释bind-address,该项表示运行哪些IP地址的机器连接,允许所有远程的机器连接.

接下来需要给对应的MySQL账户分配权限:

1.在终端输入mysql -uroot -p (password) 登录到mysql界面,

2.use mysql,

   select host,user from user

3.查找用户登录的host主机有哪些,如果你想设置针对所有IP访问,使用如下语句:

GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'password' WITH GRANT OPTION;

  如果只想让某一个IP或者某一个IP段来访问,可以使用如下语句:

GRANT ALL PRIVILEGES ON *.* TO 'root'@'192.168.1.138' IDENTIFIED BY 'my-new-password' WITH GRANT OPTION;

注意:这个'my-new-password'是针对你指定的ip定的

4.重点:最后一定要刷新权限:

FLUSH PRIVILEGES;

5.这是你再select host,user from user,就会发现host多了一个,就说明已经设置成功了,这时就可以用navicat去连接了.

### 配置MariaDB以允许远程连接和访问 #### 启动MariaDB服务 确保MariaDB已经正确安装并启动。对于Linux系统,可以使用如下命令来启动MariaDB服务: ```bash sudo systemctl start mariadb ``` 为了使MariaDB随系统自动启动,还可以启用该服务: ```bash sudo systemctl enable mariadb ``` #### 初始化MariaDB安全设置 首次运行MariaDB时建议执行安全脚本`mysql_secure_installation`来进行必要的初始化配置[^1]。 #### 修改绑定地址 默认情况下,MariaDB仅监听本地回环接口(127.0.0.1),这会阻止外部尝试建立TCP/IP连接的行为。要更改此行为,需编辑主配置文件 `/etc/mysql/my.cnf` 或者位于 `/etc/my.cnf.d/` 下的相关子配置文件中的 `[mysqld]` 段落部分,将 `bind-address` 设置为 `0.0.0.0` 表示接受来自任何网络接口上的请求;或者指定特定的IPv4或IPv6地址作为服务器对外提供服务所使用的唯一入口[^3][^4]。 例如,在配置文件中添加或修改如下行: ```ini [mysqld] bind-address = 0.0.0.0 ``` 完成上述改动之后保存文件,并重启MariaDB服务让新的设定生效: ```bash sudo systemctl restart mariadb ``` #### 授予用户远程访问权限 进入MySQL/MariaDB控制台后,可以通过GRANT语句赋予目标账户相应的全局权限以及指定可用来认证的身份验证源位置(即Host列)。下面的例子展示了如何给名为'root'@'%'(这里的百分号代表任意主机)授予全部特权并且刷新授权表单使之立即可用[^5]: ```sql CREATE USER 'root'@'%' IDENTIFIED BY 'your_password'; GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION; FLUSH PRIVILEGES; ``` 请注意替换 `'your_password'` 为你想要设置的实际密码字符串。 另外一种方式是在已有用户的前提下直接调整其host属性值,比如把localhost改为%或其他具体的IP地址范围。 最后一步非常重要——确认防火墙规则开放了用于接收传入流量所需的端口,默认通常是3306/tcp。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值