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 |