MySQL 中的服务器配置和状态详解(MySQL Server Configuration and Status)

本文主要是介绍MySQL 中的服务器配置和状态详解(MySQL Server Configuration and Status),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《MySQL中的服务器配置和状态详解(MySQLServerConfigurationandStatus)》MySQL服务器配置和状态设置包括服务器选项、系统变量和状态变量三个方面,可以通过...

MySQL 之服务器配置和状态

1 MySQL 架构和性能优化

1.1 服务器配置和状态

设置 MySQL 服务的特性,可以通过 mysqld 服务选项,服务器系统变量和服务器状态变量这三个方面来进行设置和查看。

官方文档

https://dev.mysql.com/doc/refman/8.0/en/server-option-variable-reference.html
https://dev.mysql.com/doc/refman/5.7/en/server-option-variable-reference.html
https://mariadb.com/kb/en/variables-and-modes/ 

MySQL 中的服务器配置和状态详解(MySQL Server Configuration and Status)

文档说明

Name 

Cmd-Line 

OptionFile

SystemVar

StatusVar

VarScope

Dynamic

名称 

是否能在命令行下设置

是否能写配置文件

是否是系统变量

是否是状态变量

作用范围

是否能动态修改

Cmd-Line 和 Opton File 列的值如果是 Yes,则表示该项是服务器选项

System Var 列的值如果是 Yes,则表示该项是系统变量

Status Var 列的值如果是 Yes,则表示该项是状态变量

Option File 指配置文件

服务器选项通常在命令行后面添加或在配置文件中设置

状态变量表示的是当前的一个状态值

变量生效范围有三种,分别是全局,会话,全局和会话,Var Scope 列对应的值分别是 Global,Session,Both

Dynamic 列表示是否可以动态修改,如果该列值为 No,则表示不可修改,状态变量都不可修改,部分系统变量也不可修改

一个配置项可以同时是服务器选项,系统变量,状态变量这三种中的两种,但不会同时是三种角色

1.1.1 服务器选项

查看所有可用选项列表

[root@localhost ~]# mysqld --verbose --help

查看服务启动时在命令行下添加的选项

[root@localhost ~]# ps aux | grep mysqld
mysql 2423 0.6 23.7 1836108 433416 ? Ssl 13:01 3:27 /usr/libexec/mysqld --basedir=/usr
#这个选项是配置在服务脚本中的
[root@localhost ~]# systemctl cat mysqld.service | grep basedir
# Note: we set --basedir to prevent probes that might trigger SElinux alarms,
ExecStart=/usr/libexec/mysqld --basedir=/usr

查看当前服务启动选项

[root@localhost ~]# mysqld --print-defaults
/usr/libexec/mysqld would have been started with the following arguments:
--default_authentication_plugin=mysql_native_password --datadir=/var/lib/mysql 
--socket=/var/lib/mysql/mysql.sock --log-error=/var/log/mysql/mysqld.log --pid-file=/run/mysqld/mysqld.pid
#这些选项都是写在配置文件中的
[root@localhost ~]# cat /etc/my.cnf.d/mysql-serverjs.cnf
......
[mysqld]
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
log-error=/var/log/mysql/mysqld.log
pid-file=/run/mysqld/mysqld.pid
[root@localhost ~]# cat /etc/my.cnf.d/mysql-default-authentication-plugin.cnf
......
[mysqld]
default_authentication_plugin=mysql_native_password

在命令行中设置服务器选项

[root@localhost ~]# /usr/libexec/mysqld --basedir=/usr --max_connections=202 --user=mysql &
[1] 9358
#查看
mysql> show variables like 'max_connections%';
+-----------------+-------+
| Variable_name   | Value |
+-----------------+-------+
| max_connections | 202   |
+-----------------+-------+
1 row in set (0.01 sec)

在配置文件中设置服务器选项

[root@localhost ~]# vim /etc/my.cnf
[mysqld]
max_connections=200
#查看,此时配置在在配置文件中可见,但并没有生效,需要重启
[root@localhost ~]# mysqld --print-defaults
/usr/libexec/mysqld would have been started with the following arguments:
--default_authentication_plugin=mysql_native_password --datadir=/var/lib/mysql 
--socket=/var/lib/mysql/mysql.sock --log-error=/var/log/mysql/mysqld.log --pid-file=/run/mysqld/mysqld.pid --max_connections=200
#查看选项,因为此项与变量同名
mysql> show variables like 'max_connections%';
+-----------------+-------+
| Variable_name   | Value |
+-----------------+-------+
| max_connections | 151   |
+-----------------+-------+
1 row in set (0.00 sec)
#重启服务
[root@localhost ~]# systemctl restart mysqld.service
#再次查看
mysql> show variables like 'max_connections%';
+-----------------+-------+
| Variable_name   | Value |
+-----------------+-------+
| max_connections | 200   |
+-----------------+-------+
1 row in set (0.00 sec)​​​​​​​​​​​​​
#配置文件中的服务器选项,可以写下划线,也可以写中划线
[root@localhost ~]# vim /etc/my.cnf
[mysqld]
#max_connections=200
max-connections=201
#重启服务
[root@localhost ~]# systemctl restart mysqld.service
#查看
mysql> show variables like 'max_connections%';
+-----------------+-------+
| Variable_name   | Value |
+-----------------+-------+
| max_connections | 201   |
+-----------------+-------+
1 row in set (0.00 sec)

