MySQL服务两项,MySQL 的启动选项和系统变量实例详解

本文实例讲述了mysql 的启动选项和系统变量。分享给大家供大家参考,具体如下:

mysql的配置信息可以通过两种方式实现,一种是命令行形式,在启动mysql服务时后边带上相关配置参数,此种方式会在mysql重启后失效。另外一种是通过写入配置文件,如my.cnf,启动或者重启mysql服务都会生效,此种方式是永久生效。

启动选项

命令行

在mysql服务命令启动时,带上配置参数

参数的长形式和短形式

配置参数有长形式和短形式之分,有些作用是一样的,只是写法不同而已

配置文件

配置文件my.cnf的位置,有可能是以下的几种,如mysql服务启动时未指定配置文件时,会从以下地方查找读取并初始化。

注意

1. 在配置文件中指定的启动选项不允许加--前缀,并且每行只指定一个选项,而且=周围可以有空白字符

2. 如果我们在多个配置文件中设置了相同的启动选项,那以最后一个配置文件中的为准

3. 如果同一个启动选项既出现在命令行中,又出现在配置文件中,那么以命令行中的启动选项为准

4. mysqld --defaults-file=/tmp/myconfig.txt

//在程序启动的时候将只在/tmp/myconfig.txt路径下搜索配置文件。如果文件不存在或无法访问,则会发生错误

配置组

配置文件一共可以以下这些组别:mysqld、mysqld_safe、mysql.server、mysql、mysqladmin、mysqldump,可以针对不同组别进行配置

212G34310-0.png

内容格式

注意

1. [server]组下边的启动选项将作用于所有的服务器程序,如mysqld、mysqld_safe、mysql.server

2. [client]组下边的启动选项将作用于所有的客户端程序,如mysql、mysqladmin、mysqldump

3. 同一个配置文件中多个组的优先级,将以最后一个出现的组中的启动选项为准

系统变量

mysql服务器程序运行过程中会用到许多影响程序行为的变量,它们被称为mysql系统变量。

例如:

1. 允许同时连入的客户端数量用系统变量max_connections表示

2. 表的默认存储引擎用系统变量default_storage_engine表示

3. 查询缓存的大小用系统变量query_cache_size表示

......

查看

212G323R-1.png

设置

通过启动项设置

命令行设置

配置文件设置

注意:

对于启动选项来说,如果启动选项名由多个单词组成,各个单词之间用短划线-或者下划线_连接起来都可以,但是它对应的系统变量的单词之间必须使用下划线_连接起来(即通过show查看或set设置时)

服务器程序运行过程中设置

系统变量比较牛逼的一点就是,对于大部分系统变量来说,它们的值可以在服务器程序运行过程中进行动态修改而无需停止并重启服务器

不过系统变量有全局和当前会话作用域之分

作用域

global

session

查看

注意:

如果某个客户端改变了某个系统变量在global作用范围的值,并不会影响该系统变量在当前已经连接的客户端作用范围为session的值,只会影响后续连入的客户端在作用范围为session的值。

补充说明

并不是所有系统变量都具有global和session的作用范围

* 有一些系统变量只具有global作用范围,比方说max_connections,表示服务器程序支持同时最多有多少个客户端程序进行连接

* 有一些系统变量只具有session作用范围,比如insert_id,表示在对某个包含auto_increment列的表进行插入时,该列初始的值

* 有一些系统变量的值既具有global作用范围,也具有session作用范围,比如我们前边用到的default_storage_engine,而且其实大部分的系统变量都是这样的

有些系统变量是只读的,并不能设置值

比方说version,表示当前mysql的版本,我们客户端是不能设置它的值的,只能在show variables语句里查看。

启动选项与系统变量的关系

启动选项是在程序启动时我们程序员传递的一些参数,而系统变量是影响服务器程序运行行为的变量

* 大部分的系统变量都可以被当作启动选项传入

* 有些系统变量是在程序运行过程中自动生成的,是不可以当作启动选项来设置,比如auto_increment_offset、character_set_client啥的

* 有些启动选项也不是系统变量,比如defaults-file

状态变量

为了让我们更好的了解服务器程序的运行情况,mysql服务器程序中维护了好多关于程序运行状态的变量,它们被称为状态变量。

比方说threads_connected表示当前有多少客户端与服务器建立了连接,handler_update表示已经更新了多少行记录

由于状态变量是用来显示服务器程序运行状况的,所以它们的值只能由服务器程序自己来设置,我们程序员是不能设置的

查看

212G3A52-2.png

希望本文所述对大家MySQL数据库计有所帮助。

原文链接:https://segmentfault.com/a/1190000021608494

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值