Bootstrap

【二】、Linux中mysql的安装并用Navicat连接

1.将rpm文件通过xftp下载到linux的opt文件夹下

把rpm文件导入到opt文件夹下

2.通过命令安装rpm源

yum -y install mysql80-community-release-el8-3.noarch.rpm
安装完毕

3.安装mysql

yum -y install mysql-community-server
如果报错
报错信息

再仔细分析下日志,发现mysql8相关的安装包系统版本号都是el8,说明这个包是针对CentOS8的,而不是CentOS7(el7).
我此时安装的镜像为Centos7

解决办法:
下载适合版本的镜像
官方镜像
在这里插入图片描述
我重装了系统,没找到如果错了怎么办,mysql用了el7的就可以了
安装成功

4.启动mysql

systemctl start mysqld

5.检验mysql是否启动成功

systemctl status mysqld
检验mysql是否启动成功

6.查看mysql密码

由于是在线安装所以不知道密码
密码在/var/log/mysqld.log日志里面但是由于日志文件里面东西很多,所以我们不是用这个方法查询密码

grep "password" /var/log/mysqld.log
查看mysql密码

7.根据密码登录数据库

mysql -uroot -p
根据密码登录数据库

这个时候随便输什么都需要重新设置密码之后才可以的

需要重新设置密码
所以要先修改密码
alter user 'root'@'localhost' identified by 'rootRoot123.';
先修改密码

8.查看密码策略

使用原始的密码策略复杂,当开发时可以修改

show variables like 'validate_password%';

密码策略

dictionary_file(字典文件)是根据policy(策略)来配置的,如果policy改成strong才需要dictionary_file

9.修改密码策略和长度

修改密码策略
set global validate_password.policy=0;
修改密码策略

policy 策略

  • 0:low
  • 1:medium
  • 2:strong

修改密码长度
set global validate_password.length=4;
修改密码长度

10.修改密码(与上面一致)

11.创建一个用户去远程访问

如果使用root去进行远程访问那安全性就太差了

create user 'asule'@'%' identified by '1234';
创建一个用户去远程访问

‘asule’@‘%’ ,%代表任何IP都可以访问,localhost的话就是只能本机访问

给asule授权

grant all on *.* to 'asule'@'%';
给asule授权

  • all:所有的权限
  • *.*:所有的数据库所有的表

12.检查防火墙是否开启

firewall-cmd --permanent --zone=public --list-ports

检查防火墙是否开启

啥端口都没有开启

  1. 首先要先开启防火墙
    systemctl start firewalld.service

  2. 开放端口
    firewall-cmd --zone=public --add-port=3306/tcp --permanent
    firewall-cmd --zone=public --add-port=3306/udp --permanent

  3. 重新启动防火墙
    firewall-cmd --reload

  4. 查看端口是否开启
    查看端口是否开启
    图中显示已经开启

  5. 远程连接
    远程连接

13.如果在云服务器上需要添加安全组端口是3306

;