百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

如何在 Linux 系统上允许远程连接到 MySQL 服务器?

ahcoder 2025-03-20 11:50 15 浏览

在Linux 系统上安装 MySQL 服务器后,默认情况下它只接受来自自身的传入连接(即环回地址127.0.0.1)。

如果您只是尝试从同一服务器上的数据库读取或写入信息,则此默认配置可以正常工作,因此,将他们的网站和 MySQL 服务器托管在同一个机器上的用户不需要进行任何额外的配置来允许远程连接。

如果您想允许远程连接到您的 MySQL 服务器,因为您有其他计算机和/或需要访问该数据的用户,您需要将 MySQL 服务绑定到服务器上的公共 IP 地址,并且可能允许传入 MySQL通过系统防火墙连接。

在本教程中,我们将逐步指导您在 Linux 系统上允许远程连接到 MySQL 服务器,这些说明应该独立于您使用的任何 Linux 发行版。

在本教程中,您将学习:

  • 如何允许远程连接到 MySQL 服务器
  • 如何允许通过系统防火墙远程连接到 MySQL
  • 如何创建或更改 MySQL 用户以允许远程连接

允许远程连接到您的 MySQL 数据库是一个三步过程。

首先,我们需要通过在 MySQL 配置文件中配置公共绑定地址来将 MySQL 服务设置为可从远程机器访问。

其次,我们需要允许通过我们的系统防火墙进行远程访问,默认情况下,MySQL 在端口 3306 上运行,因此需要允许与此端口的连接。

第三,我们需要创建一个新用户或编辑一个现有用户,以使其可以从远程 IP 地址访问,我们可以选择允许所有 IP 地址或仅允许特定的 IP 地址。

配置MySQL绑定地址

我们将从打开/etc/mysql/mysql.cnf文件开始。使用 root 权限,在 nano 或您喜欢的文本编辑器中打开它。

$ sudo nano /etc/mysql/mysql.cnf

找到该部分bind-address下方的设置[mysqld],默认情况下,这当前应配置为环回地址127.0.0.1。删除该地址并将您的服务器的公共 IP 地址放在它的位置。我们将仅10.1.1.1用于示例。

[mysqld]
bind-address = 10.1.1.1

如果需要,您可以改为使用0.0.0.0绑定地址,这是一个通配符,应该将服务绑定到所有可访问的接口。不建议这样做,但如果您以后遇到问题,这对故障排除很有帮助。

[mysqld]
bind-address = 0.0.0.0

进行更改后,将更改保存到文件并退出。然后,您将需要重新启动 MySQL 服务以使更改生效。

$ sudo systemctl restart mysql

在某些发行版上,可能会调用该服务mysqld:

$ sudo systemctl restart mysqld

允许通过防火墙进行远程访问

假设您为 MySQL 服务器使用端口 3306,我们需要允许它通过系统防火墙。您需要执行的命令将取决于您使用的发行版。请参阅下面的列表或根据需要调整命令以符合您自己系统的防火墙语法。

在 Ubuntu 系统和其他使用 ufw(简单防火墙)的系统上:

$ sudo ufw allow mysql

在使用 firewalld 的 Red Hat、CentOS、Fedora 和衍生系统上:

$ sudo firewall-cmd --zone=public --add-service=mysql --permanent
$ sudo firewall-cmd --reload

以及适用于任何系统的旧iptables命令:

$ sudo iptables -A INPUT -p tcp --dport 3306 -m conntrack --ctstate NEW,ESTABLISHED -j ACCEPT

允许远程连接到特定用户

现在 MySQL 服务可以接受传入连接并且我们的防火墙将允许它们通过,我们只需要配置我们的用户以接受远程连接。

首先使用 root 帐户打开 MySQL。

$ sudo mysql

或者,在某些配置中,您可能需要输入以下命令并提供您的 root 密码:

$ mysql -u root -p

如果您已经创建了一个用户,并且需要将该用户配置为可从远程 IP 地址访问,我们可以使用 MySQLRENAME USER命令。我们将在下面的示例命令中使我们的wljslmz用户可以从 IP 地址访问10.150.1.1,但根据您自己的配置的需要进行调整。

mysql> RENAME USER 'wljslmz'@'localhost' TO 'wljslmz'@'10.150.1.1';

或者,如果您是第一次创建此用户,我们将使用该CREATE USER命令。请务必将以下用户名、IP 地址和密码替换为您自己的。

mysql> CREATE USER 'wljslmz'@'10.150.1.1' IDENTIFIED BY 'password_here';

如果您希望您的用户可以从任何 IP 地址访问,那么您可以%在命令中使用而不是特定的 IP 地址。以下是如何编辑现有用户以可从任何 IP 访问:

mysql> RENAME USER 'wljslmz'@'localhost' TO 'wljslmz'@'%';

下面是如何创建一个可以从任何 IP 地址访问的新用户:

mysql> CREATE USER 'wljslmz'@'%' IDENTIFIED BY 'password_here';

这里的所有都是它的。授予用户访问一个或多个数据库的权限后,您将能够使用帐户凭据远程访问数据库。

