本文环境信息:

软件 版本
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,只允许本地访问。

update user set host = '%' where user = 'root';

# 刷新
FLUSH PRIVILEGES;

授权 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

centOs7 安装mysql8的更多相关文章

  1. CentOS7 安装 mysql8

    本文主要从以下几个方面对自己在centos7 下安装mysql8过程做如下总结: CentOS7 安装mysql8 步骤: window下的Navicat 连接MySql8: 涉及到的Linux命令 ...

  2. Centos7安装MySQL8.0

    请到这个地址看:https://www.cnblogs.com/kevingrace/p/10482469.html Centos7安装MySQL8.0 - 操作手册 一.yum安装方式: 卸载之前版 ...

  3. Centos7 安装 MySQL8以及远程访问的配置

    Centos7 安装MySQL8 1. 添加MySQL8的本地源 执行以下命令获取安装MySQL源 [root@virde ~]# wget https://repo.mysql.com//mysql ...

  4. CentOS7安装MySQL8.0小计

    之前讲配置文件和权限的时候有很多MySQL8的知识,有同志说安装不太一样,希望发个文,我这边简单演示一下 1.环境安装 下载MySQL提供的CentOS7的yum源 官方文档:<https:// ...

  5. 阿里云centos7安装mysql8数据库

    一.安装mysql 1. mysql官网查找仓库源镜像,选择downloads https://www.mysql.com/downloads/ 2. 找到社区版 3. 选择yum仓库 4. 选择对应 ...

  6. Centos7安装MySQL8.0 - 操作手册

    MySQL 8 正式版 8.0.11 已发布,官方表示 MySQL 8 要比 MySQL 5.7 快 2 倍,还带来了大量的改进和更快的性能! 一.  Mysql8.0版本相比之前版本的一些特性 1) ...

  7. <亲测>CentOS7 安装mysql8.0(YUM方式)

    CentOS7 安装mysql(YUM方式)   1.下载mysql源安装包 shell> wget http://dev.mysql.com/get/mysql80-community-rel ...

  8. CentOS7安装mysql8.0编译报错集合

    以下都是我安装mysql8.0遇到的一些报错和解决方法 1.does not appear to contain CMakeLists.txt. 原因:mysql下载的源码包不对 解决方法:下载正确的 ...

  9. Centos7 安装mysql-8.0.13(rpm)

    yum or rpm? yum安装方式很方便,但是下载mysql的时候从官网下载,速度较慢. rpm安装方式可以从国内镜像下载mysql的rpm包,比较快.rpm也适合离线安装. 环境说明 操作系统: ...

  10. CentOS7安装MySQL8.0图文教程

    1.下载 MySQL 所需要的安装包 网址:https://dev.mysql.com/downloads/mysql/ 2.Select Operating System: 选择 Red Hat , ...

随机推荐

  1. 《BLACK HAT PYTHON3》

    Black Hat Python3 kali 安装新版本python kali中自带的pyhton是2.7版本,显然2019年了,python2.x的版本已经逐渐过时,好多第三方库都逐步宣布不再支持p ...

  2. Golang(四)正则表达式使用

    0. 前言 最近用到了 regexp 包,下面整理下正则表达式相关用法 参考 基础知识 - Golang 中的正则表达式 和 Golang regexp包中的函数和方法 做了汇总 1. 正则表达式 1 ...

  3. CURL SSL为6的由来

    起初,我直接用方倍工作室之前做微信接口调用时的http_request函数,发现能正常调用微信api的函数获取不了火星天气数据,然后又尝试用file_get_contents,仍然不行 一直出的错就是 ...

  4. 01.普通抖音新手如何从0开始入门3个月做到粉丝100w+

    普通抖音新手如何从0开始入门3个月做到粉丝100w+ 今年以来,明显感觉抖音很火,大有干掉微信,取代淘宝,京东的感觉,如今年轻人,一周7天有7天要玩抖音,所以说未来不可估量. 如是,2019春节以后, ...

  5. 【Python开发】Pycharm下的Anaconda配置

    我的系统是Win 64位的,用的Python 3.5.1 ,最近在学机器学习,用到了Numpy这个科学计算库,网上查了之后,看到很多装Numpy出问题的情况,所以决定装Anaconda,简单一些,并且 ...

  6. cad.net 块裁剪边界反向修剪

    Querying for XCLIP information inside AutoCAD using .NET  这里下面观众讨论了 How do I determine if an x-clip ...

  7. kali无法安装nvidia显卡驱动

    按照各位大神的博客安装nvidia显卡驱动一直失败,重启之后无法正常进入系统,恢复模式可以进入,一直以为自己是不是哪里步骤不对,后面来回重装了几次系统. 最后意识到虚拟机里用的是虚拟网卡,并非宿主机的 ...

  8. QFIL软件烧写镜像

    1.准备好需要烧写的文件 烧写之前,需要先准备好需要的文件,如下: 2.打开QFIL程序 接下来运行QFIL程序,如下: 3.选择端口 程序运行后,选择合适的端口,如下: 点击端口选择,然后选择Por ...

  9. 构造 + 离散数学、重言式 - POJ 3295 Tautology

    Tautology Description WFF 'N PROOF is a logic game played with dice. Each die has six faces represen ...

  10. windows下隐藏磁盘分区(转)

    在一定情况下有的人会想隐藏掉部分分区,比如双系统的情况 有两种方式 方法1: 删除盘符,适合在双系统的情况下隐藏掉另外一个系统相关的分区 请注意是删除盘符 不是删除分区 此电脑右键管理 点击磁盘管理 ...