服务器非法关闭后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目录

相关推荐
文牧之23 分钟前
PostgreSQL的扩展 pgcrypto
运维·数据库·postgresql
白总Server24 分钟前
多智能体系统的中间件架构
linux·运维·服务器·中间件·ribbon·架构·github
老友@2 小时前
小集合 VS 大集合:MySQL 去重计数性能优化
数据库·mysql·性能优化
2401_867021903 小时前
文件缓冲区(IO与文件 ·III)(linux/C)
linux·运维·服务器·c语言
刘某的Cloud3 小时前
rabbitmq常用命令
linux·运维·分布式·rabbitmq·系统
麦麦大数据3 小时前
vue+neo4j+flask 音乐知识图谱推荐系统
vue.js·mysql·flask·知识图谱·neo4j·推荐算法·音乐推荐
悄悄敲敲敲3 小时前
Linux:进程间通信->命名管道
linux·运维·服务器
望获linux4 小时前
智能清洁机器人中的实时操作系统应用研究
大数据·linux·服务器·人工智能·机器人·操作系统
io无心4 小时前
Docker绑定端口报错
运维·docker·容器
爱吃烤鸡翅的酸菜鱼5 小时前
【SpringMVC】概念引入与连接
java·开发语言·mysql