启动选项和系统变量

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 启动选项和系统变量

1:启动选 和 配置文件(startup option)

(1)在命令行上使用选项
  1. 禁止客户端使用 TCP/IP 网络进行连接。(-_:含义相同)

【 mysqld --skip-networking 】

【 mysqld --skip_networking 】

  1. 修改表的默认存储引擎。

== 启动时,设定默认的存储引擎。

【 /usr/sbin/mysqld --default-storage-engine=MyISAM 】


== 查看MySQL 默认的存储引擎。

【 show variables like 'default_storage_engine'; 】

+------------------------+--------+

| Variable_name          | Value  |

+------------------------+--------+

| default_storage_engine | InnoDB |

+------------------------+--------+

  1. MySQL 启动选项帮助

【 mysql --help 】

【 mysqld --verbose --help 】

【 mysqld_safe --help 】

(2)在配置文件中 使用选项
  1. 配置文件路径:(后加载的设定,会覆盖先加载的设定,以最后一个出现的配置为准)

/etc/my.cnf

/etc/mysql/my.cnf

/usr/etc/my.cnf

~/.my.cnf

  1. 配置文件的内容:

# http://dev.mysql.com/doc/refman/5.7/en/server-configuration-defaults.html


[mysqld_safe]  == 用于服务端程序

[mysqld.server]  == 用于服务端程序


[mysqld] == 作用于所有的服务器程序


[server] == 作用于所有的服务器程序


default-storage-engine=MyISAM

datadir=/var/lib/mysql

socket=/var/lib/mysql/mysql.sock


symbolic-links=0


log-error=/var/log/mysqld.log

pid-file=/var/run/mysqld/mysqld.pid


[client] == 作用于所有的客户端程序


[mysql]  == 用于客户端程序

[mysqladmin]  == 用于客户端程序

[mysqldump]  == 用于客户端程序

2:系统变量

  1. 查询系统变量:show variables like '%??%';

【 show variables like 'default_storage_engine'; 】

+------------------------+--------+

| Variable_name          | Value  |

+------------------------+--------+

| default_storage_engine | InnoDB |

+------------------------+--------+

【 show variables like 'max_connections'; 】

+-----------------+-------+

| Variable_name   | Value |

+-----------------+-------+

| max_connections | 151   | --(另外:+1个为超级用户准备的连接)

+-----------------+-------+

  1. 设置系统变量:

【 vim /etc/my.cnf 】


[server]

default-storage-engine=MyISAM

max-connections=10

-- (1)全局范围:

【 set global default_storage_engine=MyISAM; 】

【 set @@GLOBAL.default_storage_engine=MyISAM; 】


--(2)会话范围:

【 set default_storage_engine=MyISAM; 】

【 set session default_storage_engine=MyISAM; 】

【 set @@session.default_storage_engine=MyISAM; 】

-- (作用范围不同) 查询不同级别

【 show variables like 'default_storage_engine'; 】

【 show session variables like 'default_storage_engine'; 】

【 show global variables like 'default_storage_engine'; 】

3:状态变量

  1. 状态变量:是用来显示服务器运行状态的
  2. 与系统变量类似,状态变量也有 session 和 global 两个作用范围

-- 查询局部 状态变量

+-------------------+-------+

| Variable_name     | Value |

+-------------------+-------+

| Threads_cached    | 0     |

| Threads_connected | 4     | -- 当前有多少客户端与服务端建立了连接

| Threads_created   | 4     |

| Threads_running   | 1     |

+-------------------+-------+

-- 表示:更新了多少条,以 InnoDB 为存储引擎的表中的记录

+---------------------+-------+

| Variable_name       | Value |

+---------------------+-------+

| Innodb_rows_updated | 2     |

+---------------------+-------+



4:存储引擎

(1)各个存储引擎的官方介绍

+--------+---------+------------------------------------------------------------+-------------+----+------------+

| Engine | Support | Comment                                                    | Transactions| XA | Savepoints |

+--------+---------+------------------------------------------------------------+-------------+----+------------+

| InnoDB | DEFAULT | Supports transactions, row-level locking, and foreign keys | YES         | YES| YES        |

| MEMORY | YES     | Hash based, stored in memory, useful for temporary tables  | NO          | NO | NO         |

| MyISAM | YES     | MyISAM storage engine                                      | NO          | NO | NO         |

+--------+---------+------------------------------------------------------------+-------------+----+------------+

11 rows in set (0.00 sec)

