MySQL 8(Ubuntu 18.04.6 LTS)安装笔记

一、前言

其实之前已经写过一篇笔记【MySQL 8.0.34(x64)安装笔记】。机缘巧合,这次遇到的环境是Ubuntu 18.04 LTS,相比Windows平台的安装,对mysql的版本以及依赖的选择,稍微要窄一些。特作笔记。

二、准备
(1)材料选择
版本选择
MySQL 8.0.33是支持Ubnuntu 18.04最后的版本(发布时间:2023-03-17)
libaio MySQL依赖:异步I/O库,libaio1_0.3.112-5_amd64(发布时间:2019-08-16)
libmecab2 MySQL依赖:分词处理库,libmecab2_0.996-5_amd64(发布时间:2018-2-7)

对于依赖 libaio 和 libmecab2 的版本选择有多个版本,作者本着发布时间尽量不要相差太多的原则,尽量选择较新版本。

具体版本列表见附录(1)~(3)。

(2)材料清单
文件 备注
libaio libaio1_0.3.112-5_amd64.deb 直接安装
libmecab2 libmecab2_0.996-5_amd64.deb 直接安装
MySQL mysql-server_8.0.33-1ubuntu18.04_amd64.deb-bundle.tar 需先解压再安装

插一句,.deb 是 Ubuntu 所支持的安装文件,mysql 的 tar 文件解压后其中也全部是 .deb 文件。

三、过程
(1)解压mysql安装包.tar
bash 复制代码
tar -xvf mysql-server_8.0.33-1ubuntu18.04_amd64.deb-bundle.tar
(2)创建安装脚本
bash 复制代码
#!/bin/bash
dpkg -i libaio1_0.3.112-5_amd64.deb
dpkg -i libmecab2_0.996-5_amd64.deb
#
dpkg -i mysql-common_8.0.33-1ubuntu18.04_amd64.deb
dpkg -i mysql-community-client-plugins_8.0.33-1ubuntu18.04_amd64.deb
dpkg -i libmysqlclient21_8.0.33-1ubuntu18.04_amd64.deb
dpkg -i libmysqlclient-dev_8.0.33-1ubuntu18.04_amd64.deb
dpkg -i mysql-community-client-core_8.0.33-1ubuntu18.04_amd64.deb
dpkg -i mysql-community-client_8.0.33-1ubuntu18.04_amd64.deb
dpkg -i mysql-client_8.0.33-1ubuntu18.04_amd64.deb
dpkg -i mysql-community-server-core_8.0.33-1ubuntu18.04_amd64.deb
dpkg -i mysql-community-server_8.0.33-1ubuntu18.04_amd64.deb
dpkg -i mysql-server_8.0.33-1ubuntu18.04_amd64.deb

注意 :安装组件存在依赖,请务必保证安装顺序。

(3)执行安装脚本

如果没有意外,mysql会自动安装。其间会弹出设置root的密码以及选择账户验证方式,见附录(4)和(5)。

(4)启动 mysql 服务
bash 复制代码
systemctl start mysql
(5)验证服务是否启动
bash 复制代码
ps aux | grep mysql 

或使用客户端工具登录

bash 复制代码
mysql -u root -p 

自此,安装完成。至于安装目录,见附录(6)。

四、后续及设置
(1)创建数据库
bash 复制代码
mysql -u root -p 
sql 复制代码
show databases;
CREATE DATABASE `testdb` CHARACTER SET 'utf8mb4' COLLATE 'utf8mb4_general_ci';
(2)修改服务系统变量

① 查看并设置变量 sql_mode

sql 复制代码
use mysql;
show VARIABLES LIKE '%sql_mode';

剔除 sql_mode 中的 ONLY_FULL_GROUP_BY:

bash 复制代码
vim /etc/mysql/mysql.conf.d/mysqld.cnf

在文件尾部添加:

sql-mode = STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE。。

注意:变量名为 sql_mode,但在配置文件中的配置项是 sql-mode。

具体参见文档:http://dev.mysql.com/doc/mysql/en/server-system-variables.html。

注意:修改配置后,需重启 mysql 服务后再查看变量是否更新。

bash 复制代码
systemctl restart mysql
(3)允许远程主机连接
sql 复制代码
use mysql; # 选择系统库mysql
SELECT host FROM user WHERE user = 'root'; # 查看允许主机
UPDATE user SET host = '%' WHERE user = 'root';
flush privileges; # 提交权限
SELECT host FROM user WHERE user='root'; # 验证查看
exit # 退出命令行工具
附录
(1)选择MySQL版本

下载位置:https://downloads.mysql.com/archives/community/。

(2)选择依赖libaio库

位置:https://mirrors.tuna.tsinghua.edu.cn/ubuntu/pool/main/liba/libaio/。

备选位置:https://archive.ubuntu.com/ubuntu/pool/main/liba/libaio/。

(3)选择依赖libmecab2库

位置:https://mirrors.tuna.tsinghua.edu.cn/ubuntu/pool/universe/m/mecab/。

备选位置:https://archive.ubuntu.com/ubuntu/pool/universe/m/mecab/。

(4)设置root密码的对话框
(5)设置密码验证策略
(6)MySQL安装目录
目录 内容
/etc/mysql/ 配置文件
/usr/bin/ mysql客户端工具,如:mysql,mysqlcheck,mysqladmin。。
/usr/sbin/ mysqld,mysql服务守护进程
/usr/lib/mysql/ 插件和库文件
/var/lib/mysql/ 数据内容
/var/log/mysql/ 日志文件
相关文章

[1]. MySQL 8.0.34(x64)安装笔记

[2]. JDK(Ubuntu 18.04.6 LTS)安装笔记

[3]. Tomcat Web应用(Ubuntu 18.04.6 LTS)部署笔记

【完】

相关推荐
字节逆旅3 小时前
ubuntu应用深度守护
ubuntu
tingshuo29176 小时前
D006 【模板】并查集
笔记
随风飘的云17 小时前
mysql的innodb引擎对可重复读做了那些优化,可以避免幻读
mysql
tingshuo29171 天前
S001 【模板】从前缀函数到KMP应用 字符串匹配 字符串周期
笔记
于眠牧北4 天前
MySQL的锁类型,表锁,行锁,MVCC中所使用的临键锁
mysql
Turnip12026 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
西岸行者6 天前
学习笔记:SKILLS 能帮助更好的vibe coding
笔记·学习
加号36 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏6 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
欧云服务器6 天前
怎么让脚本命令可以同时在centos、debian、ubuntu执行?
ubuntu·centos·debian