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)部署笔记

【完】

相关推荐
某个默默无闻奋斗的人5 分钟前
高性能 MySQL 进阶:索引核心原理、失效场景与底层优化全解
数据库·mysql
妄汐霜4 小时前
小白学习笔记(spring框架的aop和tx)
笔记·学习
sheeta19986 小时前
LeetCode 每日一题笔记 日期:2025.03.24 题目:2906.构造乘积矩阵
笔记·leetcode·矩阵
似水এ᭄往昔6 小时前
【Linux】自动化构建-make/Makefile
linux·运维·服务器·ubuntu
数据科学小丫6 小时前
Python 数据存储操作_数据存储、补充知识点:Python 与 MySQL交互
数据库·python·mysql
Heartache boy7 小时前
野火STM32_HAL库版课程笔记-ADC多通道采集热敏、光敏、反射传感器(轮询)
笔记·stm32·单片机
yoothey8 小时前
Java字节流与字符流核心笔记(问答+考点复盘)
java·开发语言·笔记
xianjian09128 小时前
MySQL 的 INSERT(插入数据)详解
android·数据库·mysql
老师好,我是刘同学8 小时前
force与deposit在SystemVerilog中的区别详解
笔记
Snasph8 小时前
在Ubuntu上进行端口转发
linux·运维·ubuntu