默认情况下,Ubuntu22安装MySQL的版本为8.0。但8.0更加严格的加密规则,使得一些配置难以实现,下面就来为大家介绍在ubuntu22中怎么安装MySQL5.7.x。
以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
解压后目录
更新依赖源数据
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
一般安装成功就自动启动,输入命令检查启动状态,绿色的active表示运行中
systemctl status mysql.service
使用root用户登录MySQL
mysql -u root -p
输入密码后,如下界面就是进入MySQL命令行
此时mysql安装完成了,但是不能为我们的程序提供服务(使用连接工具现在是连接不上的)。 因为还需要配置远程连接,使我们可以远程登录才可以。
进入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访问
现在需要配置服务器的接口,从而使服务器能够侦听远程可访问的接口。默认情况下,绑定地址为“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是一个广泛使用的数据库管理工具,可用于管理多种数据库系统,如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”