基于 Linux 的 CentOS 7 安装 MySQL 8(阿里云服务器)

基于 Linux 的 CentOS 7 安装 MySQL 8

亲测可适用阿里云服务器centos7,从网上找了好多大佬的操作,结合了一下,之前的很多问题,终于安上了,发出来大家参考一下

(只是解决了我的问题,发出来供大家参考,如有侵权请联系我删除)

(最主要是阿里云服务器连接本地的navicat)

包含以下步骤

  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

图示

image-20211124173745968

查看是否有mysql依赖

 # rpm -qa | grep mysql

1、查看系统中是否自带安装mysql
 yum list installed | grep mysql
2、删除系统自带的mysql及其依赖(防止冲突)
 yum -y remove mysql-libs.x86_64

(全部删除)

1.2、下载资源包

  • 此处网上有多种教程都可以,都试过

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

2 种下载方式

1.2.2、官网下载

  • 此处也可以直接用yum下载

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

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

    image-20211125000605202

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. image-20211125002148348

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 文件夹。

    image-20220510102743817

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

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

2、配置工作

2.1、基本设置

安装完成后的基本设置。

2.1.1、文件夹重命名

  • 重命名 MySQL 文件夹(或创建软链接

  • 通常命名为 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
    • image-20211124211338766

  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

image-20211125013704323

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 &
    • image-20211125014023161

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

    •  ps -ef|grep mysql
    • image-20211125014115675

3.3.2、登录

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

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

     mysql -u root -p

说明

  • 登录后进入 MySQL 命令行

    image-20211125014331798

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

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

3.4、修改密码

3.4.1、首次修改

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

 # 修改密码
 ALTER USER 'root'@'localhost' IDENTIFIED BY '8位新密码';
 # 刷新权限
 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 字段 表示可访问当前数据库的主机,目前仅本地可访问。

    image-20211125020858741

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

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

    image-20211125021328155

4.2、远程连接 MySQL

以 Navicat 可视化工具为例

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

    image-20220510132315846

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

    在阿里云服务器此处需手动去开启

    登录到你的阿里云,点击控制台

    选择云服务器

    选择实例,然后通过你的服务器位置,找到对应的实例

    1.选择更多 2.选择网络和安全组 3.选择安全组配置

    选择配置规则

    点击快速添加

    选择mysql后,点击确定,这样你的服务器的3306端口就开启了

    使用第三方本地软件连接远程服务器上的mysql数据库
    这里我以navicat为例
    打开navicat,点击连接,选择mysql

    1. 自定义连接名  2. 输入你的服务器公网ip   3. 输入密码 4.点击确定按钮

    点击确定即可连接成功

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

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

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

       systemctl restart firewalld

  • 13
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值