进阶篇(1) Linux安装mysql

129 阅读9分钟

0. 安装前准备

0.1 检查是否安装过MySQL

rpm -qa | grep -i mysql # -i 忽略大小写

image.png
不存在则没有

0.2 卸载 MySQL

  • 关闭MySQL服务
systemctl stop mysqld.service
  • 查看当前安装状态
rpm -qa | grep -i mysql
  • 卸载上述命令查询出的已安装程序
yum remove mysqlxxx
  • 删除MySQL相关文件
find / -name mysql # 查找相关文件
rm -rf xxx # 删除上述查找出的文件
rm -rf /etc/my.cnf # 删除my.cnf

1. 下载MySQL

2.1 下载压缩包

MySQL :: Download MySQL Community Server

  • 选择对应的参数
    • 本机使用的是centos7,所以用 RedHat Linux7
  • 下载 bundle image.png
  • 我们只需要如下几个文件,将他们传到 /opt 目录下

image.png

2.2 依赖检查

  • 检查/tmp临时目录权限:mysql安装过程中,会在/tmp目录下新建tmp_db文件,所以请给/tmp较大的权限。
chmod -R 777 /tmp
  • 检查依赖(不存在请自行安装)
rpm -qa|grep libaio
rpm -qa|grep net-tools

2. 安装与初始化

# 必须按顺序
rpm -ivh mysql-community-common-8.0.25-1.el7.x86_64.rpm
rpm -ivh mysql-community-client-plugins-8.0.25-1.el7.x86_64.rpm
rpm -ivh mysql-community-libs-8.0.25-1.el7.x86_64.rpm 
rpm -ivh mysql-community-client-8.0.25-1.el7.x86_64.rpm 
rpm -ivh mysql-community-icu-data-files-8.0.28-1.el7.x86_64.rpm
rpm -ivh mysql-community-server-8.0.25-1.el7.x86_64.rpm
  • 可能出现的报错

清除之前的依赖即可 image.png

安装成功后

  • 查看版本
mysql --version
  • 服务初始化
    • 为了保证数据库目录与文件的所有者为 mysql 登录用户,如果你是以 root 身份运行 mysql 服务,需要执 行下面的命令初始化:
mysqld --initialize --user=mysql
# --initialize 选项默认以“安全”模式来初始化
# 会为 root 用户生成一个密码并将 该密码标记为过 期 ,登录后你需要设置一个新的密码。生成的 临时密码 会往日志中记录一份。
  • 查看密码
cat /var/log/mysqld.log
  • 启动MySQL,查询状态
    • mysqld 这个可执行文件就代表着 MySQL 服务器程序,运行这个可执行文件就可以直接启动一个 服务器进程。
启动:systemctl start mysqld
关闭:systemctl stop mysqld
重启:systemctl restart mysqld
查看状态:systemctl status mysqld

查看进程

ps -ef | grep -i mysql

image.png

  • 查看是否自启动
systemctl list-unit-files|grep mysqld.service
# 设置自启动与否
systemctl enable mysqld.service
systemctl disable mysqld.service

3.. MySQL登录

3.1 首次登录

mysql -hlocalhost -P3306 -uroot -p  # 密码在cat /var/log/mysqld.log

3.2 修改密码

ALTER USER 'root'@'localhost' IDENTIFIED BY '123456';

3.3 设置远程连接

3.3.1 当前问题

在用SQLyog或Navicat中配置远程连接Mysql数据库时遇到如下报错信息,这是由于Mysql配置了不支持远程连接引起的。 image.png

3.3.2 确认网络
  1. 在远程机器上使用ping ip地址 保证网络畅通
  2. 在远程机器上使用telnet命令 保证端口号开放 访问
telnet ip地址 端口号

telnet命令开启 :

image.png

image.png
连接不上 image.png

3.3.3 关闭防火墙
systemctl stop firewalld.service
3.3.4 修改配置
// mysql下
use mysql;
select Host,User from user;

image.png 可以看到root用户的当前主机配置信息为localhost。

  • 修改Host为通配符%

