1. 在rpm和mysql-server都安装安装完成后,运行service mysqld start,但是启动失败并有如下提示:
<1>. 接下来就运行它所提示的两条命令 systemctl status mysqld.service -l 【加-l会将所有信息显示】
直接看他的[ERROR]信息 --> initialize specified but the data directory has files in it. Aborting.
第二张截图所列出的问题其实跟图一类似都是数据库初始化的问题,大致是数据库数据文件夹/var/lib/mysql的权限问题,还有就是可能你的数据库的数据文件夹datadir中存在以前数据库残留的数据未删除,所以通过如下操作应该可以解决:
问题原因:
- mysql在进行初始化的时后,会检测数据目录是否存在,
- 如果不存在,mysql会创建它,
- 如果存在,而且这个目录里有数据,mysql会报错,并且终止初始化
解决方法:
将这个数据目录删掉,我用的rpm包安装,默认数据目录在 /var/lib/mysql/ ,我将它直接删掉
1. 先给数据文件夹datedir添加所有用户权限 chown mysql:mysql -R /var/lib/mysql
2. rm -rf /var/lib/mysql/*
完了重启服务 service mysqld restart , 发现问题解决
2. 在mysql数据库安装完成后,当我们在登陆时发现让输入密码,但是我们并不知道初始密码,我看网上有朋友说日 志/var/log/mysqld.log中会有初始密码,但是比较麻烦,也不太好找,下面直接掉过密码验证,之后再修改密码
- 先停止mysql服务
service mysqld stop 或者 systemctl stop mysqld.service
- 修改配置文件无密码登录
1. vi /etc/my.cnf 2. 并在尾部加上 3. skip-grant-tables 4. 保存
- 再次启动mysql
service mysqld start 或者 systemctl start mysqld.service
- 采用无密码的方式登陆mysql数据库
mysql -u root !! 不加-p
- 修改密码
1. use mysql 2. update mysql.user set authentication_string=password('123456') where user='root' ; 3. 将上述步骤中在/etc/my.cnf中添加的skip-grant-tables注释掉或者删掉 4. 保存并重启mysql服务就好了