非服务器选项不能加配置文件​​​​​​​

[root@localhost ~]# vim /etc/my.cnf
[mysqld]
#max_connections=200
max-connections=201
character_set_database=utf8
#无法启动服务,因为 character_set_database 不是服务器选项
[root@localhost ~]# systemctl restart mysqld.service
Job for mysqld.service failed because the control process exited with error code.
See "systemctl status mysqld.service" and "journalctl -xe" for details.
#查看具体错误信息
[root@localhost ~]# tail /var/log/mysql/mysqld.log

1.1.2 服务器系统变量

服务器系统变量分为全局变量和会话变量两种,全局变量表示可以影响到所有连接终端,所有会话,会话变量只影响当前会话。

查看系统变量​​​​​​​

#查看所有全局变量
mysql> show global variables 630
#查看所有变量,包括session和global
mysql> show session variables
mysql> show variables
#查看指定变量 SHOW VARIABLES LIKE 'VAR_NAME';
mysql> show variables like 'sql_log_bin';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| sql_log_bin   | ON    |
+---------------+-------+
1 row in set (0.00 sec)
mysql> show variables like 'sql_log_%';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| sql_log_bin   | ON    |
| sql_log_off   | OFF   |
+---------------+-------+
2 rows in set (0.00 sec)
#查看指定变量 SELECT @@VAR_NAME;
mysql> select @@sql_log_bin;
+---------------+
| @@sql_log_bin |
+---------------+
| 1             |
+---------------+
1 row in set (0.00 sec)

修改服务器系统变量

查看帮助

mysql> help set

修改变量时,on|true|1 代表开启,off|false|0 代表关闭。

修改全局变量:修改后全局生效,如果仅是变量,则对于己建立的连接不生效。​​​​​​​

SET GLOBAL system_var_name=value;
SET @@global.system_var_name=value;

仅是变量​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​

#终端
mysql> show variables like 'sql_warnings';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| sql_warnings  | OFF   |
+---------------+-------+
1 row in set (0.00 sec)
#终端B
mysql> select @@sql_warnings;
+----------------+
| @@sql_warnings |
+----------------+
| 0              |
+----------------+
1 row in set (0.00 sec)
#终端A中修改
mysql> set global sql_warnings=1;
Query OK, 0 rows affected (0.00 sec)
#终端A中查看
mysql> show variables like 'sql_warnings';
+---------------+-------+
| Variable_npythoname | Value |
+---------------+-------+
| sql_warnings  | OFF   |
+---------------+-------+
1 row in set (0.01 sec)
#终端B中查看
mysql> select @@sql_warnings;
+----------------+
| @@sql_warnings |
+----------------+
| 0              |
+----------------+
1 row in set (0.00 sec)
#重新建立连接再查看
mysql> select @@sql_warnings;
+----------------+
| @@sql_warnings |
+----------------+
| 1              |
+----------------+
1 row in set (0.00 sec)

又是变量又是选项​​​​​​​

#终端A
mysql> show variables like 'mysqlx_max_connections';
+------------------------+-------+
| Variable_name          | Value |
+------------------------+-------+php
| mysqlx_max_connections | 100   |
+------------------------+-------+
1 row in set (0.01 sec)
#终端B
mysql> show variables like 'mysqlx_max_connections';
+------------------------+-------+
| Variable_name          | Value |
+------------------------+-------+
| mysqlx_max_connections | 100   |
+------------------------+-------+
1 row in set (0.01 sec)
#在终端A中修改
mysql> set mysqlx_max_connections=108;
ERROR 1229 (HY000): Variable 'mysqlx_max_connections' is a GLOBAL variable and should be set with SET GLOBAL
mysql> set global mysqlx_max_connections=108;
Query OK, 0 rows affected (0.00 sec)
#终端A再次查看
mysql> show variables like 'mysqlx_max_connections';
+------------------------+-------+
| Variable_name          | Value |
+------------------------+-------+
| mysqlx_max_connections | 108   |
+------------------------+-------+
1 row in set (0.00 sec)
#终端B再次查看
mysql> show variables like 'mysqlx_max_connections';
+------------------------+-------+
| Variable_name          | Value |
+------------------------+-------+
| mysqlx_max_connections | 108   |
+------------------------+-------+
1 row in set (0.00 sec)

