基于 Linux 的 CentOS 7 安装 MySQL 8,包含以下步骤

这篇具有很好参考价值的文章主要介绍了基于 Linux 的 CentOS 7 安装 MySQL 8,包含以下步骤。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

基于 Linux 的 CentOS 7 安装 MySQL 8,包含以下步骤

  1. 安装工作:卸载 MariaDB,下载资源包,检查旧版本 MySQL,解压安装。
  2. 配置工作:基本设置,创建用户组和用户,数据目录。
  3. 初始化 MySQL:配置文件,初始化。
  4. 启动 MySQL:启动服务,登录,修改密码,创建远程连接用户,退出和关闭。

1、安装工作

1.1、卸载 MariaDB(❗)

1.1.1、MariaDB

MySQL 的一个分支,主要由开源社区维护。

 

  1. CentOS 7+ 不再默认使用 MySQL 数据库,而是 MariaDB 数据库。
  2. 直接安装 MySQL 会与 MariaDB 的文件冲突。

👉 安装 MySQL 之前,先卸载自带的 MariaDB。

1.1.2、卸载

步骤

  1. 查看版本:有则需要卸载。

    rpm -qa|grep mariadb
    
  2. 卸载:复制文件名,执行以下指令。

    rpm -e --nodeps 文件名
    
  3. 确认卸载

    rpm -qa|grep mariadb
    

图示

centos7安装mysql8,linux

1.2、下载资源包

Hint:将 MySQL 资源包放在 /usr/local/ 下

2 种下载方式

1.2.1、官网下载

  1. 官网下载Linux - Generic (glibc 2.12) (x86, 64-bit)

  2. 上传到服务器/usr/local/ 目录下。

    centos7安装mysql8,linux

1.2.2、wget 下载

  1. wget 指令:在 /usr/local/ 下执行,下载资源包。

    # 格式:wget 资源地址
    wget https://dev.mysql.com/get/Downloads/MySQL-8.0/mysql-8.0.20-linux-glibc2.12-x86_64.tar.xz
    
  2. centos7安装mysql8,linux

1.3、检查旧版本 MySQL

指令

rpm -qa|grep mysql
  • 没有输出:说明当前系统没有安装 MySQL,开始安装。

  • 有输出:显示的 MySQL 不是想要的版本,则卸载。

    # 停止服务
    systemctl stop mysqld
    
    # 卸载
    rpm -e --nodeps mysql文件名
    

1.4、解压安装

解压安装

  1. 解压:tar 指令。

    # .tar.gz 后缀
    tar -zxvf 文件名
    
    # .tar.xz 后缀
    tar -Jxvf 文件名
    
  2. 解压完成/usr/local/ 下会生成 MySQL 文件夹。

    centos7安装mysql8,linux

Hint:将 MySQL 安装在 /usr/local/ 下

若没有安装在该目录下,通过 mv 指令移动到该目录。

2、配置工作(❗)

2.1、基本设置

安装完成后的基本设置。

2.1.1、文件夹重命名

  • 重命名 MySQL 文件夹(或创建软链接 👉文件管理 2.5)

  • 通常命名为 mysql版本号

    # 重命名(也可通过Xftp修改)
    mv 原文件夹名 mysql8
    
    # 软链接
    ln -s 文件夹名 mysql8
    

2.1.2、PATH 变量(❗)

添加 PATH 变量后,可在全局使用 MySQL

添加方式

  1. 临时生效:export 命令(连接会话关闭后失效,通常用于测试环境)

    export PATH=$PATH:/usr/local/mysql8/bin
    
  2. 永久生效:修改配置文件。

2.1.3、确认安装

  1. 查看版本

    • mysql --version
      
    • centos7安装mysql8,linux

       

  2. 确定 MySQL 安装成功后,可删除压缩包。

    rm -rf 压缩包名
    

2.2、创建用户组、用户(❗)

注:需要进入 /usr/local

  1. 创建用户组groupadd

  2. 创建用户useradd-r 创建系统用户,-g 指定用户组)

    groupadd mysql
    useradd -r -g mysql mysql
    

