Ubuntu上怎么设置MySQL远程访问
来源:亿速云
时间:2023-05-15 19:14:18 379浏览 收藏
IT行业相对于一般传统行业,发展更新速度更快,一旦停止了学习,很快就会被行业所淘汰。所以我们需要踏踏实实的不断学习,精进自己的技术,尤其是初学者。今天golang学习网给大家整理了《Ubuntu上怎么设置MySQL远程访问》,聊聊,我们一起来看看吧!
第一步:检查MySQL是否启用远程访问
在开始配置之前,我们需要确保MySQL启用了远程访问。我们需要先登录MySQL服务器,以查看是否启用了远程访问。打开终端,然后输入以下命令:
sudo mysql -u root -p
该命令将以root用户的身份登录MySQL。在输入该命令后,您将被要求输入密码。如果您输入了正确的密码,您将进入MySQL shell,该shell允许您访问MySQL服务器的命令行界面。要查看MySQL shell是否启用了远程访问,我们需要键入以下命令
SELECT user,authentication_string,host FROM mysql.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中执行以下命令:
CREATE USER 'newuser'@'%' IDENTIFIED BY 'password'; GRANT ALL PRIVILEGES ON *.* TO 'newuser'@'%' WITH GRANT OPTION; FLUSH PRIVILEGES;
执行这些命令将创建一个名为“ newuser”的新用户,并授予该用户所有的访问权限。“%”表示用户可以从任何主机访问MySQL服务器。您也可以使用特定的IP地址或主机名来指定允许的主机。例如,“ newuser”@“10.0.0.2”表示只允许从IP地址为“10.0.0.2”的主机访问MySQL服务器。
第三步:配置防火墙以允许MySQL流量
通常情况下,MySQL服务器可能是由防火墙保护的。要使MySQL服务器可以远程访问,必须在防火墙上开放MySQL端口(默认为3306)。为了做到这一点,我们需要输入以下命令:
sudo ufw allow 3306/tcp
执行该命令后,防火墙将允许TCP流量通过一个名为“3306”的端口。在执行此步骤之前,请确保您已经安装并启用了防火墙。
第四步:更新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,您可以使用以下命令:
sudo systemctl restart mysql
如果您看到如下输出,则表示MySQL服务器已成功重启:
mysql.service - MySQL Community Server Loaded: loaded (/lib/systemd/system/mysql.service; enabled; vendor preset: enabled) Active: active (running) since Mon 2019-01-21 15:40:22 EST; 17s ago
此时,您已经成功地设置了MySQL服务器的远程访问。
本篇关于《Ubuntu上怎么设置MySQL远程访问》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于数据库的相关知识,请关注golang学习网公众号!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
308 收藏
-
381 收藏
-
101 收藏
-
499 收藏
-
361 收藏
-
113 收藏
-
434 收藏
-
335 收藏
-
242 收藏
-
449 收藏
-
127 收藏
-
163 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习