Ubuntu 24.04 系统版本 安装 MySQL 8 及相关配置

1、卸载原有MySQL(如果有)

复制代码
sudo apt purge mysql-*
sudo rm -rf /etc/mysql/ /var/lib/mysql
sudo apt autoremove
sudo apt autoclean

2、安装 mysql

复制代码
sudo apt-get install mysql-server -y    #mysql 服务端
#sudo apt install mysql-client  -y     #mysql 客户端
#sudo apt install libmysqlclient-dev -y #mysql 开发包

3、检查mysql服务是否成功启动

复制代码
 sudo netstat -tap | grep mysql
 ## 输出:
tcp        0      0 localhost:mysql         0.0.0.0:*               LISTEN      22147/mysqld
tcp        0      0 localhost:33060         0.0.0.0:*               LISTEN      22147/mysqld

4、查看mysql 服务运行状

复制代码
 sudo service mysql status
 ## 输出
 mysql.service - MySQL Community Server
     Loaded: loaded (/usr/lib/systemd/system/mysql.service; enabled; preset: enabled)
     Active: active (running) since Sat 2025-11-08 07:19:30 UTC; 4min 20s ago
    Process: 22135 ExecStartPre=/usr/share/mysql/mysql-systemd-start pre (code=exited, status=0/SUCCESS)

5、启动服务:

复制代码
sudo service mysql start
##遇到了警告 su:warning blah blah blah... 
解决方法参考如下:
(MySQL 8, WSL 2) su: warning: cannot change directory to /nonexistent: No such file or directory · Issue #256 · miguelgrinberg/microblog · GitHub
## 解决方法
sudo service mysql stop #先停止服务
sudo usermod -d /var/lib/mysql/ mysql #为 mysql 用户创建一个主目录
sudo service mysql start #然后再启动

6、查看默认密码

复制代码
sudo cat /etc/mysql/debian.cnf

    gyl@DESKTOP-36KGR35:~$ sudo cat /etc/mysql/debian.cnf
    # Automatically generated for Debian scripts. DO NOT TOUCH!
    [client]
    host     = localhost
    user     = debian-sys-maint
    password = MaNpLifyktR6fjgc
    socket   = /var/run/mysqld/mysqld.sock
    [mysql_upgrade]
    host     = localhost
    user     = debian-sys-maint  ###用户名###
    password = MaNpLifyktR6fjgc  ####密码####
    socket   = /var/run/mysqld/mysqld.sock

//修改密码:密码改为了yourpassword,可以设置成其他的
update mysql.user set authentication_string=password('yourpassword') where User='root' and Host ='localhost';
update user set plugin="mysql_native_password"; 
如果报错使用:
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'yourpassword';


flush privileges;
quit;

## ERROR 1396 (HY000): Operation ALTER USER failed for 'root'@'%'
# 检查mysql.user表用户和主机名:
USE mysql;
SELECT User, Host FROM user;
# Host不为"%"则更新为%
UPDATE mysql.user SET Host='%' WHERE user='root';
# 更改身份验证插件:mysql_native_password
UPDATE user SET plugin='mysql_native_password' WHERE user='root';
FLUSH PRIVILEGES;
 # 或是重置密码
UPDATE user SET authentication_string='' WHERE user='root';
FLUSH PRIVILEGES;

MySQL远程访问配置脚本

复制代码
## 修改root用户认证方式为密码认证: 【注意密码规则】
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'Root@123';

或:或者创建新的管理用户(推荐用于生产环境)
CREATE USER 'root'@'%' IDENTIFIED BY 'Root@123';
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION;

##  刷新权限使更改生效
FLUSH PRIVILEGES;

##  验证用户权限配置
SELECT user, host, plugin, authentication_string FROM mysql.user WHERE user = 'root'

## 检查MySQL服务状态
sudo systemctl status mysql --no-pager -l

## 网络监听状态:"
sudo ss -tlnp | grep mysql

## 绑定地址配置:【目录 /etc/mysql】
sudo grep -r "bind-address" /etc/mysql/

## 防火墙状态
sudo ufw status

Ubuntu System has not been booted with systemd:系统尚未以systemd作为初始系统启动

1、查看系统运行的第一个进程(init 系统)

复制代码
ps -p 1 -o comm=

e.g.: 
root@DESKTOP-36KGR35:/etc# ps -p 1 -o comm=
init(Ubuntu-24. 或是 init(Debian)

2、使用 sysvinit 命令,代替 systemctl 命令。

3、sysvinit 命令与 systemctl 命令的语法相似。对比如下:

|------------------------------|--------------------------------|
| Sysvinit command | Systemd command |
| service service_name start | systemctl start service_name |
| service service_name stop | systemctl stop service_name |
| service service_name restart | systemctl restart service_name |
| service service_name status | systemctl status service_name |
| chkconfig service_name on | systemctl enable service_name |
| chkconfig service_name off | systemctl disable service_name |

相关推荐
掉头发的王富贵2 小时前
【StarRocks】极限十分钟入门StarRocks
数据库·sql·mysql
SamDeepThinking7 小时前
一条UPDATE语句在MySQL 8.0中到底加了几把锁?
后端·mysql·程序员
李白客2 天前
KES新版MySQL兼容能力再升级意味着什么?
mysql·国产数据库
Jim6004 天前
【吃透 MySQL InnoDB连载】第 1 章・解密线上数据库高频故障
mysql
GreatSQL4 天前
gt-checksum v4.0.0 新功能解读系列文章(4):SSL 加密连接——数据校验传输安全再升级
mysql
云技纵横7 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
沉默王二7 天前
面试官:RAG 不用向量数据库,用 MySQL 硬扛?我:100 万向量不是很轻松?
mysql·面试·ai编程
小猿姐8 天前
MySQL Top 10 热点问题 AI 运维实战:从内核诊断到云原生运维
mysql·云原生·aiops