2.3、数据目录(❗)

  1. 创建目录

    mkdir -p /data/mysql8_data
    
  2. 赋予权限

    # 更改属主和数组
    chown -R mysql:mysql /data/mysql8_data
    
    # 更改模式
    chmod -R 750 /data/mysql8_data
    

3、初始化 & 启动(❗)

3.1、配置文件

在 /usr/local/etc/ 下创建 my.cnf 配置文件

用于初始化 MySQL 数据库

3.1.1、配置方式

注:部分配置涉及 MySQL 文件夹名称,若文件夹名不是 mysql8 则需修改。

  1. 在本地创建后,通过 Xftp 上传

  2. 使用 Vim 编辑器 进行编辑

    • 进入 Vim 编辑器

      vim /usr/local/etc/my.cnf
      
    • 按 i 进入输入模式,粘贴以下配置

    • 按 ESC 退出编辑模式,按 :wq 保存并退出

3.1.2、配置内容(❗)

[mysql]
# 默认字符集
default-character-set=utf8mb4
[client]
port       = 3306
socket     = /tmp/mysql.sock
[mysqld]
port       = 3306
server-id  = 3306
user       = mysql
socket     = /tmp/mysql.sock
# 安装目录
basedir    = /usr/local/mysql8
# 数据存放目录
datadir    = /data/mysql8_data/mysql
log-bin    = /data/mysql8_data/mysql/mysql-bin
innodb_data_home_dir      =/data/mysql8_data/mysql
innodb_log_group_home_dir =/data/mysql8_data/mysql
# 日志及进程数据的存放目录
log-error =/data/mysql8_data/mysql/mysql.log
pid-file  =/data/mysql8_data/mysql/mysql.pid
# 服务端字符集
character-set-server=utf8mb4
lower_case_table_names=1
autocommit =1
##### 以上涉及文件夹明,注意修改
skip-external-locking
key_buffer_size = 256M
max_allowed_packet = 1M
table_open_cache = 1024
sort_buffer_size = 4M
net_buffer_length = 8K
read_buffer_size = 4M
read_rnd_buffer_size = 512K
myisam_sort_buffer_size = 64M
thread_cache_size = 128
#query_cache_size = 128M
tmp_table_size = 128M
explicit_defaults_for_timestamp = true
max_connections = 500
max_connect_errors = 100
open_files_limit = 65535
binlog_format=mixed
binlog_expire_logs_seconds =864000
# 创建表时使用的默认存储引擎
default_storage_engine = InnoDB
innodb_data_file_path = ibdata1:10M:autoextend
innodb_buffer_pool_size = 1024M
innodb_log_file_size = 256M
innodb_log_buffer_size = 8M
innodb_flush_log_at_trx_commit = 1
innodb_lock_wait_timeout = 50
transaction-isolation=READ-COMMITTED
[mysqldump]
quick
max_allowed_packet = 16M
[myisamchk]
key_buffer_size = 256M
sort_buffer_size = 4M
read_buffer = 2M
write_buffer = 2M
[mysqlhotcopy]
interactive-timeout

3.2、初始化(❗)

Hint:需要进入 /usr/local/mysql/bin,若添加了 PATH 变量可忽略。

初始化命令:注意文件夹名称。

  • --defaults-file:指定配置文件(要放在--initialize 前面)

  • --user: 指定用户

  • --basedir:指定安装目录

  • --datadir:指定初始化数据目录

  • --intialize-insecure:初始化无密码(否则生成随机密码)

    mysqld --defaults-file=/usr/local/etc/my.cnf --basedir=/usr/local/mysql8 --datadir=/data/mysql8_data/mysql --user=mysql --initialize-insecure
    

3.3、启动 MySQL

查看 MySQL 的 /bin 下是否包含 mysqld_safe

用于后台安全启动 MySQL

centos7安装mysql8,linux

3.3.1、启动服务

  1. 安全后台启动 MySQL

    • # 完整命令
      /usr/local/mysql8/bin/mysqld_safe --defaults-file=/usr/local/etc/my.cnf &
      # 若添加了PATH变量,可省略如下
      mysqld_safe --defaults-file=/usr/local/etc/my.cnf &
      
    • centos7安装mysql8,linux

  2. 确认启动:第二条即 MySQL 服务。

    • ps -ef|grep mysql
      
    • centos7安装mysql8,linux