修改会话变量:仅对当前会话有影响​​​​​​​

SET [SESSION] system_var_name=value;
SET @@[session.]system_var_name=value;
​​​​​​
#终端A
mysql> show variables like 'sql_log_bin';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| sql_log_bin   | ON    |
+---------------+-------+
1 row in set (0.00 sec)
#终端B
mysql> show variables like 'sql_log_bin';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| sql_log_bin   | ON    |
+---------------+-------+
1 row in set (0.00 sec)
#在终端A中修改
mysql> set sql_log_bin=0;
Query OK, 0 rows affected (0.00 sec)
mysql> show variables like 'sql_log_bin';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| sql_log_bin   | OFF   |
+---------------+-------+
1 row in set (0.01 sec)
#再次在终端B中查看,并不受影响
mysql> show variables like 'sql_log_bin';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| sql_log_bin   | ON    |
+---------------+-------+
1 row in set (0.00 sec)
#重新连接,也不受影响

只读变量无法修改​​​​​​​

#该项的 Dynamic 列值为 No,不能动态修改
mysql> show variables like 'admin_port';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| admin_port    | 33062 |
+---------------+-------+
1 row in set (0.00 sec)
mysql> set global admin_port=33063;
ERROR 1238 (HY000): Variable 'admin_port' is a read only variable

变量无法实现永久保存,重启服务后会被重置​​​​​​​

mysql> show variables like 'mysqlx_max_connections';
+------------------------+-------+
| Variable_name          | Value |
+------------------------+-------+
| mysqlx_max_connections | 108   |
+------------------------+-------+
1 row in set (0.00 sec)
#重启服务
[root@localhost ~]# systemctl restart mysqld.service
#再次查看
mysql> show variables like 'mysqlx_max_connections';
+------------------------+-------+
| Variable_name          | Value |
+------------------------+-------+
| mysqlx_max_connections | 100   |
+------------------------+-------+
1 row in set (0.00 sec)

1.1.3 服务器状态变量

服务器状态变量:分全局和会话两种,其中许多变量有双重域,既是全局变量,也是会话变量,有相同的名字。

状态变量用于保存 MySQL 运行中的统计数据的变量,只读,不可修改。

查看状态变量​​​​​​​

#查看所有全局状态变量
mysql> show global status;
#查看所有状态变量,包括global和session
mysql> show status;
mysql> show session status;

查看指定变量​​​​​​​​​​​​​​

mysql> show status like 'Com_select';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| Com_select    | 2     |
+---------------+-------+
1 row in set (0.00 sec)
mysql> select * from testdb.t1;
Empty set (0.00 sec)
#查询次数增加
mysql> show status like 'Com_select';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| Com_select    | 3     |
+---------------+-------+
1 row in set (0.00 sec)
#查看全局
mysql> show global status like 'Com_select';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| Com_select    | 8     |
+---------------+-------+
1 row in set (0.00 sec)
#查看服务运行时长
mysql> show status like 'Uptime';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| Uptime     js   | 2503  |
+---------------+-------+
1 row in set (0.00 sec)
mysql> show global status like 'Uptime';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| Uptime        | 2507  |
+---------------+-------+
1 row in set (0.00 sec)

重启服务后状态被重置​​​​​​​

[root@localhost ~]# systemctl restart mysqld.service
mysql> show status like 'Com_select';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| Com_select    | 1     |
+---------------+-------+
1 row in set (0.00 sec)
mysql> show global status like 'Uptime';
+---------------+-------+
| Variable_name | Value |
+---------------+php-------+
| Uptime        | 4     |
+---------------+-------+
1 row in set (0.00 sec)

1.1.4 服务器变量 sql_mode

sql_mode 是服务器选项,也是变量,其值会影响 SQL 语句执行的工作模式。

官方文档​​​​​​​

https://mariadb.com/kb/en/library/sql-mode/
https://dev.mysql.com/doc/refman/5.7/en/server-options.html#option_mysqld_sqlmode
https://dev.mysql.com/doc/refman/8.0/en/server-options.html#option_mysqld_sqlmode

#查看
mysql> select @@sql_mode\G
*************************** 1. row ***************************
@@sql_mode:
ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
1 row in set (0.00 sec)
#修改,此处修改重启服务后会还原,如果需要永久生效,则可以写配置文件
mysql> set @@sql_mode='ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES';
Query OK, 0 rows affected, 1 warning (0.00 sec)
mysql> select @@sql_mode\G
*************************** 1. row ***************************
@@sql_mode: ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES
1 row in set (0.00 sec)

