Ubuntu22部署MySQL5.7详细教程

Ubuntu22部署MySQL5.7详细教程

默认情况下,Ubuntu22安装MySQL的版本为8.0。但8.0更加严格的加密规则,使得一些配置难以实现,下面就来为大家介绍在ubuntu22中怎么安装MySQL5.7.x。

一、下载MySQL安装包

以MySQL5.7.29为例,进入MySQL官方的Community Server选择历史版本:https://downloads.mysql.com/archives/community/

可以使用wget命令下载,或直接点击Download下载。然后将tar包放在Ubuntu的一个目录中。

使用wget命令下载tar包

复制代码
sudo wget https://downloads.mysql.com/archives/get/p/23/file/mysql-server_5.7.29-1ubuntu18.04_amd64.deb-bundle.tar

解压tar包

复制代码
sudo tar -xvf mysql-server_5.7.29-1ubuntu18.04_amd64.deb-bundle.tar

解压后目录

二、安装MySQL

更新依赖源数据

复制代码
sudo apt-get update

安装依赖lib包

复制代码
sudo apt-get install ./libmysql*
sudo apt-get install libtinfo5

安装客户端和服务端,按提示可能要先安装community版本

复制代码
sudo apt-get install ./mysql-community-client_5.7.29-1ubuntu18.04_amd64.deb
sudo apt-get install ./mysql-client_5.7.29-1ubuntu18.04_amd64.deb
sudo apt-get install ./mysql-community-server_5.7.29-1ubuntu18.04_amd64.deb
sudo apt-get install ./mysql-server_5.7.29-1ubuntu18.04_amd64.deb 

第三行命令执行时会提示设置MySQL的密码,用户名默认root

三、启动MySQL

检查状态

一般安装成功就自动启动,输入命令检查启动状态,绿色的active表示运行中

复制代码
systemctl status mysql.service

登录MySQL

使用root用户登录MySQL

复制代码
mysql -u root -p

输入密码后,如下界面就是进入MySQL命令行

此时mysql安装完成了,但是不能为我们的程序提供服务(使用连接工具现在是连接不上的)。 因为还需要配置远程连接,使我们可以远程登录才可以。

四、开启远程访问功能

1、允许其他主机通过root访问数据库

进入mysql库,查看user表。 表中host、user字段标识了可以访问数据库的主机和用户。

复制代码
use mysql;
select User,Host from user;

默认情况下 mysql 只接受本地访问 ,需要执行 mysql 语句授权外网用户访问。例如下面的数据就表示只能用本地主机通过root用户访问数据库。为了让数据库支持远程主机访问,有两种方法可以开启远程访问功能。

(1)第一种(改表法):
修改host字段的值,将localhost修改成需要远程连接数据库的ip地址,或者直接修改成%,使所有主机都可以通过root用户访问数据库。

以下是将user为root对应的host字段直接修改成%的命令:

复制代码
update user set host = '%' where user = 'root';

输入命令使修改生效

复制代码
flush privileges; 

再次查看user表, 修改成功。
第二种(授权法):

例如,你想root使用mypassword从任何主机连接到mysql服务器的话。

复制代码
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'mypassword' WITH GRANT OPTION;

如果你想允许用户myuser从ip为192.168.1.3的主机连接到mysql服务器,并使用mypassword作为密码:

复制代码
GRANT ALL PRIVILEGES ON *.* TO 'root'@'192.168.1.3' IDENTIFIED BY 
'mypassword' WITH GRANT OPTION;

输入命令使修改生效

复制代码
flush privileges; 

这两种方法选择一种即可,接下来配置允许其他IP访问

2、修改配置文件,允许其他IP通过自定义端口访问

现在需要配置服务器的接口,从而使服务器能够侦听远程可访问的接口。默认情况下,绑定地址为"127.0.0.1"。

修改位于/etc/mysql/mysql.conf.d/mysqld.cnf 的配置文件,将bind-address=127.0.0.1修改成0.0.0.0,并添加 port = 开放的具体端口号,默认端口号为3306 ,即可实现开放外网访问和自定义端口的目的。

复制代码
sudo vi /etc/mysql/mysql.conf.d/mysqld.cnf

点击 Esc按键进入命令模式,输入 :wq 保存并退出。

重启mysql服务

复制代码
systemctl restart mysql

重启成功后,就可以使用连接工具连接了!

五、使用Navicat连接数据库

Navicat是一个广泛使用的数据库管理工具,可用于管理多种数据库系统,如MySQL、MariaDB、Oracle等。

使用ifconfig查看服务器ip地址,使用Navicat与数据库建立连接。

至此 mysql的安装已全部完成 如果有部署在云服务器上的经过上列操作无法访问的话 记得查看后台防火墙端口是否开启

参考资料:
Ubuntu22.04安装低版本MySQL5.7
Ubuntu安装mysql5.7(适用于大多数ubuntu版本)
Ubuntu 安装和使用MySQL
使用 MySQL APT 存储库的快速指南(官方)
Ubuntu22 安装 mysql5.7 过程记录
MySQL 异常: "Host 'xxx' is not allowed to connect to this MySQL server"

相关推荐
张风捷特烈11 小时前
Flutter 伪3D绘制#03 | 轴测投影原理分析
android·flutter·canvas
omegayy14 小时前
Unity 2022.3.x部分Android设备播放视频黑屏问题
android·unity·视频播放·黑屏
mingqian_chu14 小时前
ubuntu中使用安卓模拟器
android·linux·ubuntu
自动花钱机15 小时前
Kotlin问题汇总
android·开发语言·kotlin
暗碳16 小时前
adb检测不到原来的设备List of devices attached解决办法
adb
行墨17 小时前
Kotlin 主构造函数
android
前行的小黑炭17 小时前
Android从传统的XML转到Compose的变化:mutableStateOf、MutableStateFlow;有的使用by有的使用by remember
android·kotlin
_一条咸鱼_17 小时前
Android Compose 框架尺寸与密度深入剖析(五十五)
android
在狂风暴雨中奔跑18 小时前
使用AI开发Android界面
android·人工智能
行墨18 小时前
Kotlin 定义类与field关键
android