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

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

    问题原因:

 

  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服务就好了
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

qin147896325

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值