安装MySQL8

88 阅读4分钟

[TOC]

安装 MySQL8

Linux:CentOS7安装MySQL8(详) - Jaywee - 博客园 (cnblogs.com)

# 创建目录放安装包
mkdir /opt/mysql
tar -zxvf /opt/mysql/mysql.xx.tar.gz -C /usr/local
cd /usr/local

# 重命名(也可通过Xftp修改
mv 原文件夹名 mysql8


# 删除以前的 mari与历史版本mysql,mari与mysql有冲突
rpm -qa | grep mari
rpm -qa | grep mari

# 强制删除软件包
rpm -e --nodeps  软件包名
rpm -e --nodeps  mari


# 配置环境变量
vim /etc/profile
export MYSQL=/usr/local/mysql8
export PATH=$MYSQL/bin:$PATH


# 打开端口
firewall-cmd --permanent --add-port=3306/tcp

# 关闭端口

# firewall-cmd --permanent --remove-port=端口/协议


# 重新载入,才能生效
firewall-cmd --reload

# 查询端口是否开放

# yes:开,no:关
firewall-cmd --query-port=端口/协议  


# 查看版本
mysql --version


cd /usr/local
groupadd mysql
useradd -r -g mysql mysql


# 创建数据目录
mkdir -p /data/mysql8_data

# 更改属主和数组
chown -R mysql:mysql /data/mysql8

# 更改模式
chmod -R 750 /data/mysql8
vim /usr/local/etc/my.cnf

[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/mysql
log-bin    = /data/mysql8/mysql/mysql-bin
innodb_data_home_dir      =/data/mysql8/mysql
innodb_log_group_home_dir =/data/mysql8/mysql

# 日志及进程数据的存放目录
log-error =/data/mysql8/mysql/mysql.log
pid-file  =/data/mysql8/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

初始化

需要进入 /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/mysql --user=mysql --initialize-insecure

启动 MySQL

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

用于后台安全启动 MySQL

image-20211125013704323

# 完整命令
/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

确认启动

ps -ef|grep mysql

登录

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

mysql -u root --skip-password

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

mysql -u root -p

修改密码

# 使用自带的mysql数据库
use mysql;   


# 查看密码策略
SHOW VARIABLES LIKE 'validate_password%'; 


# 修改密码强度等级

# 默认等级为MEDIUM(中等)改为low
set global validate_password.policy=0; 



# 修改密码长度

# 只验证长度5
set global validate_password.length=5; 


# 修改密码
ALTER USER 'root'@'localhost' IDENTIFIED BY '你自己要改的新密码';


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


# 刷新权限
FLUSH PRIVILEGES;

平时修改

Linux 命令行

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

MySQL 命令行

# 设置密码
SET PASSWORD FOR '用户名'@'主机' = PASSWORD(‘密码');

SET PASSWORD FOR 'root'@'localhost' = PASSWORD('root');

# 刷新权限
FLUSH PRIVILEGES;

忘记 Root 密码

# 先杀掉所有mysql服务
killall -9 mysql
killall -9 mysqld


# 前面安装时设的路径 /usr/local/etc/my.cnf

# 一般叫 my.cnf ,可以用 find 查找

# 修改/usr/local/etc/my.cnf
vim /usr/local/etc/my.cnf

# 在 [mysqld] 配置最后加上如下语句,保存退出:
skip-grant-tables


# 启动mysql  启动后不要关命令行终端

# 完整命令
/usr/local/mysql8/bin/mysqld_safe --defaults-file=/usr/local/etc/my.cnf &

# 若添加了PATH变量,可省略如下
mysqld_safe --defaults-file=/usr/local/etc/my.cnf &


# 新开一个命令行终端
mysql -u root -p

# password 直接回车登录


mysql> use mysql;

# 设置新密码

mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY '你自己要改的新密码';

# 刷新权限

mysql> FLUSH PRIVILEGES;

mysql> quit;

vim /usr/local/etc/my.cnf

# 在 [mysqld] 配置最后注释刚刚添加的语句,保存退出:

# skip-grant-tables


# 重启mysql
killall -9 mysqld
systemctl start mysqld

退出 MySQL

quit;
exit;

关闭 MySQL 服务

shutdown;

远程连接 MySQL

(133条消息) SQLyog连接虚拟机中mysql8.0详解,2003、1130、2058错误码解决_有时候我也会的博客-CSDN博客_sqlyog连接虚拟机mysql

mysql>use mysql;

mysql>update user set host = '%' where user ='root';

mysql>flush privileges;

查看ip及mysql端口

# 查看虚拟机ip
ifconfig  


# 切换到mysql命令,-p后跟新设置的密码
mysql -uroot -p 密码 


# 查看端口
show global variables like 'port';