(2)InnoDB表的优势
  1. InnoDB存储引擎在实际应用中拥有诸多优势,比如操作便利、提高了数据库的性能、维护成本低等。如果由于硬件或软件的原因导致服务器崩溃,那么在重启服务器之后不需要进行额外的操作。InnoDB崩溃恢复功能自动将之前提交的内容定型,然后撤销没有提交的进程,重启之后继续从崩溃点开始执行。
  2. InnoDB存储引擎在主内存中维护缓冲池,高频率使用的数据将在内存中直接被处理。这种缓存方式应用于多种信息,加速了处理进程。
  3. 在专用服务器上,物理内存中高达80%的部分被应用于缓冲池。如果需要将数据插入不同的表中,可以设置外键加强数据的完整性。更新或者删除数据,关联数据将会被自动更新或删除。如果试图将数据插入从表,但在主表中没有对应的数据,插入的数据将被自动移除。如果磁盘或内存中的数据出现崩溃,在使用脏数据之前,校验和机制会发出警告。当每个表的主键都设置合理时,与这些列有关的操作会被自动优化。插入、更新和删除操作通过做改变缓冲自动机制进行优化。 InnoDB不仅支持当前读写,也会缓冲改变的数据到数据流磁盘
  4. InnoDB的性能优势不只存在于长时运行查询的大型表。在同一列多次被查询时,自适应哈希索引会提高查询的速度。使用InnoDB可以压缩表和相关的索引,可以 在不影响性能和可用性的情况下创建或删除索引 。对于大型文本和BLOB数据,使用动态行形式,这种存储布局更高效。通过查询INFORMATION_SCHEMA库中的表可以监控存储引擎的内部工作。在同一个语句中,InnoDB表可以与其他存储引擎表混用。即使有些操作系统限制文件大小为2GB,InnoDB仍然可以处理。 当处理大数据量时,InnoDB兼顾CPU,以达到最大性能
(3)InnoDB和ACID模型

ACID模型是一系列数据库设计规则,这些规则着重强调可靠性,而可靠性对于商业数据和任务关键型应用非常重要。MySQL包含类似InnoDB存储引擎的组件,与ACID模型紧密相连,这样出现意外时,数据不会崩溃,结果不会失真。如果依赖ACID模型,可以不使用一致性检查和崩溃恢复机制。如果拥有额外的软件保护,极可靠的硬件或者应用可以容忍一小部分的数据丢失和不一致,可以将MySQL设置调整为只依赖部分ACID特性,以达到更高的性能。下面讲解InnoDB存储引擎与ACID模型相同作用的四个方面。

  1. 原子方面:ACID的原子方面主要涉及InnoDB事务,与MySQL相关的特性主要包括:
  • 自动提交设置。
  • COMMIT语句。
  • ROLLBACK语句。
  • 操作INFORMATION_SCHEMA库中的表数据。
  1. 一致性方面:ACID模型的一致性主要涉及保护数据不崩溃的内部InnoDB处理过程,与MySQL相关的特性主要包括:
  • InnoDB双写缓存。
  • InnoDB崩溃恢复。
  1. 隔离方面:隔离是应用于事务的级别,与MySQL相关的特性主要包括:
  • 自动提交设置。
  • SET ISOLATION LEVEL语句。
  • InnoDB锁的低级别信息。
  1. 耐久性方面:ACID模型的耐久性主要涉及与硬件配置相互影响的MySQL软件特性。由于硬件复杂多样化,耐久性方面没有具体的规则可循。与MySQL相关的特性有:
  • InnoDB双写缓存,通过innodb_doublewrite配置项配置。
  • 配置项innodb_flush_log_at_trx_commit。
  • 配置项sync_binlog。
  • 配置项innodb_file_per_table。
  • 存储设备的写入缓存。
  • 存储设备的备用电池缓存。
  • 运行MySQL的操作系统。
  • 持续的电力供应。
  • 备份策略。
  • 对分布式或托管的应用,最主要的在于硬件设备的地点以及网络情况。
