centos7 上安装mysql5.7后遇到的一些问题

1. 在rmp和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中存在以前数据库残留的数据未删除,所以通过如下操作应该可以解决:

    问题原因:

  1.       mysql在进行初始化的时后,会检测数据目录是否存在, 
  2.      如果不存在,mysql会创建它, 
  3.      如果存在,而且这个目录里有数据,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服务就好了

猜你喜欢

转载自blog.csdn.net/zd147896325/article/details/80759488