1. 安装

更新数据源

1
apt-get update

安装 MySQL

1
apt-get install mysql-server

系统将提示您在安装过程中创建 root 密码。选择一个安全的密码,并确保你记住它,因为你以后需要它。接下来,我们将完成 MySQL 的配置

2. 配置

因为是全新安装,您需要运行附带的安全脚本。这会更改一些不太安全的默认选项,例如远程 root 登录和示例用户。在旧版本的 MySQL 上,您需要手动初始化数据目录,但 Mysql 5.7 已经自动完成了。

运行安全脚本:

1
mysql_secure_installation

这将提示您输入您在之前步骤中创建的 root 密码。您可以按 Y,然后 ENTER 接受所有后续问题的默认值,但是要询问您是否要更改 root 密码。您只需在之前步骤中进行设置即可,因此无需现在更改

3. 测试

按上边方式安装完成后,MySQL 应该已经开始自动运行了。要测试它,请检查其状态。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
root@zysheep:/usr/local/tomcat# ystemctl status mysql.service
-bash: ystemctl: command not found
root@zysheep:/usr/local/tomcat# systemctl status mysql.service
● mysql.service - MySQL Community Server
Loaded: loaded (/lib/systemd/system/mysql.service; enabled; vendor preset: enabled)
Active: active (running) since Sun 2020-01-05 12:34:18 CST; 21min ago
Process: 3069 ExecStartPost=/usr/share/mysql/mysql-systemd-start post (code=exited, status=0/SUCCESS)
Process: 3057 ExecStartPre=/usr/share/mysql/mysql-systemd-start pre (code=exited, status=0/SUCCESS)
Main PID: 3068 (mysqld)
Tasks: 31
Memory: 153.5M
CPU: 2.040s
CGroup: /system.slice/mysql.service
└─3068 /usr/sbin/mysqld

Jan 05 12:34:17 zysheep systemd[1]: Starting MySQL Community Server...
Jan 05 12:34:18 zysheep systemd[1]: Started MySQL Community Server.
root@zysheep:/usr/local/tomcat#

查看 MySQL 版本:

1
mysqladmin -p -u root version

3. 配置远程访问

修改配置文件

1
vim /etc/mysql/mysql.conf.d/mysqld.cnf

注释掉(语句前面加上 # 即可):

1
bind-address = 127.0.0.1   或者修改地址为0.0.0.0

重启 MySQL

1
service mysql restart

登录 MySQL

1
mysql -u root -p

授权 root 用户允许所有人连接

1
grant all privileges on *.* to 'root'@'%' identified by '你的 mysql root 账户密码';

3. 因弱口令无法成功授权解决步骤

查看和设置密码安全级别

1
2
3
select @@validate_password_policy;

set global validate_password_policy=0;

查看和设置密码长度限制

1
2
3
select @@validate_password_length;

set global validate_password_length=1;

4. 常用命令

启动

1
service mysql start

停止

1
service mysql stop

重启

1
service mysql restart

5. 其它配置

修改配置mysqld.cnf 配置文件

1
vim /etc/mysql/mysql.conf.d/mysqld.cnf

配置默认字符集

在[mysqld]节点上增加如下配置

1
2
[client]
default-character-set=utf8

[mysqld]节点底部增加如下配置

1
2
3
default-storage-engine=INNODB
character-set-server=utf8
collation-server=utf8_general_ci

配置忽略数据库大小写敏感

[mysqld] 节点底部增加如下配置

1
lower-case-table-names = 1

Contos 7 安装mysql

MySql8.0远程连接配置

1
2
3
4
5
6
7
8
use mysql
修改host为%,并刷新权限
update user set host='%' where user='root';
flush privileges;
修改密码的加密方式
alter user 'root'@'%' indetified by 'root' password expire never;
alter user 'root'@'%' indetified with mysql_native_password by 'root';
flush privileges;

Centos7开放及查看端口

1、开放端口

1
2
3
4
5
firewall-cmd --zone=public --add-port=8080/tcp --permanent   # 开放8080端口

firewall-cmd --zone=public --remove-port=8080/tcp --permanent #关闭8080端口

firewall-cmd --reload # 配置立即生效

2、查看防火墙所有开放的端口

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

3.、关闭防火墙

1
2
如果要开放的端口太多,嫌麻烦,可以关闭防火墙,安全性自行评估
systemctl stop firewalld.service

4、查看防火墙状态

1
firewall-cmd --state

关闭防火墙

1
2
3
4
5
6
7
8
9
10
11
12
13
查看防火墙状态
systemctl status firewalld.service

执行后可以看到绿色字样标注的“active(running)”,说明防火墙是开启状态

关闭运行的防火墙
systemctl stop firewalld.service

关闭后,使用命令systemctl status firewalld.service

查看防火墙状态

可以看到,disavtive(dead)的字样,说明防火墙已经关闭