(4)InnoDB架构
  1. 缓冲池:缓冲池是主内存中的一部分空间,用来缓存已使用的表和索引数据。缓冲池使得经常被使用的数据能够直接在内存中获得,从而提高速度。
  2. 更改缓存:更改缓存是一个特殊的数据结构,当受影响的索引页不在缓存中时,更改缓存会缓存辅助索引页的更改。索引页被其他读取操作时会加载到缓存池,缓存的更改内容就会被合并。不同于集群索引,辅助索引并非独一无二的。当系统大部分闲置时,清除操作会定期运行,将更新的索引页刷入磁盘。更新缓存合并期间,可能会大大降低查询的性能。在内存中,更新缓存占用一部分InnoDB缓冲池。在磁盘中,更新缓存是系统表空间的一部分。更新缓存的数据类型由innodb_change_buffering配置项管理。
  3. 自适应哈希索引:自适应哈希索引将负载和足够的内存结合起来,使得InnoDB像内存数据库一样运行,不需要降低事务上的性能或可靠性。这个特性通过innodb_adaptive_hash_index选项配置,或者通过--skip-innodb_adaptive_hash_index命令行在服务启动时关闭。
  4. 重做日志缓存:重做日志缓存存放要放入重做日志的数据。重做日志缓存大小通过innodb_log_buffer_size配置项配置。重做日志缓存会定期地将日志文件刷入磁盘。大型的重做日志缓存使得大型事务能够正常运行而不需要写入磁盘。
  5. 系统表空间:系统表空间包括InnoDB数据字典、双写缓存、更新缓存和撤销日志,同时也包括表和索引数据。多表共享,系统表空间被视为共享表空间。
  6. 双写缓存:双写缓存位于系统表空间中,用于写入从缓存池刷新的数据页。只有在刷新并写入双写缓存后,InnoDB才会将数据页写入合适的位置。
  7. 撤销日志:撤销日志是一系列与事务相关的撤销记录的集合,包含如何撤销事务最近的更改。如果其他事务要查询原始数据,可以从撤销日志记录中追溯未更改的数据。撤销日志存在于撤销日志片段中,这些片段包含于回滚片段中。
  8. 每个表一个文件的表空间:每个表一个文件的表空间是指每个单独的表空间创建在自身的数据文件中,而不是系统表空间中。这个功能通过innodb_file_per_table配置项开启。每个表空间由一个单独的.ibd数据文件代表,该文件默认被创建在数据库目录中。
  9. 通用表空间:使用CREATE TABLESPACE语法创建共享的InnoDB表空间。通用表空间可以创建在MySQL数据目录之外能够管理多个表并支持所有行格式的表。
  10. 撤销表空间:撤销表空间由一个或多个包含撤销日志的文件组成。撤销表空间的数量由innodb_undo_tablespaces配置项配置。
  11. 临时表空间:用户创建的临时表空间和基于磁盘的内部临时表都创建于临时表空间。innodb_temp_data_file_path配置项定义了相关的路径、名称、大小和属性。如果该值为空,默认会在innodb_data_home_dir变量指定的目录下创建一个自动扩展的数据文件。
  12. 重做日志:重做日志是基于磁盘的数据结构,在崩溃恢复期间使用,用来纠正数据。正常操作期间,重做日志会将请求数据进行编码,这些请求会改变InnoDB表数据。遇到意外崩溃后,未完成的更改会自动在初始化期间重新进行。
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
存储 网络协议 关系型数据库
第2章 MySQL的调控按钮-启动选项和系统变量
第2章 MySQL的调控按钮-启动选项和系统变量
59 0
|
6月前
|
存储 Shell Linux
【Shell 命令集合 系统设置 】⭐ Linux 取消或删除已设置的环境变量 unset命令 使用指南
【Shell 命令集合 系统设置 】⭐ Linux 取消或删除已设置的环境变量 unset命令 使用指南
220 0
|
3月前
|
Shell Linux 数据库
bat cmd 无效参数/选项 - deleting
bat cmd 无效参数/选项 - deleting
18 0
|
3月前
|
SQL 关系型数据库 MySQL
proxysql修改默认系统配置
proxysql修改默认系统配置
|
6月前
|
存储
201403-3 命令行选项
201403-3 命令行选项
|
6月前
|
安全 Windows
Windows 10 用户变量、系统变量等环境变量新建、编辑修改与删除方法
Windows 10 用户变量、系统变量等环境变量新建、编辑修改与删除方法
262 2
|
Python
如何优雅地解析命令行选项(上)
随着我们编程经验的增长,对命令行的熟悉程度日渐加深,想来很多人会渐渐地体会到使用命令行带来的高效率。 自然而然地,我们自己写的很多程序(或者干脆就是脚本),也希望能够像原生命令和其他程序一样,通过运行时输入的参数就可以设定、改变程序的行为;而不必一层层找到相应的配置文件,然后还要定位到相应内容、修改、保存、退出……
157 0
|
Python
如何优雅地解析命令行选项(下)
随着我们编程经验的增长,对命令行的熟悉程度日渐加深,想来很多人会渐渐地体会到使用命令行带来的高效率。 自然而然地,我们自己写的很多程序(或者干脆就是脚本),也希望能够像原生命令和其他程序一样,通过运行时输入的参数就可以设定、改变程序的行为;而不必一层层找到相应的配置文件,然后还要定位到相应内容、修改、保存、退出……
273 0
|
存储 缓存 关系型数据库
MySQL 的启动选项和系统变量
MySQL的配置信息可以通过两种方式实现,一种是命令行形式,在启动MySQL服务时后边带上相关配置参数,此种方式会在MySQL重启后失效。另外一种是通过写入配置文件,如my.cnf,启动或者重启MySQL服务都会生效,此种方式是永久生效。
1451 0
MySQL 的启动选项和系统变量