准备
本文环境信息:
软件
版本
CentOS
CentOS 7.4
MySQL
8.0.x
安装前先更新系统所有包
sudo yum update
安装
1. 添加 Yum 包
wget https://dev.mysql.com/get/mysql80-community-release-el7-1.noarch.rpm # 或者 wget http://repo.mysql.com/mysql80-community-release-el7-1.noarch.rpm sudo yum update sudo rpm -ivh mysql80-community-release-el7-1.noarch.rpm
注:在 官网 可以找到最新的 rpm 包名。
2. 安装 MySQL
# 安装 sudo yum -y install mysql-community-server # 启动守护进程 sudo systemctl start mysqld # 查看状态 sudo systemctl status mysqld # 查看版本 mysql -V
安装完后,MySQL 会在系统启动时自动启动,如果不想让它自动启动,可以使用 systemctl disable mysqld 关闭它。
3. 修改密码
MySQL 安装过程中会为 root 用户生成一个临时密码,保存在 /var/log/mysqld.log 中。通过以下命令查看:
sudo grep 'temporary password' /var/log/mysqld.log
进入 MySQL 客户端修改:
mysql -u root -p ALTER USER 'root'@'localhost' IDENTIFIED BY 'your passowrd'; # ALTER USER 'root'@ IDENTIFIED BY 'your passowrd';
密码强度要求是:不少于12字符,必须包含大写字母、小写字母、数字和特殊字符。
3. MySQL 安全配置
MySQL 包含一个安全设置向导脚本,可以用它来修改安全选项。
sudo mysql_secure_installation
运行后依次设置以下几项:
1.修改root账号密码
2.密码强度验证插件(建议使用)
3.移除匿名用户(建议移除)
4.禁用root账户远程登录
5.移除测试数据库(test)
根据个人情况设置。
用户权限
1. 赋予权限
# 创建本地用户 CREATE USER 'user'@'localhost' IDENTIFIED BY 'password'; # 新建远程用户 CREATE USER 'user'@'%' IDENTIFIED BY 'password'; # 新建数据库 CREATE DATABASE test_db; # 查看用户权限 SHOW GRANTS FOR 'user'@'%'; # 赋予用户指定数据库远程访问权限 GRANT ALL PRIVILEGES ON test_db.* TO 'user'@'%'; # 赋予用户对所有数据库远程访问权限 GRANT ALL PRIVILEGES ON *.* TO 'user'@'%'; # 赋予用户对所有数据库本地访问权限 GRANT ALL PRIVILEGES ON *.* TO 'user'@'localhost'; # 刷新权限 FLUSH PRIVILEGES;
2. 收回权限
# 收回权限 REVOKE ALL PRIVILEGES ON *.* FROM 'test'@'%'; # 删除本地用户 DROP USER 'user'@'localhost'; # 删除远程用户 DROP USER 'user'@'%'; # 刷新权限 FLUSH PRIVILEGES;
3. 远程登录
在 mysql 数据库查看 user 表信息 :
use mysql; select host, user, authentication_string, plugin from user;
表格中 root 用户的 host 默认是 localhost,只允许本地访问。授权 root 用户的所有权限并设置远程访问:
# 授权 GRANT ALL ON *.* TO 'root'@'%'; # 刷新 FLUSH PRIVILEGES;
root 用户默认的密码加密方式是:caching_sha2_password;而很多图形客户端工具可能还不支持这种加密认证方式,连接的时候就会报错 。通过以下命令重新修改密码:
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'your password';
这里指定了 root 的密码加密方式为 mysql_native_password,如果想改变默认密码加密方式都是,可以在 /etc/my.cnf 文件加上一行:
default-authentication-plugin=mysql_native_password
如果服务器开启了防火墙,则需要打开 3306 端口。
firewall-cmd --add-port=3306/tcp --permanent firewall-cmd --reload
注意:如果是云服务器,有的服务商(如阿里云)需要到控制台去开放端口的。
修改字符编码
字符集是一套符号和编码,查看字符集配置:
mysql> show variables like 'charac%'; +--------------------------+--------------------------------+ | Variable_name | Value | +--------------------------+--------------------------------+ | character_set_client | utf8mb4 | | character_set_connection | utf8mb4 | | character_set_database | utf8mb4 | | character_set_filesystem | binary | | character_set_results | utf8mb4 | | character_set_server | utf8mb4 | | character_set_system | utf8 | | character_sets_dir | /usr/share/mysql-8.0/charsets/ | +--------------------------+--------------------------------+
字符集生效规则为:Table 继承于 Database,Database 继承于 Server。就是说,可只设置 character_set_server。
校对规则是在字符集内用于比较字符的一套规则,查看校对规则:
mysql> show character set like 'utf8%'; +---------+---------------+--------------------+--------+ | Charset | Description | Default collation | Maxlen | +---------+---------------+--------------------+--------+ | utf8 | UTF-8 Unicode | utf8_general_ci | 3 | | utf8mb4 | UTF-8 Unicode | utf8mb4_0900_ai_ci | 4 | +---------+---------------+--------------------+--------+
校对规则生效规则:如果没有设置校对规则,字符集取默认校对规则,例如 utf8mb4 的校对规则是utf8mb4_0900_ai_ci。
MySQL 8 默认字符集改成了 utf8mb4。之前的 MySQL 版本如果默认字符集不是 utf8mb4,建议改成 utf8mb4。
mb4 即 most bytes 4。为什么是 utf8mb4,而不是 utf8?MySQL 支持的 utf8 编码最大字符长度为 3 字节,如果遇到 4 字节的宽字符就会插入异常。
下面是 老版MySQL 修改字符集为 utf8mb4 的步骤,MySQL 8.0+ 无需修改。
# 查看配置文件位置 whereis my.cnf # 打开文件 vi /etc/my.cnf
增加字符编码配置项:
[client] default-character-set=utf8mb4 [mysqld] character-set-server=utf8mb4 collation-server=utf8mb4_general_ci
重启 MySQL 服务
sudo systemctl restart mysqld
使用 MySQL 命令检查字符集配置:
show variables like 'charac%';
参考
https://dev.mysql.com/doc/mysql-yum-repo-quick-guide/en/
https://ken.io/note/centos-mysql8-setup
推荐:
感兴趣的朋友可以关注小编的微信公众号【码农那点事儿】,更多网页制作特效源码及学习干货哦!!!
总结
以上所述是小编给大家介绍的在 CentOS 7 中安装 MySQL 8 的教程详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新动态
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]