MySql升级安装、socket 及密码重置

升级

项目需要使用Mysql8.0, 查看自己的ubuntu22.04上mysql版本为5.7, 使用以下命令自动升级到8.0版本。

复制代码
sudo apt install Mysql

sock错误: Can't connect to local MySQL server through socket

运行mysql -u -p 报以下错误:

复制代码
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysqld.sock'

解决如下: 修改配置文件,增加以下内容:

复制代码
[mysqld]
socket = /tmp/mysqld.sock

[client]
socket = /tmp/mysqld.sock

修改之后 ,重启mysql服务

复制代码
sudo systemctl restart mysql

密码问题: ERROR 1045 (28000): Access denied for user 'root'@'localhost'

忘记密码会提示以下错误,以下是重置mysql密码方法:

复制代码
#执行以下命令,输入密码
mysql -u root -p 
ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)

#停止服务 
(base) moon@moon:~$ sudo service mysql stop

#跳过密码检查
(base) moon@moon:~$ sudo mysqld_safe --skip-grant-tables &
[1] 27049
(base) moon@moon:~$ 2025-06-19T09:30:30.942961Z mysqld_safe Logging to '/var/log/mysql/error.log'.
2025-06-19T09:30:30.998082Z mysqld_safe Starting mysqld daemon with databases from /var/lib/mysql

#进入mysql,
(base) moon@moon:~$ mysql -u root
# 重新设置密码
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY 'newpassword';
ERROR 1290 (HY000): The MySQL server is running with the --skip-grant-tables option so it cannot execute this statement
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY '123456';
ERROR 1290 (HY000): The MySQL server is running with the --skip-grant-tables option so it cannot execute this statement
mysql> FLUSH PRIVILEGES;
Query OK, 0 rows affected (0.06 sec)

mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY '123456';
Query OK, 0 rows affected (0.06 sec)

mysql> quit
Bye

#重启服务 
(base) moon@moon:~$ sudo service mysql restart

#重新进入
base) moon@moon:~$ mysql -u root -p
Enter password: 
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 9
Server version: 8.0.36-0ubuntu0.22.04.1 (Ubuntu)

Copyright (c) 2000, 2018, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> 
相关推荐
AI人工智能+电脑小能手26 分钟前
【大白话说Java面试题 第99题】【Mysql篇】第29题:如何选择合适的分布式主键方案?
java·数据库·分布式·mysql·面试
拾贰_C3 小时前
【mysql | windows | installation】 MySQL5.安装
数据库·windows·mysql
yuezhilangniao4 小时前
MySQL 8.0.32 二进制安装脚本 和初始化 操作系统版本rocky86
数据库·mysql·adb
学代码的真由酱5 小时前
MySQL数据库进阶-数据库设计实践-Java
数据库·mysql·数据库设计
遇事不決洛必達5 小时前
【数据库系列】本地映射云服务器Mysql的方法
服务器·数据库·mysql·定时任务
yuezhilangniao6 小时前
xtr备份prepare到底变化了啥
mysql
yyk的萌6 小时前
创建属于自己的mysql的mcp
mysql·adb·ai·mcp
流烟默6 小时前
腾讯云Centos7.6使用yum安装MySQL8
mysql·centos·腾讯云
仙俊红6 小时前
如何优化 MySQL 深分页 SQL
android·sql·mysql
超梦dasgg6 小时前
工作中 MySQL 读写分离主从延迟:成因、影响、落地方案、生产实战处理
数据库·mysql