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

相关推荐
HaoHao_01016 分钟前
AWS Snowball
服务器·云计算·aws·云服务器
xf8079891 小时前
cursor远程调试Ubuntu以及打开Ubuntu里面的项目
linux·运维·ubuntu
dot to one1 小时前
Linux 入门 常用指令 详细版
linux·服务器·centos
狄加山6752 小时前
Linux 基础1
linux·运维·服务器
测试冲鸭2 小时前
【可实战】Linux 系统扫盲、 Shell扫盲(如何写一个简单的shell脚本)
linux·运维·arm开发
Zfox_3 小时前
HTTP cookie 与 session
linux·服务器·网络·c++·网络协议·http
betazhou3 小时前
sysbench压力测试工具mysql以及postgresql
数据库·mysql·postgresql
wanhengidc4 小时前
服务器中的流量主要是指什么?
运维·服务器·流量
wit_@4 小时前
深入理解SSH:安全远程登录与高级应用
linux·运维·web安全·ssh·kail
老苏畅谈运维7 小时前
MySQL性能分析的“秘密武器”,深度剖析SQL问题
数据库·sql·mysql