3.3.2、登录

  • 无密码:若以 --initialize-insecure 初始化,首次登录时跳过密码。

    mysql -u root --skip-password
    
  • 有密码:若初始化时设置了随机密码,在 /data/mysql8_data/mysql/mysql.log 查看

    mysql -u root -p
    

说明

  • 登录后进入 MySQL 命令行

    centos7安装mysql8,linux

     

  • 以下报错,说明 MySQL 服务没开启

    ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)

3.4、修改密码

3.4.1、首次修改

MySQL 初始化的 root 用户、新创建的用户,都需要设置首次密码。

建议使用本地密码插件 mysql_native_password

# 修改密码
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '新密码';

# 刷新权限
FLUSH PRIVILEGES;

3.4.2、平时修改

可在 Linux 或 MySQL 中修改。

  1. Linux 命令行

    mysqladmin -u用户名 -p旧密码 password 新密码
    
  2. MySQL 命令行

    # 设置密码
    SET PASSWORD FOR '用户名'@'主机' = PASSWORD(‘密码');
    
    # 刷新权限
    FLUSH PRIVILEGES;
    

3.5、退出、关闭服务

在 MySQL 命令行中执行

若在 Linux 命令行中,会退出/关闭 Linux 服务器。

  1. 退出 MySQL(命令行)

    quit;
    exit;
    
  2. 关闭 MySQL 服务

    shutdown;
    

4、远程连接 MySQL(❗)

4.1、创建远程连接用户(❗)

  1. 选择 mysql 数据库,查看当前用户

    USE mysql;
    
    SELECT user,host,plugin,authentication_string FROM user;
    
  2. host 字段 表示可访问当前数据库的主机,目前仅本地可访问。

    centos7安装mysql8,linux

  3. 创建用户,任意远程访问

    # 创建用户
    CREATE user 'root'@'%';
    
    # 设置首次密码
    ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '密码';
    
    # 授权用户所有权限,刷新权限
    GRANT ALL PRIVILEGES ON *.* TO 'root'@'%';
    FLUSH PRIVILEGES;
    
  4. 查看用户:已创建一个可被任意远程主机访问的 root 用户。

    centos7安装mysql8,linux

     

4.2、远程连接 MySQL

以 Navicat 可视化工具为例

  1. 启动 MySQL 服务(本文 4.1.1)

    centos7安装mysql8,linux

  2. 开放端口:默认端口号 3306

    • 查看端口状态:no 表示未开启

      firewall-cmd --query-port=3306/tcp
      
    • 永久开放端口

      firewall-cmd --add-port=3306/tcp --permanent
      
    • 重启防火墙

      systemctl restart firewalld
      
  3. 远程连接

    centos7安装mysql8,linux

TODO:远程连接报错 1045 分析。

完结撒花 🌹

Linux 中还可以设置 MySQL 开机自启,本文不做介绍。文章来源地址https://www.toymoban.com/news/detail-708795.html

到了这里,关于基于 Linux 的 CentOS 7 安装 MySQL 8,包含以下步骤的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Centos7安装mysql8.0操作步骤(yum安装方法)

    以下操作在Centos7.5上实操成功。 rpm -qa | grep -i mariadb(检查有没有mariadb) rpm -e  --nodeps  mariadb-libs-5.5.56-2.el7.x86_64(不检查依赖直接卸载) rpm -qa | grep mysql wget https://repo.mysql.com//mysql80-community-release-el7-3.noarch.rpm yum -y install mysql80-community-release-el7-3.noarch.rpm rpm --import https://rep

    2023年04月15日
    浏览(54)
  • Centos7 两种方式安装 MySQL5.7 步骤 yum 、本地 tar 文件

    1、卸载系统自带 mariadb MariaDB Server 是最流行的开源 关系型数据库 之一。它由 MySQL 的原始开发者制作,并保证保持开源。 在 CentOS 7 中默认安装有 MariaDB 可忽略,安装完成之后可以直接覆盖掉 MariaDB。 查看并卸载系统自带的 Mariadb 2、下载并安装 MySQL 官方的 Yum 由于 CentOS 的

    2024年01月24日
    浏览(40)
  • minio 安装流程(linux) Centos7环境下搭建minio步骤详细教程

    一、下载安装文件     1、在home目录下创建minio文件夹     2、进入/home/minio 文件夹     3、下载文件 二、创建数据文件夹     三、创建日志文件 四、启动   如果想要修改超管账户名和密码 1、打开 /etc/profile 文件 2、在文件的最末尾加上以下信息(启动的时候看提示,新版

    2024年02月10日
    浏览(51)
  • Linux下安装Mysql【CentOS7 】

    Mysql官网:https://www.mysql.com/ 下载网址:https://downloads.mysql.com/archives/community/ 首先使用第三方工具上传 解压后的文件都是 rpm 文件,因此需要用到 rpm 包资源管理器相关的指令安装这些 rpm 的安装包 安装完该插件之后, 依次执行 以下命令安装这些 rpm 包 问题1 解决方案1:清除之

    2024年01月18日
    浏览(57)
  • 基于CentOS7安装MySQL数据库并远程访问

    MySQL是目前最为流行的开放源码的数据库,是完全网络化的跨平台的关系型数据库系统,它是由瑞典MySQLAB公司开发,目前属于Oracle公司。任何人都能从Internet下载MySQL软件,而无需支付任费用,并且“开放源码”意味着任何人都可以使用和修改该软件。下面我们来学习如何在

    2024年02月11日
    浏览(39)
  • Linux(CentOS7)安装与卸载MySQL8.0图文详解

    Mysql数据库的安装对于开发者来说,是我们必然会面对的问题,它的安装过程其实并不复杂,并且网络上的安装教程也非常多,但是对于新手来说,各种不同形式的安装教程,又给新手们带来了要选择哪种方式进行安装的难题,而且很多时候按照教程也没有能够安装成功,安

    2023年04月25日
    浏览(35)
  • 【Linux】Centos7 shell实现MySQL5.7 tar 一键安装

    🦄 个人主页——🎐 个人主页 🎐✨🍁 🪁🍁🪁🍁🪁🍁🪁🍁 感谢点赞和关注 ,每天进步一点点!加油!🪁🍁🪁🍁🪁🍁🪁🍁 目录 一、安装下载 二、执行安装 下载地址: https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.44-el7-x86_64.tar.gz 脚本和tar包结构 my.cnf 配置文件 ins

    2024年02月05日
    浏览(29)
  • linux centos7系统离线部署mysql-8.0.35免安装版本

    在CentOS中默认安装有MariaDB,是MySQL的一个分支,主要由开源社区维护。 CentOS 7及以上版本已经不再使用MySQL数据库,而是使用MariaDB数据库。 如果直接安装MySQL,会和MariaDB的文件冲突。 因此,需要先卸载自带的MariaDB,再安装MySQL。 查看版本: 卸载 检查是否卸载干净: 注意:

    2024年01月18日
    浏览(39)
  • Linux CentOs7 安装Mysql(5.7和8.0版本)密码修改 超详细教程

    今天出一期Centos下安装Mysql(详细教程)包括数据库密码跳过修改  目录 1.获取安装包 2.安装程序 安装下载的rpm包 查看安装包 修改5.7版本(重要) 安装MySQL Server 3. 进入数据库 方法1.   查找密码 方法2.   跳过密码 4.修改登录密码 官网下载地址 这里有很多不同的版本(选择

    2024年01月24日
    浏览(51)
  • Centos7的详细安装步骤

    虚拟机环境: VMWare15.5Pro 官网地址: https://www.vmware.com/cn.html 安装的过程中需要序列码,百度搜索VMware序列码多得很。例如: https://www.win7zhijia.cn/win10jc/win10_44991.html 镜像:Centos7 阿里云Centos7镜像下载地址: https://developer.aliyun.com/mirror/ 打开地址后,选择屏幕中间的OS镜像进行选

    2024年02月05日
    浏览(46)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包