Ubuntu 22.04部署MySQL8.4

1、部署MySQL87.4

1.1、解压及安装

解压

powershell 复制代码
mkdir -p /opt/software/mysql
tar -xf mysql-server_8.4.8-1ubuntu22.04_amd64.deb-bundle.tar -C mysql

安装

powershell 复制代码
apt-get update
apt-get install libaio1
apt-get install libmecab2

dpkg -i mysql-common_8.4.8-1ubuntu22.04_amd64.deb 
dpkg -i mysql-community-client-plugins_8.4.8-1ubuntu22.04_amd64.deb 
dpkg -i mysql-community-client-core_8.4.8-1ubuntu22.04_amd64.deb 
dpkg -i mysql-community-client_8.4.8-1ubuntu22.04_amd64.deb 
dpkg -i mysql-client_8.4.8-1ubuntu22.04_amd64.deb 
dpkg -i mysql-community-server_8.4.8-1ubuntu22.04_amd64.deb 
dpkg -i mysql-community-server-core_8.4.8-1ubuntu22.04_amd64.deb 
dpkg -i mysql-server_8.4.8-1ubuntu22.04_amd64.deb 

systemctl status mysql
apt install -y net-tools
netstat -anp|grep 3306

2、修改配置

2.1、修改配置

vi /etc/my.cnf

powershell 复制代码
[mysqld]
# 基本设置
user=mysql
basedir=/usr
datadir=/data/mysql/data
socket=/var/lib/mysql/mysql.sock
pid-file=/var/run/mysqld/mysqld.pid

# 网络设置
port=3306
bind-address=0.0.0.0
skip-name-resolve

# 日志路径
log-error=/data/mysql/log/mysqld.log
slow_query_log=ON
slow_query_log_file=/data/mysql/log/slow.log
long_query_time=2

# 设置字符集
character-set-server=utf8mb4
collation-server=utf8mb4_unicode_ci

# 设置默认存储引擎
default-storage-engine=INNODB

# 激活插件
mysql_native_password=ON

# 安全性
symbolic-links=0

#忽略大小写
# lower_case_table_names=1

# 资源调优(8C16G)
innodb_buffer_pool_size=10G
innodb_log_file_size=1G
innodb_log_buffer_size=64M
innodb_flush_log_at_trx_commit=1
sync_binlog=1
max_connections=5000
max_allowed_packet=64M
thread_cache_size=64
table_open_cache=4096

2.1、AppArmor 允许自定义目录

powershell 复制代码
cat >> /etc/apparmor.d/local/usr.sbin.mysqld << EOF
/data/mysql/ r,
/data/mysql/** rwk,
/var/lib/mysql/ r,
/var/lib/mysql/** rwk,
/var/run/mysqld/ r,
/var/run/mysqld/** rwk,
EOF

systemctl restart apparmor

2.2、初始化数据库

powershell 复制代码
mysqld --initialize --user=mysql --datadir=/data/mysql/data

2.3、启动MySQL

powershell 复制代码
systemctl restart mysql
systemctl enable mysql

3、基本操作

3.1、远程登录

powershell 复制代码
cat /data/mysql/log/mysqld.log |grep password

# 切换到系统库
use mysql;

# 重置 root 密码(强制用 mysql_native_password 插件,避免兼容问题)
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'Kylin.2026';
FLUSH PRIVILEGES;

# MySQL服务开通对外访问权限
CREATE USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'Kylin.2026';
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION;
FLUSH PRIVILEGES;

# update mysql.user set host='%' where user='root';
# flush privileges;

3.2、建库并赋权

powershell 复制代码
CREATE DATABASE hive CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
CREATE USER 'hive'@'%' IDENTIFIED WITH mysql_native_password BY 'WishFox.2026';
GRANT ALL PRIVILEGES ON hive.* TO 'hive'@'%' WITH GRANT OPTION;
FLUSH PRIVILEGES;

show variables like '%character%';
相关推荐
卤炖阑尾炎1 小时前
MySQL 故障排查与生产环境优化实战指南
数据库·mysql
一叶飘零_sweeeet2 小时前
击穿 MySQL InnoDB MVCC 底层:从 undo log、Read View 到隔离级别的全链路深度拆解
mysql·innodb·mvcc
前进的李工2 小时前
MySQL大小写规则与存储引擎详解
开发语言·数据库·sql·mysql·存储引擎
殷紫川3 小时前
MySQL 锁等待与死锁根治全攻略:从底层原理到 innodb status 精准定位实战
mysql
MaCa .BaKa3 小时前
44-校园二手交易系统(小程序)
java·spring boot·mysql·小程序·maven·intellij-idea·mybatis
无小道3 小时前
Mysql——索引
mysql·索引·搜索
元宝骑士4 小时前
深度解析 ROW_NUMBER() 窗口函数:从入门到实战避坑指南
后端·mysql
014-code4 小时前
MySQL 常用业务 SQL
数据库·sql·mysql
y = xⁿ5 小时前
【MySQL】数据库的脏读,不可重复读和幻读,覆盖索引是什么,索引类型有哪些
数据库·mysql
羊小蜜.5 小时前
Mysql 07: 正则表达式查询(REGEXP)全解
数据库·mysql·正则表达式