mysql 5.7.17 rpm安装_MySQL5.7.17 RPM方式安装

数据库是绝大多数企业应用必需的,而 MySQL 是最流行的开源数据库。本文以最新的 MySQL Community Server 5.7.17 为例,总结了 CentOS 下 MySQL 服务器的安装和必要配置,并演示了 MySQL 单机多实例的部署方法。

作者:王克锋

出处:https://kefeng.wang/2016/12/20/mysql-installation/

版权:自由转载-非商用-非衍生-保持署名,转载请标明作者和出处。

1. CentOS 下安装 MySQLOracle 收购 MySQL 后,CentOS 为避免 MySQL 闭源的风险,改用 MySQL 的分支 MariaDB;

MariaDB 完全兼容 MySQL,包括API和命令行,但还是有些地方不一样(比如命令行提示符);

要想使用传统的官方版本 MySQL Community,需要手工下载并安装。

1.1 安装与启动

1.1.1 自动方法,国内下载慢(90min)## https://dev.mysql.com/downloads/repo/yum/ wget --tries=0 --retry-connrefused http://repo.mysql.com//mysql57-community-release-el7-9.noarch.rpm sudo yum -y install mysql57-community-release-el7-9.noarch.rpm

sudo yum -y install mysql-server1

2

3

4

9cc493f1e15b23d0f4eaea0d0f8b35d0.png

1.1.2 手动方法,下载速度快使用迅雷等多线程下载工具,下载各安装包至 PC,再上传至 Linux 主机:

-

mysql-community-server, 162M

-

mysql-community-client, 24M

-

mysql-community-common, 1M

-

mysql-community-libs, 2M

然后按下面顺序安装(有依赖关系):

sudo yum -y remove mariadb-libs

sudo yum -y install mysql-community-common-5.7.17-1.el7.x86_64.rpm

sudo yum -y install mysql-community-libs-5.7.17-1.el7.x86_64.rpm

sudo yum -y install mysql-community-client-5.7.17-1.el7.x86_64.rpm

sudo yum -y install mysql-community-server-5.7.17-1.el7.x86_64.rpm1

2

3

4

5

9cc493f1e15b23d0f4eaea0d0f8b35d0.png

1.2 启动 MySQL 服务进程sudo systemctl enable mysqld # 加入开机启动

sudo systemctl start mysqld # 立即启动

sudo netstat -natp | grep mysql ## 检测监听端口1

2

3

9cc493f1e15b23d0f4eaea0d0f8b35d0.png

1.3 日志文件时间格式查看日志文件 /var/log/mysqld.log,发现时间格式为 2016-12-21T13:15:11.097632Z,为 UTC 格式,与北京时间相差 8 小时;

### sudo vim /etc/my.cnf

log_timestamps=SYSTEM # log time zone

explicit_defaults_for_timestamp=true1

2

3

b303364dc8d788bc830b1e2a21d6c01b.png

调整后重启 mysqld,日志中变为北京时间,形如“2016-12-22T11:52:12.499593+08:00”,但格式非预期,没能找到解决办法,但尚能授受。

1.4 修改密码

1.4.1 已知 root 密码时## MySQL 首次启动时随机生成 root 密码,要求修改后才能继续使用

## MySQL 5.7 密码要求: 8位以上、大小写、数字、字符

sudo grep "temporary password" /var/log/mysqld.log | awk -F'root@localhost: ' '{print $2}' # 查询初始密码

mysql -uroot -p

MySQL> SET PASSWORD = 'MySQL5.7';

MySQL> SHOW VARIABLES LIKE 'validate_password%'; ## 查看密码要求

MySQL> GRANT ALL PRIVILEGES ON *.* TO 'root'@'192.168.%' IDENTIFIED BY 'MySQL5.7' WITH GRANT OPTION;

MySQL> SHOW GRANTS FOR 'root'@'192.168.%'; ## 查看授权结果1

2

3

4

5

6

7

8

9cc493f1e15b23d0f4eaea0d0f8b35d0.png

1.4.2 忘记密码时首先,修改 MySQL 配置,跳过授权验证,安全起见同时关闭网络防止外部主机连接:

## sudo vim /etc/my.cnf

[mysqld]

skip-networking

skip-grant-tables1

2

3

4

9cc493f1e15b23d0f4eaea0d0f8b35d0.png

重启 MySQL 服务:

sudo systemctl restart mysqld1

b303364dc8d788bc830b1e2a21d6c01b.png

重新设置 root 密码:

mysql -uroot # 此时可无密码登录

MySQL> UPDATE mysql.user SET authentication_string=password('MySQL5.7') WHERE user='root';

MySQL> FLUSH PRIVILEGES; EXIT;1

2

3

b303364dc8d788bc830b1e2a21d6c01b.png

恢复之前的 MySQL 配置,并重启服务,操作完毕:

sudo vim /etc/my.cnf # 撤消刚刚的修改

sudo systemctl restart mysqld

mysql -uroot -p # 此时指定新设密码登录1

2

3

9cc493f1e15b23d0f4eaea0d0f8b35d0.png

1.5 防火墙放行### sudo vim /etc/sysconfig/iptables

-A INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT

### 重启生效: sudo systemctl restart iptables1

2

3

b303364dc8d788bc830b1e2a21d6c01b.png

1.6 验证连接在 Windows 上连接 MySQL 来验证:

DOS> mysql -uroot -hcentos -pMySQL5.7 -P3306 -e “SELECT user(), @@port”

输出 root@192.168.214.1 | 3306, 验证通过。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值