文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2023-09-10 19:27

关注

基于 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

图示

1.2、下载资源包

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

2 种下载方式

1.2.1、官网下载

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

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

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

1.3、检查旧版本 MySQL

指令

rpm -qa|grep mysql

1.4、解压安装

解压安装

  1. 解压:tar 指令。

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

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

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

2、配置工作(❗)

2.1、基本设置

安装完成后的基本设置。

2.1.1、文件夹重命名

2.1.2、PATH 变量(❗)

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

添加方式

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

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

2.1.3、确认安装

  1. 查看版本

    • mysql --version
    •  

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

    rm -rf 压缩包名

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

注:需要进入 /usr/local

  1. 创建用户组groupadd

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

    groupadd mysqluseradd -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       = 3306socket     = /tmp/mysql.sock[mysqld]port       = 3306server-id  = 3306user       = mysqlsocket     = /tmp/mysql.sock# 安装目录basedir    = /usr/local/mysql8# 数据存放目录datadir    = /data/mysql8_data/mysqllog-bin    = /data/mysql8_data/mysql/mysql-bininnodb_data_home_dir      =/data/mysql8_data/mysqlinnodb_log_group_home_dir =/data/mysql8_data/mysql# 日志及进程数据的存放目录log-error =/data/mysql8_data/mysql/mysql.logpid-file  =/data/mysql8_data/mysql/mysql.pid# 服务端字符集character-set-server=utf8mb4lower_case_table_names=1autocommit =1##### 以上涉及文件夹明,注意修改skip-external-lockingkey_buffer_size = 256Mmax_allowed_packet = 1Mtable_open_cache = 1024sort_buffer_size = 4Mnet_buffer_length = 8Kread_buffer_size = 4Mread_rnd_buffer_size = 512Kmyisam_sort_buffer_size = 64Mthread_cache_size = 128#query_cache_size = 128Mtmp_table_size = 128Mexplicit_defaults_for_timestamp = truemax_connections = 500max_connect_errors = 100open_files_limit = 65535binlog_format=mixedbinlog_expire_logs_seconds =864000# 创建表时使用的默认存储引擎default_storage_engine = InnoDBinnodb_data_file_path = ibdata1:10M:autoextendinnodb_buffer_pool_size = 1024Minnodb_log_file_size = 256Minnodb_log_buffer_size = 8Minnodb_flush_log_at_trx_commit = 1innodb_lock_wait_timeout = 50transaction-isolation=READ-COMMITTED[mysqldump]quickmax_allowed_packet = 16M[myisamchk]key_buffer_size = 256Msort_buffer_size = 4Mread_buffer = 2Mwrite_buffer = 2M[mysqlhotcopy]interactive-timeout

3.2、初始化(❗)

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

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

3.3、启动 MySQL

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

用于后台安全启动 MySQL

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 &
  2. 确认启动:第二条即 MySQL 服务。

    • ps -ef|grep mysql

3.3.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 字段 表示可访问当前数据库的主机,目前仅本地可访问。

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

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

     

4.2、远程连接 MySQL

以 Navicat 可视化工具为例

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

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

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

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

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

      systemctl restart firewalld
  3. 远程连接

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

完结撒花 🌹

Linux 中还可以设置 MySQL 开机自启,本文不做介绍。

来源地址:https://blog.csdn.net/qq_51835226/article/details/131575378

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