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

相关推荐
超龄超能程序猿1 分钟前
Bitvisse SSH Client 安装配置文档
运维·ssh·github
帧栈17 分钟前
mysql基础(一)快速上手篇
mysql
奈斯ing18 分钟前
【Redis篇】数据库架构演进中Redis缓存的技术必然性—高并发场景下穿透、击穿、雪崩的体系化解决方案
运维·redis·缓存·数据库架构
鳄鱼皮坡1 小时前
仿muduo库One Thread One Loop式主从Reactor模型实现高并发服务器
运维·服务器
即将头秃的程序媛1 小时前
centos 7.9安装tomcat,并实现开机自启
linux·运维·centos
小Mie不吃饭1 小时前
FastAPI 小白教程:从入门级到实战(源码教程)
运维·服务器
fo安方2 小时前
运维的利器–监控–zabbix–第三步:配置zabbix–中间件–Tomcat–步骤+验证
运维·中间件·zabbix
爱奥尼欧2 小时前
【Linux 系统】基础IO——Linux中对文件的理解
linux·服务器·microsoft
戒不掉的伤怀3 小时前
【Navicat 连接MySQL时出现错误1251:客户端不支持服务器请求的身份验证协议;请考虑升级MySQL客户端】
服务器·数据库·mysql
超喜欢下雨天3 小时前
服务器安装 ros2时遇到底层库依赖冲突的问题
linux·运维·服务器·ros2