Host列指定了允许用户登录所使用的IP。root用户只能通过本机的客户端去访问。
而 % 是个 通配符 ,如果Host=192.168.1.%,只要是IP地址前缀为“192.168.1.”的客户端都可以连接。如果 Host=% ,表示所有IP都有连接权限。

注意:在生产环境下不能为了省事将host设置为%,这样做会存在安全问题,具体的设置可以根据生产 环境的IP进行设置。

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

Host修改完成后记得执行flush privileges使配置立即生效:

flush privileges;

可以连接上了:image.png

4. 字符集相关操作

4.1 修改步骤

  • 查看默认使用的字符集
show variables like 'character%';

image.png

而MySQL5.7及之前版本默认字符集为 latin1,不支持中文 image.png

  • 修改字符集
vim /etc/my.cnf

在MySQL5.7或之前的版本中,在文件最后加上中文字符集配置:

character_set_server=utf8
  • 重新启动MySQL服务
systemctl restart mysqld

修改已创建数据库/表的字符集

alter database 数据库名 character set 'utf8';
alter table 表名 convert to character set 'utf8';

4.2 各级别字符集

MySQL有4个级别的字符集和比较规则,分别是:

  • 服务器级别
  • 数据库级别
  • 表级别
  • 列级别

image.png

  • character_set_server:服务器级别的字符集
  • character_set_database:当前数据库的字符集
  • character_set_client:服务器解码请求时使用的字符集
  • character_set_connection:服务器处理请求时会把请求字符串从character_set_client转为 character_set_connection
  • character_set_results:服务器向客户端返回数据时使用的字符集

1. 服务器级别
我们可以在配置文件中修改

[server] 
character_set_server=gbk # 默认字符集
collation_server=gbk_chinese_ci #对应的默认的比较规则

2. 数据库级别

CREATE DATABASE 数据库名
    [[DEFAULT] CHARACTER SET 字符集名称] 
    [[DEFAULT] COLLATE 比较规则名称]; 
    
ALTER DATABASE 数据库名 
    [[DEFAULT] CHARACTER SET 字符集名称] 
    [[DEFAULT] COLLATE 比较规则名称];

3. 表级别

CREATE TABLE 表名 (列的信息) 
    [[DEFAULT] CHARACTER SET 字符集名称]
    [COLLATE 比较规则名称]]
ALTER TABLE 表名 
    [[DEFAULT] CHARACTER SET 字符集名称] 
    [COLLATE 比较规则名称]

如果创建和修改表的语句中没有指明字符集和比较规则,将使用该表所在数据库的字符集和比较规则作 为该表的字符集和比较规则。

4. 列级别

同一个表中的不同的列也可以有不同的字符集和比较规则

CREATE TABLE 表名(
    列名 字符串类型 [CHARACTER SET 字符集名称] [COLLATE 比较规则名称], 
    其他列... 
);
ALTER TABLE 表名 MODIFY 列名 字符串类型 [CHARACTER SET 字符集名称] [COLLATE 比较规则名称];

对于某个列来说,如果在创建和修改的语句中没有指明字符集和比较规则,将使用该列所在表的字符集 和比较规则作为该列的字符集和比较规则。

4.3 请求到响应过程中字符集的变化

  1. 前提

假设我们客户端发送的请求是下边这个字符串:

SELECT * FROM t WHERE s = '我';

character_set_client表t的列scharacter_set_results 采用 utf8mb4;
character_set_connection = gbk;

  1. 客户端发送请求所使用字符集
    一般情况下客户端所使用的字符集和当前操作系统一致
    当客户端使用的是 utf8 字符集,字符 '我' 在发送给服务器的请求中的字节形式就是: 0xE68891

  2. 服务器接收到客户端发送来的请求其实是一串二进制的字节,它会认为这串字节采用的字符集是 character_set_client ,然后把这串字节转换为 character_set_connection 字符集编码的字符。
    首先会按照 utf8 字符集对字节串 0xE68891 进行解码,得到的字符串就是 '我' ,然后按照character_set_connection 代表的字符集,也就是 gbk 进行编码,得到的结果就是字节串 0xCED2

  3. 因为表 t 的列 s 采用的是 utf8 字符集,字节串又解码后通过 utf8 编码为 0xE68891

  4. 上一步骤是一个字节串 0xE68891 , 而character_set_results 代表的字符集也是 utf8 直接发送给客户端。

  5. 由于客户端使用的字符集是 utf8 ,所以可以顺利的将 0xE68891 解释成字符 我,从而显示到我们的显示器上,所以我们人类也读懂了返回的结果。

