CentOS7安装mysql8

一、配置yum源

1. 下载mysql源安装包

MySQL官网:http://dev.mysql.com/downloads/repo/yum/

  • 执行下载命令:
wget https://dev.mysql.com/get/mysql80-community-release-el7-1.noarch.rpm
2. 安装mysql源
yum localinstall mysql80-community-release-el7-1.noarch.rpm
3. 检查是否安装成功
yum repolist enabled | grep "mysql.*-community.*"

4. 修改安装版本(非必须)
  • 如果需要安装指定版本的mysql,可以修改/etc/yum.repos.d/mysql-community.repo源,改变默认安装的mysql版本。

例如要安装5.7版本,将5.7源的enabled=0改成enabled=1,将8.0的enabled=1改成enabled=0即可,如下(本次未做修改,直接安装最新版8.0.12)

二、安装mysql

yum install mysql-community-server

三、启动mysql服务

1. 启动
systemctl start mysqld
或者
service mysqld start
2. 查看启动状态
systemctl status mysqld
或者
service mysqld status

3. 设置开机启动
systemctl enable mysqld
systemctl daemon-reload

四、配置及部分命令

1. 修改登录密码
  • mysql安装完成之后,在/var/log/mysqld.log文件中给root生成了一个默认密码。通过下面的方式找到root默认密码,然后登录mysql进行修改
grep 'temporary password' /var/log/mysqld.log
或者
cat /var/log/mysqld.log | grep password

  • 本地MySQL客户端登录
mysql -uroot -p
  • 修改密码
ALTER USER 'root'@'localhost' IDENTIFIED BY 'TestBicon@123';
或者
set password for 'root'@'localhost'=password('TestBicon@123');

注:mysql5.7默认安装了密码安全检查插件(validate_password),默认密码检查策略要求密码必须包含:大小写字母、数字和特殊符号,并且长度不能少于8位。否则会提示ERROR 1819 (HY000): Your password does not satisfy the current policy requirements错误

  • 通过msyql环境变量可以查看密码策略的相关信息(执行这一步需要先修改默认密码,即执行完上一步修改才可以,否则会报错:ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executing this statement.)
show variables like '%password%';

validate_password_policy:密码策略,默认为MEDIUM策略

validate_password_dictionary_file:密码策略文件,策略为STRONG才需要

validate_password_length:密码最少长度

validate_password_mixed_case_count:大小写字符长度,至少1个

validate_password_number_count :数字至少1个

validate_password_special_char_count:特殊字符至少1个
2. 修改密码策略

如果没有设置使用指定目录的my.cnf,mysql启动时会读取安装目录根目录及默认目录下的my.cnf文件

  • 查看mysql默认读取my.cnf的目录
mysql --help|grep 'my.cnf'

  • 在my.cnf文件添加validate_password_policy配置,指定密码策略
# 选择0(LOW),1(MEDIUM),2(STRONG)其中一种,选择2需要提供密码字典文件。
validate_password_policy=0
# 如果不需要密码策略,添加my.cnf文件中添加如下配置禁用即可:
validate_password = off
  • 重新启动mysql服务使配置生效
systemctl restart mysqld
3. 添加远程登录用户

默认只允许root帐户在本地登录,如果要在其它机器上连接mysql,必须修改root允许远程连接,或者添加一个允许远程连接的帐户

  • 修改root用户远程访问权限,选择 mysql 数据库
use mysql;
  • 在 mysql 数据库的 user 表中查看当前 root 用户的相关信息
select host, user from user;

查看表格中 root 用户的 host,默认应该显示的 localhost,只支持本地访问,不允许远程访问。

  • 授权 root 用户的所有权限并设置远程访问
GRANT ALL ON *.* TO 'root'@'%';
# 如果报错:ERROR 1410 (42000): You are not allowed to create a user with GRANT
# 则使用:
update user set host='%' where user ='root';
  • 使修改生效
flush privileges;
4. sqlyog链接时出现2058异常
  • 完成上面的配置使用sqlyog链接时会出现2058的异常,此时我们需要修改mysql,命令行登录mysql(与修改密码中登录相同,使用修改后的密码),然后执行下面的命令
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'password';
# 其中password为自己修改的密码。然后SQLyog中重新连接,则可连接成功,OK
# 如果报错:ERROR 1396 (HY000): Operation ALTER USER failed for 'root'@'localhost'则使用下面命令
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'password';
5. 修改默认编码方式
  • mysql8.0默认编码方式为utf8mb4,因此使用时不需要修改,可使用如下命令查看
SHOW VARIABLES WHERE Variable_name LIKE 'character_set_%' OR Variable_name LIKE 'collation%';

  • 如果需要修改其他编码方式,方法有很多,以下仅为举例
  • 比如需要修改为utf8mb4,可以使用如下方式
  • 修改mysql配置文件my.cnf(windows为my.ini)
  • 在my.cnf中添加以下三部分内容
[client]

default-character-set = utf8mb4

[mysql]

default-character-set = utf8mb4

[mysqld]

character-set-client-handshake = FALSE

character-set-server = utf8mb4

collation-server = utf8mb4_unicode_ci

init_connect='SET NAMES utf8mb4'
  • 重启mysql即可
  • collation_connection 、collation_database 、collation_server是什么没关系。但必须保证以下这几个变量必须是utf8mb4
character_set_client  (客户端来源数据使用的字符集)
character_set_connection     (连接层字符集)
character_set_database   (当前选中数据库的默认字符集)
character_set_results (查询结果字符集)
character_set_server (默认的内部操作字符集)

注:数据库连接参数中:characterEncoding=utf8会被自动识别为utf8mb4,也可以不加这个参数,会自动检测。而autoReconnect=true是必须加上的。

6. 部分参数配置查询命令
#查询mysql最大连接数设置

show global variables like 'max_conn%';

SELECT @@MAX_CONNECTIONS AS 'Max Connections';

# 查看最大链接数

show global status like 'Max_used_connections';

# 查看慢查询日志是否开启以及日志位置

show variables like 'slow_query%';

# 查看慢查询日志超时记录时间

show variables like 'long_query_time';

# 查看链接创建以及现在正在链接数

show status like 'Threads%';

# 查看数据库当前链接

show processlist;

# 查看数据库配置

show variables like '%quer%';

五、彻底卸载mysql

1. 卸载软件
yum remove mysql-community-server
  • 完成后使用rpm -qa|grep mysql命令查看,如果有查询结果,则使用yum remove 名称清理掉

  • 再使用命令rpm -qa | grep -i mysql查看,如果有结果使用rpm -e 名称卸载

2. 删除文件
rm -rf /var/lib/mysql
rm /etc/my.cnf
rm -rf /usr/share/mysql-8.0
  • 如果需要重新安装,在安装完成启动之前可以先对mysql目录赋予权限防止异常发生
chmod -R 777 /var/lib/mysql

文章作者: 有梦想的咸鱼
版权声明: 咳咳想白嫖文章?本文章著作权归作者所有,任何形式的转载都请注明出处。 http://www.trisomy.cn !
还能输入 100 字
  目录