准备

本文环境信息:

软件 版本
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

作者:王亮

出处:http://cnblogs.com/willick

联系:liam.wang@live.com

本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。如有问题或建议,请多多赐教,非常感谢。

[转载] 在 CentOS 7 中安装 MySQL 8相关推荐

  1. 虚拟机安装mysql5.7.20_虚拟机环境下CentOS 7 中安装Mysql 5.7.24(源码方式安装)

    偿试过用yum安装的都失败了,原因是服务启动时报错,偿试了多种解决办法,均不成功.然用源码方法却成功了,下面就介绍记录一下安装步骤. 1 安装cmake工具 yum install -y cmake ...

  2. linux mysql授权外部访问权限,Linux中安装Mysql授权远程访问

    Linux中安装MySQL 因为使用yum安装.安装过程需保证网络通畅 一.安装mysql 1.yum安装mysqlCentOS7默认数据库是mariadb,配置等用着不习惯,因此决定改成mysql, ...

  3. 在Ubuntu中安装MySQL (转载)

    MySQL在Linux Ubuntu中安装 本文使用的Linux是Ubuntu 12.04.2 LTS 64bit的系统,安装MySQL数据库软件包可以通过apt-get实现. 在Linux Ubun ...

  4. linux为mysql创建gpower_系统运维|RHEL/CentOS 7中安装并配置 PowerDNS 和 PowerAdmin

    PowerDNS是一个运行在许多Linux/Unix衍生版上的DNS服务器,它可以使用不同的后端进行配置,包括BIND类型的区域文件.关系型数据库,或者负载均衡/失效转移算法.它也可以被配置成一台DN ...

  5. centos mysql 安装教程_CentOS中安装MySQL步骤详解

    本文中Linux环境为CentOS 6.4 32位,且安装选择的是Basic Server版. 在有些Linux版本中会自带有MySQL数据库,所以在安装之前,需要检查当前Linux环境中是否已有My ...

  6. Linux CentOS 中安装 MySQL 与卸载 MySQL(三)

    VMware 安装 MySQL 内容 一.软件下载 二.安装步骤 1. 上传压缩文件 2. 防止依赖冲突 3. 安装依赖 4. 查找以前是否装有mysql 5. 查看安装包目录 6. 安装mysql- ...

  7. 阿里云 centos 6.9 安装 mysql 5.7

    2019独角兽企业重金招聘Python工程师标准>>> Step1: 检测系统是否自带安装mysql          yum list installed | grep mysql ...

  8. centos6.5 mysql 远程访问_CentOS 6.5 中安装 Mysql 5.6,并远程连接Mysql

    ι 版权声明:本文为博主原创文章,未经博主允许不得转载. 1.在安装CentOS时,若选择的是Basic Server(可支持J2EE开发),则新安装好的CentOS系统中默认是已经安装了一个mysq ...

  9. 如何在 CentOS 7 中安装或升级最新的内核

    转 原创 2017-03-19 译者:geekpi Linux中国 随着新的设备和技术定期出来,如果我们想充分利用它们,保持最新的内核就很重要.此外,更新内核将帮助我们利用新的内核函数,并保护自己免受 ...

  10. 在CentOS 7中安装与配置Tomcat-8方法

    安装前提 在CentOS 7中安装与配置JDK8 安装tomcat  apache-tomcat-8.0.14.tar.gz文件上传到/usr/local中执行以下操作: [root@localhos ...

最新文章

  1. 【译】使用Kotlin和RxJava测试MVP架构的完整示例 - 第1部分
  2. 今年央视春晚的创意担当,给了这个1岁的拓荒牛机器人
  3. MinGW:sjlj vs dwarf vs seh有什么区别?
  4. Redis 主从复制的原理及演进
  5. linux生成表格文件大小,如何为linux中的文件夹生成清单(文件列表及其大小和数量)...
  6. 研讨会 | 知识图谱前沿技术课程暨学术研讨会(武汉大学站)
  7. openfeign调用服务是否需要网关_阿里新一代微服务解决方案:Spring Cloud Alibaba
  8. MongoDB数据库因安全漏洞,导致Family Locator泄露二十多万名用户数据
  9. 代码画简单动物_[500行代码学懂OpenGL]之六数学知识
  10. 苹果手机计算机键盘声音怎么办,苹果键盘声音怎么设置大小声
  11. [转载] python复数类型-Python 复数属性和方法操作实例
  12. textbox 下拉模糊查询ajax,Ajax实现在textbox中输入内容,动态从数据库中模糊查询显示到下拉框中...
  13. 基于java+springboot+mybatis+laiyu实现学科竞赛管理系统《建议收藏》
  14. 光盘文件格式-udf、iso9660、Joliet、Romeo
  15. 脚踏实地才能仰望星空
  16. 微信小程序注册开发流程详解
  17. 著名的NP问题:TSP问题(Traveling Salesman Problem)
  18. 如何将台式计算机连接到WiFi,台式机怎么连接wifi?台式电脑连接无线网络的方法(图文)...
  19. Mac 与PC键盘的对比及快捷键(黑苹果)
  20. 微信是怎样炼成的 微信产品的发展历程

热门文章

  1. 12_首页显示热门商品和最新商品
  2. CF651A Joysticks
  3. element的loading的蒙版导致滚动条消失,页面抖动
  4. ssh: connect to host gitee.com port 22: Connection timed out fatal: Could not read from remote repos
  5. erlang连接数据库mysql_[原]Erlang连接mysql问题解决
  6. a4b5笔记本大小对比_2L大小的迷你电脑上班拎着走
  7. c语言sigaction,C语言中的Sigaction和setitimer
  8. react 表单设计器_神器:让你相见恨晚的5个React应用程序库
  9. ab压力测试_使用ab来一次压力测试之旅
  10. 根据ip地址制作html,根据ip掩码计算可用ip