image.png

5. SQL 大小写规范

5.1 Windows和Linux平台区别

windows系统默认大小写不敏感 ,但是 linux系统是大小写敏感的

SHOW VARIABLES LIKE '%lower_case_table_names%'

image.png

  • lower_case_table_names 参数:
    • 默认是0,大小写敏感
    • 设置1,大小写不敏感。创建的表,数据库都是以小写形式存放在磁盘上,对于sql语句都是转 换为小写对表和数据库进行查找。
    • 设置2,创建的表和数据库依据语句上格式存放,凡是查找都是转换为小写进行。
  • 两个平台上SQL大小写的区别具体来说:

MySQL在Linux下数据库名、表名、列名、别名大小写规则是这样的:
1、数据库名、表名、表的别名、变量名是严格区分大小写的;
2、关键字、函数名称在 SQL 中不区分大小写;
3、列名(或字段名)与列的别名(或字段别名)在所有的情况下均是忽略大小写的;

MySQL在Windows的环境下全部不区分大小写

5.2 大小写规则设置

当想设置为大小写不敏感时,要在 my.cnf 这个配置文件 [mysqld] 中加入 lower_case_table_names=1 ,然后重启服务器。

  • 但是要在重启数据库实例之前就需要将原来的数据库和表转换为小写,否则将找不到数据库名。
  • 此参数适用于MySQL5.7。在MySQL 8下禁止在重新启动 MySQL 服务时将 lower_case_table_names 设置成不同于初始化 MySQL 服务时设置的 lower_case_table_names 值。如果非要将MySQL8设置为大小写不敏感,具体步骤为:
1、停止MySQL服务 
2、删除数据目录,即删除 /var/lib/mysql 目录
3、在MySQL配置文件( /etc/my.cnf )中添加 lower_case_table_names=1
4、启动MySQL服务

6. sql_mode的合理设置

6.1 宽松模式 vs 严格模式

宽松模式:

如果设置的是宽松模式,那么我们在插入数据的时候,即便是给了一个错误的数据,也可能会被接受, 并且不报错。

举例 :表中有一个字段name char(10) ,插入name的一条数据的 长度超过10 ,'1234567890abc',取前10个字符存上,并没有报错,mysql自行处理并接受了,这就是宽松模式的效果。

应用场景 :通过设置 sql mode 为宽松模式,来保证大多数sql符合标准的sql语法,这样应用在不同数据 库之间进行 迁移 时,则不需要对业务sql 进行较大的修改。

严格模式:

出现上面宽松模式的错误,应该报错才对,所以MySQL5.7版本就将sql_mode默认值改为了严格模式。

在生产等环境中,必须采用的是严格模式。

开发经验 :MySQL等数据库总想把关于数据的所有操作都自己包揽下来,包括数据的校验,但我们应该在自己 开发的项目程序级别将这些校验给做了 ,这样做之后,在进行迁移时会方便很多。

6.2 宽松模式再举例

MySQL的sql_mode模式说明及设置

6.3 模式查看和设置

  • 查看当前的sql_mode
select @@session.sql_mode  #全局
select @@global.sql_mode #当前会话
  • 临时设置方式:设置当前窗口中设置sql_mode
SET GLOBAL sql_mode = 'modes...';
SET SESSION sql_mode = 'modes...'; 

  • 永久设置方式:在/etc/my.cnf中配置sql_mode

在my.cnf文件(windows系统是my.ini文件),新增:

[mysqld] sql_mode=ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR _DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION

然后 重启MySQL 。

当然生产环境上是禁止重启MySQL服务的,所以采用 临时设置方式 + 永久设置方式 来解决线上的问题, 那么即便是有一天真的重启了MySQL服务,也会永久生效了。