CentOS 7 安装 MySQL 8.0 部署文档

CentOS 7 安装 MySQL 8.0 部署文档

1. 安装 MySQL
  1. 添加 MySQL Yum 仓库:

    复制代码
    sudo rpm -Uvh https://dev.mysql.com/get/mysql80-community-release-el7-3.noarch.rpm
  2. 安装 MySQL 服务:

    复制代码
    sudo yum install --nogpgcheck mysql-community-server
2. 初始化 MySQL
  1. 初始化数据库:

    复制代码
    mysqld --initialize --user=mysql --lower-case-table-names=1
  2. 记录 root 密码 :

    查看 /var/log/mysqld.log 文件获取自动生成的临时 root 密码。

    复制代码
    grep "password" /var/log/mysqld.log
3. 修改 /etc/my.cnf 配置文件
  1. 编辑配置文件:

    复制代码
    vi /etc/my.cnf
  2. 添加配置 :

    [mysqld] 下添加:

    复制代码
    lower-case-table-names=1
    default-time_zone='+8:00'
    max_connections=1000
    max_connect_errors=1000
    default-authentication-plugin=mysql_native_password
    character-set-server=utf8
    sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION'

    [client][mysql] 下添加:

    复制代码
    default-character-set=utf8
4. 启动 MySQL 服务
复制代码
systemctl start mysqld
5. 修改数据库 root 密码及创建全域 root 用户
  1. 登录 MySQL :

    使用记录的临时密码登录。

    复制代码
    mysql -u root -p
  2. 修改 root 用户密码:

    复制代码
    ALTER USER 'root'@'localhost' IDENTIFIED BY 'QWER1234@';
  3. 创建全域 root 用户:

    复制代码
    CREATE USER 'root'@'%' IDENTIFIED BY 'QWER1234@';
    GRANT ALL PRIVILEGES ON *.* TO 'root'@'%';
    FLUSH PRIVILEGES;
  4. 更改权限:

    复制代码
    UPDATE mysql.user SET Grant_priv='Y', Super_priv='Y' WHERE user ='root' AND host='%'; 
    FLUSH PRIVILEGES;
6. 配置修改
  • 重启 MySQL 服务:

    复制代码
    systemctl restart mysqld
  • 验证配置 :

    使用相应的验证 SQL 语句来确认配置的修改。

7. 更改数据文件存储位置
  1. 停止 MySQL 服务:

    复制代码
    systemctl stop mysqld
  2. 创建新的数据存储路径:

    复制代码
    mkdir -p /home/data/mysql
    mv /var/lib/mysql/* /home/data/mysql/
  3. 修改 /etc/my.cnf 配置 :

    [mysqld] 下修改 datadirsocket 路径。

    复制代码
    datadir=/home/data/mysql
    socket=/home/data/mysql/mysql.sock

    [client] 下添加:

    复制代码
    socket=/home/data/mysql/mysql.sock
  4. 启动 MySQL 服务:

    复制代码
    systemctl start mysqld
相关推荐
历程里程碑3 分钟前
21:重谈重定义理解一切皆“文件“及缓存区
linux·c语言·开发语言·数据结构·c++·算法·缓存
李少兄5 分钟前
MySQL 中为时间字段设置默认当前时间
android·数据库·mysql
AZ996ZA14 分钟前
自学linux的二十天【DNS 服务从入门到实战】
linux·运维·服务器
wdfk_prog14 分钟前
[Linux]学习笔记系列 -- [drivers][mmc]mmc_sd
linux·笔记·学习
qinyia15 分钟前
**使用AI助手在智慧运维中快速定位并修复服务异常:以Nginx配置错误导致502错误为例**
linux·运维·服务器·数据库·mysql·nginx·自动化
❀͜͡傀儡师16 分钟前
CentOS 7部署FTP服务
linux·运维·centos·ftp
济61720 分钟前
ARM Linux 驱动开发篇----字符设备驱动开发(2)--字符设备驱动开发步骤---- Ubuntu20.04
linux·运维·服务器
仗剑天涯 回首枉然25 分钟前
Linux 和 windows 共享文件
linux·运维·windows
zzzsde27 分钟前
【Linux】进程(3):进程状态
linux·运维·服务器
Mr_liu_66628 分钟前
ubuntu:beyond compare 4 This license key has been revoked——————转载拼接
linux·运维·ubuntu