当前位置: 首页 > MySQL数据库

Ubuntu上怎么设置MySQL远程访问

时间:2026-01-25 16:20:08

第一步:检查MySQL是否启用远程访问

在开始配置之前,我们需要确保MySQL启用了远程访问。首先,我们需要登录MySQL服务器,并查看是否启用了远程访问。打开终端,然后输入以下命令:

sudomysql-uroot-p

该命令将以root用户的身份登录MySQL。在输入该命令后,您将被要求输入密码。如果您输入了正确的密码,您将进入MySQL shell,该shell允许您访问MySQL服务器的命令行界面。在MySQL shell中,我们需要输入以下命令来查看是否启用了远程访问:

SELECTuser,authentication_string,hostFROMmysql.user;

如果远程访问已启用,您应该会看到如下输出:

+------------------+-------------------------------+-----------+|user|authentication_string|host|+------------------+-------------------------------+-----------+|root|*E0AAECBBB187B27AAF667AEC86667|localhost||root|*E0AAECBBB187B27AAF667AEC86667|%||mysql.session|*THISISNOTAVALIDPASSWORDTHAT|localhost||mysql.sys|*THISISNOTAVALIDPASSWORDTHAT|localhost||debian-sys-maint|*456D0C7680DF288F66F7401EABC4B|localhost|+------------------+-------------------------------+-----------+

这里的“%”表示MySQL允许任何主机上的用户访问。如果您看到这个输出,那么MySQL已启用远程访问。

如果您没有看到上面的输出或者如果您看到的输出与上面的不同,则表示MySQL没有启用远程访问。在这种情况下,您需要对MySQL进行配置,以允许远程访问。

第二步:为MySQL设置新的远程访问帐户

在启用远程访问之前,我们需要为MySQL创建一个新的远程访问帐户。这样做的原因是MySQL默认只允许root用户在本地访问服务器,其他用户需要使用开放授权来访问。

为了设置新的远程访问帐户,我们需要在MySQL shell中执行以下命令:

CREATEUSER'newuser'@'%'IDENTIFIEDBY'password';GRANTALLPRIVILEGESON*.*TO'newuser'@'%'WITHGRANTOPTION;FLUSHPRIVILEGES;

这些命令将创建一个名为“ newuser”的新用户,并分配所有访问权限。“%”表示用户可以从任何主机访问MySQL服务器。您也可以使用特定的IP地址或主机名来指定允许的主机。例如,“ newuser”@“10.0.0.2”表示只允许从IP地址为“10.0.0.2”的主机访问MySQL服务器。

第三步:配置防火墙以允许MySQL流量

通常情况下,MySQL服务器可能是由防火墙保护的。为了允许远程访问MySQL服务器,您需要在防火墙上打开MySQL端口(默认为3306)。为了做到这一点,我们需要输入以下命令:

sudoufwallow3306/tcp

这个命令将打开一个名为“3306”的端口,允许TCP流量通过防火墙。但是,在进行这个步骤之前,你需要确保您的防火墙是否已经安装和启用。

第四步:更新MySQL配置文件

为了允许远程登录MySQL服务器,您需要在MySQL配置文件中对其进行设置。默认情况下,MySQL配置文件位于“/etc/mysql/mysql.conf.d/mysqld.cnf”。您需要以管理员身份打开该文件并编辑如下几个值:

bind-address=0.0.0.0

上面的命令将允许MySQL服务器接受来自任何IP地址的连接请求。注意,这可能是不安全的,因为它使得MySQL服务器容易受到未授权的访问。如果你想更安全地进行MySQL远程访问,你应该指定允许访问的IP地址或CIDR范围。

第五步:重启MySQL服务器

在修改了MySQL配置文件之后,您需要重启MySQL服务器,以使更改生效。要重启MySQL,您可以使用以下命令:

sudosystemctlrestartmysql

如果您看到如下输出,则表示MySQL服务器已成功重启:

mysql.service-MySQLCommunityServerLoaded:loaded(/lib/systemd/system/mysql.service;enabled;vendorpreset:enabled)Active:active(running)sinceMon2019-01-2115:40:22EST;17sago

此时,您已经成功地设置了MySQL服务器的远程访问。


上一篇:MySQL 5.7版本怎么配置和安装
下一篇:Windows上无法启动MySQL如何解决
Ubuntu mysql
  • 英特尔与 Vertiv 合作开发液冷 AI 处理器
  • 英特尔第五代 Xeon CPU 来了:详细信息和行业反应
  • 由于云计算放缓引发扩张担忧,甲骨文股价暴跌
  • Web开发状况报告详细介绍可组合架构的优点
  • 如何使用 PowerShell 的 Get-Date Cmdlet 创建时间戳
  • 美光在数据中心需求增长后给出了强有力的预测
  • 2027服务器市场价值将接近1960亿美元
  • 生成式人工智能的下一步是什么?
  • 分享在外部存储上安装Ubuntu的5种方法技巧
  • 全球数据中心发展的关键考虑因素
  • 英特尔与 Vertiv 合作开发液冷 AI 处理器

    英特尔第五代 Xeon CPU 来了:详细信息和行业反应

    由于云计算放缓引发扩张担忧,甲骨文股价暴跌

    Web开发状况报告详细介绍可组合架构的优点

    如何使用 PowerShell 的 Get-Date Cmdlet 创建时间戳

    美光在数据中心需求增长后给出了强有力的预测

    2027服务器市场价值将接近1960亿美元

    生成式人工智能的下一步是什么?

    分享在外部存储上安装Ubuntu的5种方法技巧

    全球数据中心发展的关键考虑因素