常见MODE

NO_AUTO_CREATE_USER:禁止 GRANT 创建密码为空的用户

NO_ZERO_DATE:在严格模式,不允许使用 '0000-00-00' 的时间

ONLY_FULL_GROUP_BY:对于 GROUP BY 聚合操作,如果在 SELECT 中的列,没有在 GROUP BY 中出现,那认为这个 SQL 是不合法的

NO_BACKSLASH_ESCAPES:反斜杠 "\" 作为普通字符而非转义字符

PIPES_AS_CONCAT:将 "||" 视为连接操作符而非 "或" 运算符

到此这篇关于MySQL 中的服务器配置和状态详解(MySQL Server Configuration and Status)的文章就介绍到这了,更多相关mysql服务器配置和状态内容请搜索China编程(www.chinasem.cn)以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程China编程(www.chinasem.cn)!

这篇关于MySQL 中的服务器配置和状态详解(MySQL Server Configuration and Status)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1153529

相关文章

MySQL数据库双机热备的配置方法详解

《MySQL数据库双机热备的配置方法详解》在企业级应用中,数据库的高可用性和数据的安全性是至关重要的,MySQL作为最流行的开源关系型数据库管理系统之一,提供了多种方式来实现高可用性,其中双机热备(M... 目录1. 环境准备1.1 安装mysql1.2 配置MySQL1.2.1 主服务器配置1.2.2 从

Linux kill正在执行的后台任务 kill进程组使用详解

《Linuxkill正在执行的后台任务kill进程组使用详解》文章介绍了两个脚本的功能和区别,以及执行这些脚本时遇到的进程管理问题,通过查看进程树、使用`kill`命令和`lsof`命令,分析了子... 目录零. 用到的命令一. 待执行的脚本二. 执行含子进程的脚本,并kill2.1 进程查看2.2 遇到的

MyBatis常用XML语法详解

《MyBatis常用XML语法详解》文章介绍了MyBatis常用XML语法,包括结果映射、查询语句、插入语句、更新语句、删除语句、动态SQL标签以及ehcache.xml文件的使用,感兴趣的朋友跟随小... 目录1、定义结果映射2、查询语句3、插入语句4、更新语句5、删除语句6、动态 SQL 标签7、ehc

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置

从基础到高级详解Go语言中错误处理的实践指南

《从基础到高级详解Go语言中错误处理的实践指南》Go语言采用了一种独特而明确的错误处理哲学,与其他主流编程语言形成鲜明对比,本文将为大家详细介绍Go语言中错误处理详细方法,希望对大家有所帮助... 目录1 Go 错误处理哲学与核心机制1.1 错误接口设计1.2 错误与异常的区别2 错误创建与检查2.1 基础

k8s按需创建PV和使用PVC详解

《k8s按需创建PV和使用PVC详解》Kubernetes中,PV和PVC用于管理持久存储,StorageClass实现动态PV分配,PVC声明存储需求并绑定PV,通过kubectl验证状态,注意回收... 目录1.按需创建 PV(使用 StorageClass)创建 StorageClass2.创建 PV

Python版本信息获取方法详解与实战

《Python版本信息获取方法详解与实战》在Python开发中,获取Python版本号是调试、兼容性检查和版本控制的重要基础操作,本文详细介绍了如何使用sys和platform模块获取Python的主... 目录1. python版本号获取基础2. 使用sys模块获取版本信息2.1 sys模块概述2.1.1

一文详解Python如何开发游戏

《一文详解Python如何开发游戏》Python是一种非常流行的编程语言,也可以用来开发游戏模组,:本文主要介绍Python如何开发游戏的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、python简介二、Python 开发 2D 游戏的优劣势优势缺点三、Python 开发 3D

Redis 基本数据类型和使用详解

《Redis基本数据类型和使用详解》String是Redis最基本的数据类型,一个键对应一个值,它的功能十分强大,可以存储字符串、整数、浮点数等多种数据格式,本文给大家介绍Redis基本数据类型和... 目录一、Redis 入门介绍二、Redis 的五大基本数据类型2.1 String 类型2.2 Hash

Linux云服务器手动配置DNS的方法步骤

《Linux云服务器手动配置DNS的方法步骤》在Linux云服务器上手动配置DNS(域名系统)是确保服务器能够正常解析域名的重要步骤,以下是详细的配置方法,包括系统文件的修改和常见问题的解决方案,需要... 目录1. 为什么需要手动配置 DNS?2. 手动配置 DNS 的方法方法 1:修改 /etc/res