1. CentOS 下安装 MySQL
Oracle 收购 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
wget --tries=0 --retry-connrefused http://repo.mysql.com//mysql57-community-release-el7-9.noarch.rpm
sudo yum -y install mysql-server
1.1.2 手动方法,下载速度快
然后按下面顺序安装(有依赖关系):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.rpm
1.2 启动 MySQL 服务进程sudo systemctl enable mysqld # 加入开机启动
sudo systemctl start mysqld # 立即启动
sudo netstat -natp | grep mysql ## 检测监听端口
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=true
调整后重启 mysqld,日志中变为北京时间,形如“2016-12-22T11:52:12.499593+08:00”,但格式非预期,没能找到解决办法,但尚能授受。
1.4 修改密码
1.4.1 已知 root 密码时
## MySQL首次启动时随机生成 root 密码,要求修改后才能继续使用
## MySQL5.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.4.2 忘记密码时
首先,修改 MySQL 配置,跳过授权验证,安全起见同时关闭网络防止外部主机连接:## sudo vim /etc/my.cnf
[mysqld]
skip-networking
skip-grant-tables
重启 MySQL 服务:sudo systemctl restart mysqld
重新设置 root 密码:mysql -uroot # 此时可无密码登录
MySQL> UPDATE mysql.user SET authentication_string=password('MySQL5.7') WHERE user='root';
MySQL> FLUSH PRIVILEGES; EXIT;
恢复之前的 MySQL 配置,并重启服务,操作完毕:sudo vim /etc/my.cnf # 撤消刚刚的修改
sudo systemctl restart mysqld
mysql -uroot -p # 此时指定新设密码登录
1.5 防火墙放行
### sudo vim /etc/sysconfig/iptables-A INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT
### 重启生效: sudo systemctl restart iptables
1.6 验证连接
在 Windows 上连接 MySQL 来验证: DOS> mysql -uroot -hcentos -pMySQL5.7 -P3306 -e “SELECT user(), @@port” 输出 root@192.168.214.1 | 3306, 验证通过。