前言
这两天买了台阿里云ECS服务器,准备安装mysql8,看了网上安装流程,结果五花八门,没有一个正确的,在这里我整理了下安装步骤分享下!
下载地址
https://downloads.mysql.com/archives/community/
- 第一个红框是包含了mysql-router,mysql-test,以及mysql本体;如果只是单机版 只下载第二个红框mysql本体就可以了。
安装
官方安装文档
https://dev.mysql.com/doc/refman/8.0/en/binary-installation.html
下载依赖
yum install libaio
将mysql放到 /usr/local/目录
将包mysql-8.0.27-linux-glibc2.12-x86_64.tar.xz放到 /usr/local/目录下
cd /usr/local/
解压mysql
tar -xvf mysql-8.0.27-linux-glibc2.12-x86_64.tar.xz
重命名文件夹
mv mysql-8.0.27-linux-glibc2.12-x86_64 mysql8
创建文件夹
mkdir data
mkdir tmp
目录结构
创建用户组以及用户和密码
groupadd mysql
useradd -g mysql mysql
授权用户
chown -R mysql.mysql /usr/local/mysql8/
编辑my.cnf文件 vi /etc/my.cnf
vi /etc/my.cnf
配置
[mysqld]
basedir = /usr/local/mysql8
datadir = /usr/local/mysql8/data
port = 3306
socket = /usr/local/mysql8/tmp/mysql.sock
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
[client]
port=3306
default-character-set=utf8mb4
socket = /usr/local/mysql8/tmp/mysql.sock
切换到mysql的bin目录下
cd bin
初始化基础信息
./mysqld --initialize --user=mysql
一定记住红框密码
添加mysqld服务到系统
切换到support-files目录
cp support-files/mysql.server /etc/init.d/mysql.server
授权以及添加服务
chmod +x /etc/init.d/mysql.server
chkconfig --add mysql.server
查看是否添加成功
将mysql命令添加到服务
ln -sf /usr/local/mysql8/bin/mysql /usr/bin
启动服务
service mysql.server start
查看启动状态
登录mysql mysql -uroot -p 密码使用之前随机生成的密码
我刚随机生成的密码是lrwQR75;ljAL 见上述初始化信息
mysql -uroot -p
修改root密码
ALTER USER 'root'@'localhost' IDENTIFIED BY '123456';
flush privileges;
其中123456为新密码
切换到mysql库
use mysql;
select host,user,plugin from user;
修改远程连接并生效
update user set host = '%' where user ='root';
flush privileges;
其中plugin为caching_sha2_password 远程连接需要带上后缀allowPublicKeyRetrieval = true
阿里云服务器配置安全组
远程连接测试
create database testdb;
DBeaver连接 修改驱动属性allowPublicKeyRetrieval = true
安装注意点
常见报错一:
缺少依赖libaio-devel.x86_64
yum install libaio-devel.x86_64
常见报错二:
没有XXX权限,mysql安装目录授权,命令读写权限刷一下!!!
|