要在同一局域网内连接到MySQL数据库,请按照以下步骤操作:
-
确保MySQL服务正在运行。在服务器上,您可以使用以下命令检查MySQL服务的状态:
sudo systemctl status mysql
如果MySQL服务未运行,请使用以下命令启动它:
sudo systemctl start mysql
-
修改MySQL配置文件以允许局域网内的连接。打开MySQL配置文件
/etc/mysql/mysql.conf.d/mysqld.cnf
(在某些系统上可能是/etc/my.cnf
):sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf
找到
bind-address
这一行,将其值更改为0.0.0.0
,以允许来自任何IP地址的连接。如果该行被注释掉了,请删除注释符号(;)。bind-address = 0.0.0.0
保存并关闭文件。
-
重启MySQL服务以应用更改:
sudo systemctl restart mysql
-
在MySQL中创建一个具有远程访问权限的用户。登录到MySQL:
mysql -u root -p
输入您的root密码。然后运行以下命令,将
your_username
和your_password
替换为您想要的用户名和密码,将your_ip_address
替换为您要允许访问的特定IP地址或使用%
允许任何IP地址访问:CREATE USER 'your_username'@'your_ip_address' IDENTIFIED BY 'your_password';
例如:
CREATE USER 'myuser'@'%' IDENTIFIED BY 'mypassword';
为新用户分配权限。将
your_database
替换为您要允许访问的数据库名称:GRANT ALL PRIVILEGES ON your_database.* TO 'your_username'@'your_ip_address';
例如:
GRANT ALL PRIVILEGES ON mydb.* TO 'myuser'@'%';
刷新权限并退出MySQL:
FLUSH PRIVILEGES; EXIT;
-
现在,您应该能够从局域网内的其他设备连接到MySQL数据库。使用以下命令,将
your_server_ip
替换为运行MySQL服务器的设备的IP地址,将your_username
和your_password
替换为之前创建的用户名和密码:mysql -h your_server_ip -u your_username -p
输入您的密码,然后您应该能够成功连接到MySQL数据库。