使用MySQL的yum源安装MySQL5.7数据库的方法

2023年 4月 26日 57.8k 0

一、安装配置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的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

三、初始化并启动MySQL

service mysqld start

直接启动服务会报错,如下:

[root@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。

以上所述是小编给大家介绍的使用MySQL的yum源安装MySQL5.7数据库的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对每日运维网站的支持!

相关文章

Oracle如何使用授予和撤销权限的语法和示例
Awesome Project: 探索 MatrixOrigin 云原生分布式数据库
下载丨66页PDF,云和恩墨技术通讯(2024年7月刊)
社区版oceanbase安装
Oracle 导出CSV工具-sqluldr2
ETL数据集成丨快速将MySQL数据迁移至Doris数据库

发布评论