当前位置: 首页 > news >正文

服务器非法关闭后MySQL服务启动失败

在写这篇文章前,我弄好了,写完之后把成功安装的几个MySQL都删除了,只留了最后测试成功的服务“mysql-test” ,然后点击运行,发现又出现上图的错误。心态炸了。

本以为定位到问题了,但是这个错误让我迷茫了。我只能临时记录下可能的地方,因为我改来改去大概就这几个地方了。然后就成功了

改动的地方有:(以下都是基于免安装版本的mysql8.0.26,操作之前必须要备份啊)

以下不是步骤,只是说了关键点,我想定位问题来着,但是太花时间了。另外这个my.ini文件本身也有点问题,太费时间了。这篇文章更多的是我一个临时记录。以后找到问题再更新文章

1、在my.ini中加入innodb_force_recovery=1,然后重启mysql服务

[mysqld]
innodb_force_recovery=1

2、在data文件夹下找到xxx.err 文件,然后把里面的内容清空,然后重启mysql服务

3、打开命令窗执行下mysql -V 看有没有报错

4、看下环境变量,记得看path变量是否有。这里要说下。安装mysql服务时,跟这个变量有关系的,你可以选择mysql服务,右击看属性就知道它关联的是哪个my.ini文件。明白了这点后,你的电脑可以使用很多个不同版本的mysql都不是问题。设置环境变量只是方便任何路径可以使用

5、安装mysql服务命令

mysqld install mysql8 --defaults-file="C:\XSoft\mysql\my.ini"

mysql8: 自定义服务名

C:\XSoft\mysql\my.ini  换成你自己的

6、删除服务

sc delete mysql8

7、把360关了

8、my.ini文件

某个老6的my.ini文件

[mysqld]
#设置后不需要密码进入mysql
#skip-grant-tables

# 设置3306端口
port=3306
# 设置mysql的安装目录   ----------是你的文件路径-------------
basedir=C:\XSoft\mysql
# 设置mysql数据库的数据的存放目录  ---------是你的文件路径data文件夹自行创建
#datadir=C:\XSoft\mysql\data
# 允许最大连接数
max_connections=200
# 允许连接失败的次数。
max_connect_errors=1000
# 服务端使用的字符集默认为utf8mb4
character-set-server=utf8mb4
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
# 默认使用“mysql_native_password”插件认证
#mysql_native_password
default_authentication_plugin=mysql_native_password 
# add the length to the max
group_concat_max_len = 1024000

[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8mb4
[client]
# 设置mysql客户端连接服务端时默认使用的端口
port=3306
default-character-set=utf8mb4

我又从其他地方拷一个来参考

[mysqld]
# 设置端口,默认3306
port=3306
# 设置mysql的安装目录
basedir=C:\\Program Files\\mysql-8.0.17-winx64
# 设置mysql数据库的数据的存放目录
datadir=C:\\Program Files\\mysql-8.0.17-winx64\\data
# 允许最大连接数
max_connections=200
# 允许连接失败的次数。这是为了防止有人从该主机试图攻击数据库系统
max_connect_errors=10
# 服务端使用的字符集默认为UTF8
character-set-server=utf8mb4
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8mb4
[client]
# 设置mysql客户端连接服务端时默认使用的端口
port=3306
default-character-set=utf8mb4

9、初始化数据库 mysqld --initialize --user=mysql --console。但是吧,这个初始化前,还是把data文件备份下。可以把data目录改成其他名字,然后新建一个data目录


http://www.mrgr.cn/news/31387.html

相关文章:

  • 解决RabbitMQ设置TTL过期后不进入死信队列
  • 【数据结构】什么是二叉搜索(排序)树?
  • 二层、三层网络基本原理
  • 6.C++程序中的基本数据类型
  • A. Closest Point
  • 基于开源鸿蒙(OpenHarmony)的【智能家居综合应用】系统
  • OpenAI GPT o1技术报告阅读(3)-英文阅读及理解
  • ubuntu 20.04 ‘Wired Unmanaged‘ 网络无法配置解决方法
  • 八股文-多线程、并发
  • 小新-13 2019 Intel款IML版【81UQ】原装出厂Win10系统镜像下载
  • 缓存装饰器@cached_property
  • vulnhub(11):derpnstink(hydra爆破用户名和密码、验证的文件上传)
  • 变量的作用域和生命周期
  • React基础教程(10):React Hooks
  • 建筑工程五方责任主体项目负责人质量终身责任追究暂行办法
  • 哈希表的使用
  • Spring Boot中使用注解拦截器实现通用校验器和基于角色的权限注解
  • java之杨辉三角问题
  • A Simple Encoder-Decoder for Open-Vocabulary Semantic Segmentation
  • safepoint是什么?有什么用?