设为首页 收藏本站
查看: 487|回复: 0

[经验分享] 使用MySQL的yum源安装MySQL5.7

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2016-8-3 09:05:57 | 显示全部楼层 |阅读模式
一、安装配置MySQL的yum源

# 安装MySQL的yum源,下面是RHEL6系列mysql5.6的下载地址:
wget http://dev.mysql.com/get/mysql-community-release-el6-5.noarch.rpm
下面是RHEL6系列mysql5.7的下载地址:
wget http://repo.mysql.com//mysql57-community-release-el6-8.noarch.rpm

安装yum源。

rpm -ivh mysql57-community-release-el6-8.noarch.rpm
清除缓存
yum clean all


下面几个命令可以顺便学习一下

# 安装yum-config-manager

yum install yum-utils -y

# 禁用MySQL5.6的源

yum-config-manager --disable mysql56-community

# 启用MySQL5.7的源

yum-config-manager --enable mysql57-community-dmr

# 用下面的命令查看是否配置正确
yum repolist enabled | grep mysql

二、yum安装MySQL5.7
本次安装的版本是5.7.14,测试环境上原来有5.1.73版本,是升级安装.

yum install mysql
QQ截图20160803090539.jpg

三、初始化并启动MySQL
service mysqld start
直接启动服务会报错,如下:
[iyunv@localhost lib]# service mysqld start
MySQL Daemon failed to start.
正在启动 mysqld: [失败]
解决方法:新版本要求先初始化mysql。

初始化mysql

# mysqld --initialize --user=mysql --datadir=/var/lib/mysql
或者
# mysqld --initialize-insecure --user=mysql --datadir=/var/lib/mysql

另外,当你是以mysql的账户登录并执行程序的情况下,你可以将--user选项从命令中去掉。
通过官方文档我们可以知道,如果我是root身份登录Linux系统,可以执行:mysqld --initialize --user=mysql或者mysqld --initialize-insecure --user=mysql。如果我是以mysql用户登录Linux系统,可以执行:mysqld --initialize或者mysqld --initialize-insecure。

不管在哪个平台上,使用--initialize选项就是以“默认安全模式”来进行安装的(即包含一个随机的root初始密码的生成)。在这种情况下,密码是被标志为过期的,你需要选择一个新的密码。使用--initialize-insecure选项,没有root密码生成;如果是这样的话,在服务器投入生产使用之前,你需要及时地为账户指定密码。

使用--initialize会为root账户生成一个随机的初始密码,我们可以使用命令:mysql -u root -p,然后输入密码来登录MySQL。使用--initialize-insecure不会为root账户生成一个随机的初始密码,我们可以使用命令:mysql -u root --skip-password直接登录MySQL。


我初始化过程中遇到报错如下:
[ERROR] --initialize specified but the data directory has files in it. Aborting.
[ERROR] Aborting

解决方法:
rm  -rf  /var/lib/mysql/*


原因分析:

mysqld服务会检查数据目录是否存在,如下:
如果数据目录不存在,mysqld则会创建它。
如果数据目录存在,且不是空目录(即包含有文件或子目录),mysqld会显示一条错误信息并中止:
[ERROR] --initialize specified but the data directory exists. Aborting.
遇到这种情况,就将数据目录删除或重命名后,重新再试一次。

总之: 初始化之前,先检查一下数据目录是否存在,执行命令:ls  -l  /var/lib|grep mysql。若有,则执行命令:
rm  -rf  /var/lib/mysql,将其删除;
或者执行命令:mv  /var/lib/mysql   /var/lib/newname,将其重命名为newname,就可以了。

再次执行初始化命令,成功执行.

[Note] A temporary password is generated for root@localhost: ihey0gFhTT;f
记住初始化生成的临时的root密码,登录时会用到

初始化完成之后,直接启动service mysqld start



四、连接MySQL并修改密码

初始化时会生成一个临时的root密码,且登录之后必须先改密码,然后才能执行命令.
mysql -uroot -p  临时密码
登录之后,如果不立即改密码,执行命令时报如下错误:
mysql> show databases ;
ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executing this statement.

修改密码:  set password=password('123@Zxc');
或者:alter user 'root'@'localhost'  identified  by  '123@Zxc';
再次执行成功.


从官方文档中我们了解到要用ALTER USER语句可以修改密码。登录MySQL后,执行语句:
alter user 'root'@'localhost'  identified  by  '123@Zxc';
就将root账户的密码修改为123@Zxc了。
MySQL对用户密码安全性有所加强,所以设置的密码必须包含有数字,大写字母,小写字母,特殊符号,如果你设置的密码过于简单,会提示:
ERROR 1819 (HY000): Your password does NOT satisfy the CURRENT policy requirements。






运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-252244-1-1.html 上篇帖子: RedHat6.6上安装MySQL5.7.13 下篇帖子: mysql分库备份 shell脚本
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表