总结

在本教程中,我们了解了如何允许远程连接到 Linux 系统上的 MySQL 服务。这是使服务可访问、允许通过防火墙连接和创建可访问的 MySQL 帐户的三部分过程。由于 MySQL 在所有发行版中的工作原理基本相同,因此这些步骤应该对每个人都可用。

相关推荐

ARM64内核内存布局图(ARM64内核内存布局图解)

ARM64架构处理器采用48位物理寻址机制,最大可以寻找到256TB的物理地址空间。对于目前的应用来说已经足够了,不需要扩展到64位的物理地址寻址。虚拟地址也同样最大支持48位支持,所以在处理器的架构...

ARM64 linux 调试串口通信(ARM64 linux 调试串口通信实验报告)

ARM64linux调试串口通信随着国产机普及很多工作也转移到了新平台上,以前调试设备用的笔记本电脑也换成新国产ARM64架构的了。本文以绿联CM204USB-A转RJ45Console调试线...

Gentoo Linux 终止对 Itanium IA-64 体系的支持

GentooLinux是最后几个继续维护Itanium(IA-64)架构构建的Linux发行版之一,但现在这些已停产的英特尔处理器正在逐步淘汰。由于Linux6.7内核放弃了对Itan...

如何检查 Linux 系统是 32 位还是 64 位?这9个命令查的又快又准!

在Linux系统中,位数(bit)通常指的是CPU架构的位宽,即CPU一次能够处理的数据量。32位系统和64位系统在内存寻址能力、计算性能和软件支持上存在显著差异:「32位系统」:...

调出好画面!带你玩转飞凌嵌入式AM62x开发板的显示接口

来源:飞凌嵌入式官网“显示”是嵌入式开发板最为重要的功能之一,能够支持更多种类、更高规格的显示接口,意味着它能够应对的使用场景也更加广泛。每一款嵌入式开发板在出厂前都会做屏幕调试,但在客户的实际项目开...

带你玩转AM62x开发板的显示接口——LVDS的显示和修改方式

此前小编已为大家介绍过OK6254-C开发板的RGB显示和修改方式,今天将继续为大家介绍OK6254-C开发板的LVDS显示和修改方式。话不多说,我们进入正题。1、LVDS接口规格飞凌嵌入式OK62...

AM335x继任者?AM6254性能解析(am2361p)

飞凌嵌入式FET6254-C核心板基于TISitaraTMAM62x系列工业级处理器设计开发,采用ARMCortex-A53架构,主频最高可达1.4GHz;并集成了丰富的接口,可广泛应用于的工...

如何在 Linux 发行版中安装微信和 QQ?

很多人因为工作沟通的原因需要用到微信和QQ,那么如何在Linux发行版中安装微信和QQ呢?以下是一些尝试的解决方法。QQ上一个版本的QQLinux版还是在2009年,而在现在,基于N...

MySQL:物理备份工具XBK(mysql 备份方案)

XBK的优缺点:XBK(PerconaXtraBackup)优点:1.免费2.热备:备份期间不阻塞innodb和XtraDB表,但会阻塞Myisam表3.物理备份:备份恢复快XBK缺点:1.不支持远...

AMD锐龙9 9950X CPU AIDA64跑分曝光:比7950X最高快45%

IT之家6月26日消息,Anandtech论坛网友igor_kavinski本周一发布帖子,分享了AMD旗舰锐龙99950X处理器的AIDA64基准测试跑分,与当前基于Z...

qemu linux内核(5.10.209)开发环境搭建

版本信息宿主机:ubuntu20.04.6LTS(FocalFossa)虚拟机:ubuntu20.04.6LTS(FocalFossa)安装宿主机的步骤省略,和一般的在vmware中安...

iPhone 7成刷机神器,成功运行乌班图、Linux、安卓

在智能机刚开始流行的时候,很多手机发烧友都喜欢刷机,当时民间大神们制作了特别多优化的ROM。后来随着手机硬件的逐步提升,以及厂商们对系统的大力优化,让大家对于刷机的兴趣也越来越少。不知道大家还记得这部...

12 款最佳免费开源 Linux 渲染器 | 火狐浏览器 130.0 版本更新

12款最佳免费开源Linux渲染器Linux的一大优势在于其拥有丰富的开源软件,可以满足艺术家、摄影师、动画师和设计师的需求。凭借价格低廉的硬件、免费的软件以及少量的才能和灵感,任何人都可以创...

Linux中xargs 命令详解与实用场景

xargs是Linux系统中常用的命令行工具之一,它能够从标准输入构造参数列表并传递给其他命令使用,是处理批量数据操作时的重要利器。一、xargs的基本语法xargs[OPTION]...[C...

Linux 磁盘扩容(非LVM)方式(linux扩容lvm磁盘容量)

今天接到一个客户的需求,CentOS的/分区容量太小了,OA系统所有的数据都在这下面,由于当时前同事给客户安装系统时采用了标准分区,而不是LVM逻辑卷,所以不支持在线扩容。df-hT查看磁盘使...