Linux安装mysql8

168 阅读6分钟

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

  1. 卸载

:复制文件名,执行以下指令。

rpm -e --nodeps 文件名

  1. 确认卸载

rpm -qa|grep mariadb

图示

0

1.2、下载资源包

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

2 种下载方式:

1.2.1、官网下载

  1. 官网下载

:Linux - Generic (glibc 2.12) (x86, 64-bit)

  1. 上传到服务器

:/usr/local/ 目录下。

0

1.2.2、wget 下载

  1. wget 指令

:在 /usr/local/ 下执行,下载资源包。

格式:wget 资源地址 wget dev.mysql.com/get/Downloa…

0

1.3、检查旧版本 MySQL

指令:rpm -qa|grep mysql

  • 没有输出

:说明当前系统没有安装 MySQL,开始安装。

  • 有输出

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

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

1.4、解压安装

解压安装

  1. 解压

:tar 指令。

#解压前需线删除my.cnf文件(怕起后续冲突,最好还是删除) rm /etc/my.cnf # .tar.gz 后缀 tar -zxvf 文件名 # .tar.xz 后缀 tar -Jxvf 文件名

  1. 解压完成

:/usr/local/ 下会生成 MySQL 文件夹。

0

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

  1. 永久生效

:修改配置文件。

2.1.3、确认安装

  1. 查看版本
    • mysql --version

0

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

rm -rf 压缩包名

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

注:需要进入 /usr/local

  1. 创建用户组

:groupadd

  1. 创建用户

:useradd(-r 创建系统用户,-g 指定用户组)

groupadd mysql useradd -r -g mysql mysql

2.3、数据目录(❗)

  1. 创建目录

mkdir -p /data/mysql8_data

  1. 赋予权限

更改属主和数组 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 上传
  1. 使用

 Vi 编辑器 进行编辑

    • 进入 Vi 编辑器

vi /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/mysql8/bin,若添加了 PATH 变量可忽略。

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

  • --defaults-file:指定配置文件(要放在--initialize 前面)
  • --user: 指定用户
  • --basedir:指定安装目录
  • --datadir:指定初始化数据目录
  • --intialize-insecure:初始化无密码(否则生成随机密码)

--lower-case-table-names=1:不区分大小写

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

3.3、启动 MySQL

查看 MySQL 的 /bin 下是否包含 mysqld_safe用于后台安全启动 MySQL

0

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 &

0

  1. 确认启动

:第二条即 MySQL 服务。

    • ps -ef|grep mysql

0

3.3.2、登录

  • 无密码

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

mysql -u root --skip-password

  • 有密码

:若初始化时设置了随机密码,在 /data/mysql8_data/mysql/mysql.log 查看

mysql -u root -p

说明

  • 登录后进入 MySQL 命令行

0

  • 以下报错,说明 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 '123456'; # 刷新权限 FLUSH PRIVILEGES;

3.4.2、平时修改

可在 Linux 或 MySQL 中修改。

  1. Linux 命令行

mysqladmin -u用户名 -p旧密码 password 新密码

  1. MySQL 命令行

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

3.5、退出、关闭服务

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

  1. 退出 MySQL(命令行)

quit; exit;

  1. 关闭 MySQL 服务

shutdown;

4、远程连接 MySQL(❗)

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

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

USE mysql; SELECT user,host,plugin,authentication_string FROM user;

  1. host 字段

 表示可访问当前数据库的主机,目前仅本地可访问。

0

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

创建用户 CREATE user 'root'@'%'; # 设置首次密码 ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456'; # 授权用户所有权限,刷新权限 GRANT ALL PRIVILEGES ON . TO 'root'@'%'; FLUSH PRIVILEGES;

  1. 查看用户

:已创建一个可被任意远程主机访问的 root 用户。

0

4.2、远程连接 MySQL

以 Navicat 可视化工具为例

  1. 启动 MySQL 服务

(本文 4.1.1)

0

  1. 开放端口

:默认端口号 3306

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

firewall-cmd --query-port=3306/tcp

开启防火墙

systemctl start firewalld

永久开放端口

firewall-cmd --add-port=3306/tcp --permanent

    • 重新载入

firewall-cmd --reload

    • 重启防火墙

systemctl restart firewalld

关闭防火墙

systemctl stop firewalld