解决Ubuntu20.04启动MySQL报错(Job for mysql.service failed because the control process exited with error)

运行环境:ubuntu20.04,mysql 8.0

mysql Ver 8.0.29-0ubuntu0.20.04.3 for Linux on x86_64 ((Ubuntu))

授人以鱼不如授人以渔:具体错误原因请到日志文件/var/log/mysql/error.log中排查(注意要放开日志文件的写入权限)

mysql启动时报错情况

sudo service mysql start # 启动

Job for mysql.service failed because the control process exited with error code.
See “systemctl status mysql.service” and “journalctl -xe” for details.

sudo service mysql status # 查看状态;建议加上sudo,会有更详细的信息

● mysql.service - MySQL Community Server
Loaded: loaded (/lib/systemd/system/mysql.service; enabled; vendor preset: enabled)
Active: failed (Result: exit-code) since Wed 2024-02-28 10:10:31 CST; 10min ago
Process: 546126 ExecStartPre=/usr/share/mysql/mysql-systemd-start pre (code=exited, status=1/FAILURE)

0.Ubuntu下的mysql相关文件介绍

(注意Centos等其他linux系统下的mysql相关文件路径与Ubuntu不一样)

配置文件:

/etc/mysql/mysql.conf.d/mysqld.cnf # 其中log_error对应的路径是ubuntu中mysql的日志存放位置(log_error = /var/log/mysql/error.log)
/etc/mysql/my.cnf # 启动配置

日志文件:

/var/log/mysql/error.log # 由/etc/mysql/mysql.conf.d/mysqld.cnf中的log_error设置

数据文件:

/var/lib/mysql # 注意:/var/lib/mysql千万不要删!这是存放mysql数据文件的目录

运行时文件:

/var/run/mysqld
/tmp/data

1.修改文件权限

# 可能需要创建/tmp/data、/var/run/mysqld【ubuntu18升级到20,需要增加/var/run/mysqld,并且需要sudo dpkg --configure -a】
sudo mkdir -p /var/run/mysqld /tmp/data
sudo chown -R mysql:mysql /var/lib/mysql /var/log/mysql /var/run/mysqld /tmp/data
sudo chmod -R 777 /var/lib/mysql /var/log/mysql /var/run/mysqld /tmp/data

2.测试(可选)

mysqld_safe测试启动服务端(无需用户名和密码)

# 启动;并写入日志(可查看日志报错信息)
mysqld_safe --defaults-file=/etc/mysql/my.cnf
# /etc/mysql/my.cnf是ubuntu下的mysql启动参数配置文件

注意,测试通过后,要关闭测试进程,否则报错。

客户端连接mysql服务端,mysql -u root -p

可能出现客户端报错:

ERROR 2002 (HY000): Can’t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock’ (2)

tail -n50 /var/log/mysql/error.log找到日志报错:

[ERROR] InnoDB: Unable to lock ./ibdata1, error: 11, Could not open or create the system tablespace.

原因:之前启动的mysqld_safe进程占用

解决:找到其他占用端口的进程,kill

ps -ef | grep mysql

user0 618596 617876 0 13:17 pts/22 00:00:00 /bin/sh /usr/bin/mysqld_safe --defaults-file=/etc/mysql/my.cnf
user0 618942 618596 0 13:17 pts/22 00:00:05 /usr/sbin/mysqld --defaults-file=/etc/mysql/my.cnf --basedir=/usr --datadir=/var/lib/mysql --plugin-dir=/usr/lib/mysql/plugin --log-error=/var/log/mysql/error.log --pid-file=/var/run/mysqld/mysqld.pid --socket=/var/run/mysqld/mysqld.sock --port=3306

kill -9 618596 618942

3.重启mysql

重启mysql服务端:

sudo service mysql restart

sudo service mysql status查看正确的启动状态,示例如下:

● mysql.service - MySQL Community Server
Loaded: loaded (/lib/systemd/system/mysql.service; enabled; vendor preset: enabled)
Active: active (running) since Wed 2024-02-28 13:57:17 CST; 16min ago
Process: 623015 ExecStartPre=/usr/share/mysql/mysql-systemd-start pre (code=exited, status=0/SUCCESS)
Main PID: 623049 (mysqld)
Status: “Server is operational”
Tasks: 38 (limit: 347383)
Memory: 369.1M
CGroup: /system.slice/mysql.service
└─623049 /usr/sbin/mysqld

  • 26
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Ubuntu 20.04.6 中,你可以使用 sysbench 工具进行 MySQL 压测。 以下是使用 sysbench 进行 MySQL 压测的步骤: 1. 安装 MySQL 如果你还没有安装 MySQL,可以使用以下命令进行安装: ``` sudo apt-get update sudo apt-get install mysql-server ``` 安装完成后,你需要运行以下命令来确保 MySQL 服务已经启动: ``` sudo systemctl status mysql ``` 2. 安装 sysbench 你可以使用以下命令安装 sysbench: ``` sudo apt-get install sysbench ``` 3. 准备测试数据 使用以下命令登录到 MySQL 并创建一个新的数据库: ``` mysql -u root -p CREATE DATABASE testdb; ``` 然后使用 sysbench 工具创建测试数据。以下是一个示例命令: ``` sysbench oltp_read_write --db-driver=mysql --mysql-user=root --mysql-password=yourpassword --mysql-db=testdb --tables=10 --table-size=100000 --threads=64 prepare ``` 上述命令将在 testdb 数据库中创建 10 张表,每张表包含 100000 行数据。并发线程数为 64。 4. 运行压测 运行以下命令进行压测: ``` sysbench oltp_read_write --db-driver=mysql --mysql-user=root --mysql-password=yourpassword --mysql-db=testdb --tables=10 --table-size=100000 --threads=64 --time=300 --report-interval=10 run ``` 上述命令将运行一次为期 300 秒的 OLTP 读写测试,并在每 10 秒钟输出一次测试结果。 最后,你可以使用以下命令清理测试数据: ``` sysbench oltp_read_write --db-driver=mysql --mysql-user=root --mysql-password=yourpassword --mysql-db=testdb --tables=10 --table-size=100000 --threads=64 cleanup ``` 希望这个回答能够帮助到你。如果你还有其他问题,可以继续问我。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

nefu-ljw

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值