如何在 Linux 系统上允许远程连接到 MySQL 服务器?
gudong366 2025-06-20 16:53 14 浏览
在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 在所有发行版中的工作原理基本相同,因此这些步骤应该对每个人都可用。
相关推荐
- 使用再生龙工具远程克隆Linux服务器
-
大家好,之前给大家介绍一个一款可以用来备份还原、远程克隆、P2V、V2V的工具--再生龙,今天就来给大家演示如何用该工具来远程克隆一台linux服务器。使用此方法,可以将一台物理服务器远程克隆到虚拟...
- Linux 下用 SSH 登录远程服务器后把远程服务器文件传本地电脑
-
在Linux下,使用SSH命令登录远程服务器后,可以使用scp命令将远程服务器上的文件复制到本地电脑。以下是scp命令的基本用法:scp[用户名]@[远程服务器地址]:[远程文件路径][本地存放路...
- 一文掌握怎么利用Shell+Python实现Linux系统数据异地备份程序
-
简介:在当今的信息化时代,数据安全已成为企业和个人运维的重中之重。无论是服务器宕机、硬盘损坏,还是遭遇勒索病毒,数据丢失都可能带来巨大损失。为了最大程度保障数据安全,异地备份成为了最佳实践之一。本文将...
- 如何在Linux上搭建本地Docker Registry并实现远程连接
-
在Linux上搭建本地DockerRegistry并实现远程连接,可以按照以下步骤操作:一、安装Docker确保Linux系统上已经安装了Docker。如果尚未安装,可以使用以下命令进行安装(以Ub...
- 服务器连接方法教程(服务器地址怎么连接)
-
连接服务器的方式多种多样,具体取决于服务器的类型、操作系统以及你的使用需求。以下是几种常见的服务器连接方法,包含详细步骤和注意事项:一、远程桌面连接(适用于Windows服务器)适用场景:需要图形...
- 自动化测试学习:使用python库Paramiko实现远程服务器上传和下载
-
前言测试过程中经常会遇到需要将本地的文件上传到远程服务器上,或者需要将服务器上的文件拉到本地进行操作,以前安静经常会用到xftp工具。今天安静介绍一种python库Paramiko,可以帮助我们通过代...
- 手把手教你安装、远程连接Ubuntu 22.04
-
Ubuntu分为桌面版和服务器版本,我们选择服务器版本1下载Ubuntu22.04Ubuntu22.04下载地址:https://releases.ubuntu.com/22.04/ubuntu...
- Windows服务器怎么连接?远程连接服务器命令
-
服务器操作系统可以实现对计算机硬件与软件的直接控制和管理协调,任何计算机的运行离不开操作系统,服务器也一样,服务器操作系统主要分为四大流派:WindowsServer、Netware、Unix和Li...
- 如何使用JuiceSSH实现手机端远程连接Linux服务器
-
在当今数字化时代,远程连接到服务器成为了许多人工作和生活中的必需品。JuiceSSH是一款比较强大的Android应用程序,它可以让您在手机上轻松地远程连接到Linux服务器。下面简单的向您介绍如何使...
- 本地电脑如何远程连接服务器(电脑如何远程桌面连接服务器)
-
下面就来说说如何远程登录服务器。服务器一般有两大类系统,一种是windows系统,一种是Linux系统。下面以Windows系统为例1、Windows系统有自带的登录系统,点击“运行”(或者windo...
- 如何用CHAT配置linux的远程连接?(chattr linux)
-
问CHAT:配置linux的远程连接1.下载ssh2.启动ssh服务3.查看ssh服务状态4.设置ssh服务开机自启动5.设置windows的cmd下ssh6.通过cmd的ssh命令远程到...
- 服务器怎么远程连接控制(服务器远程桌面连接设置方法)
-
我是艾西,还是有很多小白同学问我服务器怎么远程连接。那么今天我们重点来教教大家如何用电脑远程服务器配上图文教程,让不懂的新手小白一看就会,分分钟上手教程远程服务器需要一台电脑俗称“PC”就是我们自己平...
- 如何远程管理Linux服务器(linux远程登录管理)
-
在当今数字化的时代,Linux服务器凭借其稳定性和高效性,成为众多企业和开发者的首选。然而,很多时候我们无法直接在服务器前操作,这就需要掌握远程管理Linux服务器的技巧啦。别担心,今天就来给大家分享...
- Linux系统无法启动?别慌!这可能是全网最全的故障排查攻略
-
当Linux系统罢工时,盲目重装只会浪费时间!本文整理8种常见故障的解决方案,涵盖从引导修复到硬件检测全流程,建议收藏备用。一、引导阶段故障排查1.GRUB引导丢失现象:黑屏显示"grub&...
- Linux进程管理(linux进程管理实验报告)
-
原作者:Linux教程,原文「链接」:https://mp.weixin.qq.com/s/39rQMl3V2Egot9cZ14NCLg【获得原作者转载授权】每个计算机系统都包含一个核心软件集合,即操...
- 一周热门
- 最近发表
- 标签列表
-
- linux一键安装 (31)
- linux运行java (33)
- ln linux (27)
- linux 磁盘管理 (31)
- linux 内核升级 (30)
- linux 运行python (28)
- linux 备份文件 (30)
- linux 网络测试 (30)
- linux 网关配置 (31)
- linux jre (32)
- linux 杀毒软件 (32)
- linux语法 (33)
- linux博客 (33)
- linux 压缩目录 (37)
- linux 查看任务 (32)
- 制作linux启动u盘 (35)
- linux 查看存储 (29)
- linux乌班图 (31)
- linux挂载镜像 (31)
- linux 软件源 (28)
- linux题目 (30)
- linux 定时脚本 (30)
- linux 网站搭建 (28)
- linux 远程控制 (34)
- linux bind (31)