mysql启动选项只读_MySQL的启动选项和系统变量该如何配置?
MySQL的配置信息可以通过两种方式实现,一种是命令行形式,在启动MySQL服务时后边带上相关配置参数,此种方式会在MySQL重启后失效。另外一种是通过写入配置文件,如my.cnf,启动或者重启MySQL服务都会生效,此种方式是永久生效。
启动选项
命令行
在MySQL服务命令启动时,带上配置参数
命令格式:启动命令 --启动选项1[=值1] --启动选项2[=值2] ... --启动选项n[=值n]
例如:mysqld --default-storage-engine=MyISAM //设置默认存储引擎
错误例子:mysqld --default-storage-engine = MyISAM //设置默认存储引擎原因:因为启动项和值之间的等号不能有空格
参数的长形式和短形式
配置参数有长形式和短形式之分,有些作用是一样的,只是写法不同而已
--host => -h //主机--port => -P // 端口--user => -u //用户--password => -p //密码--version => -V //版本......
例子:mysqld --port=3306mysqld -P3306mysqld -P 3306
注意:密码不能有空格mysqld -proot
配置文件
配置文件my.cnf的位置,有可能是以下的几种,如MySQL服务启动时未指定配置文件时,会从以下地方查找读取并初始化。
* /etc/my.cnf * /etc/mysql/my.cnf* defaults-extra-file //指定的额外配置文件路径* SYSCONFDIR/my.cnf //cmake编译安装情况* $MYSQL_HOME/my.cnf //设置环境变量,默认安装路径* ~/.my.cnf //用户特定选项,家目录* ~/.mylogin.cnf //用户特定的登录路径选项(仅限客户端),mysql_config_editor修改,不是纯文件
注意1. 在配置文件中指定的启动选项不允许加--前缀,并且每行只指定一个选项,而且=周围可以有空白字符2. 如果我们在多个配置文件中设置了相同的启动选项,那以最后一个配置文件中的为准3. 如果同一个启动选项既出现在命令行中,又出现在配置文件中,那么以命令行中的启动选项为准4. mysqld --defaults-file=/tmp/myconfig.txt //在程序启动的时候将只在/tmp/myconfig.txt路径下搜索配置文件。如果文件不存在或无法访问,则会发生错误
配置组
配置文件一共可以以下这些组别:mysqld、mysqld_safe、mysql.server、mysql、mysqladmin、mysqldump,可以针对不同组别进行配置
内容格式
[server](具体的启动选项...)[mysqld](具体的启动选项...)[mysqld_safe](具体的启动选项...)[client](具体的启动选项...)[mysql](具体的启动选项...)[mysqladmin](具体的启动选项...)
例子:[mysqld]pid-file = /var/run/mysqld/mysqld.pidsocket = /var/run/mysqld/mysqld.sockdatadir = /var/lib/mysqllog-error = /var/log/mysql/error.log# 优化配置wait_timeout=10back_log=600key_buffer_size = 2048Mread_buffer_size = 100Mmax_allowed_packet = 1000Mthread_stack = 192Kthread_cache_size = 4myisam-recover-options = BACKUPmax_connections = 4000max_user_connections = 0max_connect_errors = 65535open_files_limit = 10240......
注意1. [server]组下边的启动选项将作用于所有的服务器程序,如mysqld、mysqld_safe、mysql.server2. [client]组下边的启动选项将作用于所有的客户端程序,如mysql、mysqladmin、mysqldump3. 同一个配置文件中多个组的优先级,将以最后一个出现的组中的启动选项为准
系统变量
MySQL服务器程序运行过程中会用到许多影响程序行为的变量,它们被称为MySQL系统变量。
例如:1. 允许同时连入的客户端数量用系统变量max_connections表示2. 表的默认存储引擎用系统变量default_storage_engine表示3. 查询缓存的大小用系统变量query_cache_size表示......
查看
格式:SHOW VARIABLES [LIKE 匹配的模式];
例如:SHOW VARIABLES LIKE 'default_storage_engine';
设置
通过启动项设置
命令行设置
mysqld --default-storage-engine=MyISAM --max-connections=10
配置文件设置
[mysqld]default-storage-engine = MyISAMmax-connections = 10......
注意:对于启动选项来说,如果启动选项名由多个单词组成,各个单词之间用短划线-或者下划线_连接起来都可以,但是它对应的系统变量的单词之间必须使用下划线_连接起来(即通过show查看或set设置时)
服务器程序运行过程中设置
系统变量比较牛逼的一点就是,对于大部分系统变量来说,它们的值可以在服务器程序运行过程中进行动态修改而无需停止并重启服务器
不过系统变量有全局和当前会话作用域之分
作用域
GLOBAL:全局变量,影响服务器的整体操作。SESSION:会话变量,影响某个客户端连接的操作。(别名叫LOCAL)
格式:1\. SET [GLOBAL|SESSION] 系统变量名 = 值;2\. SET [@@(GLOBAL|SESSION).]var_name = XXX;
global
例如:1\. SET GLOBAL default_storage_engine = InnoDB;2\. SET @@GLOBAL.default_storage_engine = InnoDB;
session
例如:1\. SET SESSION default_storage_engine = InnoDB;2\. SET @@SESSION.default_storage_engine = InnoDB;3\. SET default_storage_engine = InnoDB;//默认 session
查看
格式:SHOW [GLOBAL|SESSION] VARIABLES [LIKE 匹配的模式];1\. SHOW SESSION VARIABLES LIKE 'default_storage_engine';2\. SHOW GLOBAL VARIABLES LIKE 'default_storage_engine';
注意:如果某个客户端改变了某个系统变量在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表示已经更新了多少行记录
由于状态变量是用来显示服务器程序运行状况的,所以它们的值只能由服务器程序自己来设置,我们程序员是不能设置的
查看
格式:SHOW [GLOBAL|SESSION] STATUS [LIKE 匹配的模式];例如:SHOW STATUS LIKE 'thread%';
mysql启动选项只读_MySQL的启动选项和系统变量该如何配置?相关推荐
- mysql打开无法控制_MySQL不能启动和停止 MySQL各种解决方法教程
MySQL不能启动和停止 MySQL各种解决方法教程 本文章总结了种MySQL无法启动.无法停止解决办法,包括在windows系统,linux系统中mysql不能启动与停止的解决办法,有需了解的朋友可 ...
- mysql创建服务失败_mysql服务启动失败
事情是这样的,我在linux系统下做mysql备份与还原实验.我先是进入mysql,创建一个数据库ds,然后在数据库建了一张innodb表stu,再往表里插入几条数据.因为是做实验只是在验证备份与还原 ...
- mysql mgr 读写分离_MySQL Group Replication mgr 单主 proxysql 读写分离配置过程
1.前期准备,mgr安装见上一篇文章 2.创建用户和导入脚本 GRANT ALL ON *.* TO 'rootuser'@'%' IDENTIFIED BY '123456'; /mgr/mysql ...
- mysql community server 安装_MySQL Community Server 8.0.11下载与安装配置
一.下载 1.选择合适的安装包,我在这里下载的是目前最新的安装包,8.0.11,而且我选择下载的是解压版的,安装版的话,安装会比较麻烦. 点击进入下载页面,滚动到归最下面,选择压缩版的进行下载. 2. ...
- mysql gtidpurged_7. MySQL复制全解析 Part 7 gtid_next和gtid_purged 系统变量解析
实验环境 此次实验的环境如下 MySQL 5.7.25 Redhat 6.10 操作系统账号:mysql 数据库复制账号:repl 复制格式:基于行的复制 IP地址 主从关系 复制账号 复制格式 11 ...
- mysql启动数据库进程_MySQL数据库启动报错的处理
今天在linux中启动mysql时提示mysql Starting MySQL.. The server quit without updating PID file了,下面我来给大家介绍解决办法 从 ...
- 启动mysql数据库是红色_Mysql无法启动
今天继续研究flask,想把数据库先起来. net start mysql 系统提示: Mysql服务正在启动 Mysql服务无法启动. 请键入 NET HELPMSG 3534 以获得更多的帮助. ...
- mysql服务启动很久_Mysql服务启动问题
Endnote专题之--output style相关问题 Endnote专题之--output style相关问题 1. 打开output style, Edit--->Output Style ...
- mysql设置root只读_mysql主从架构的实现
阅读文本大概需要20分钟. 1.1 环境准备: centos系统服务器2台. 一台用户做Mysql主服务器, 一台用于做Mysql从服务器, 配置好yum源. 防火墙关闭. 各节点时钟服务同步. 各节 ...
最新文章
- PAT(甲级)2021年春季考试 7-4 Recycling of Shared Bicycles
- php项目数据库连接设置,在PHP中设置数据库连接类
- BZOJ #3746: [POI2015]Czarnoksiężnicy okrągłego stołu 动态规划
- 一个LinkedList的简单体现(用户缓存手机通话记录)
- Android代码修改系统时间
- Arduino IDE for ESP8266 项目(1) 点亮灯+按键LED+pwm
- 读书若谈恋爱:如何阅读一本书?
- 面试算法 香槟塔 ,算法:暴力算法
- 【STM32F429开发板用户手册】第33章 STM32F429的SPI总线应用之驱动DAC8563(双通道,16bit分辨率,正负10V)
- 电脑卡顿,终于解决了多年的电脑卡顿问题
- code回归采访哭 ladies_LADIES’CODE再次提到高恩妃和权梨世的车祸事故 在节目中流泪...
- DTMF 编码及解码
- WAV 和AAC格式
- Google Play 应用上架(二)
- 量子计算机算法与应用研究论文(转载务必注明出处)
- 如何理解反射信号淹没在上升沿中
- 递去了怎么还归来了呢
- 【code-server】部署浏览器上的VSCode「IPAD编程」
- 大数据分析案例-基于随机森林模型对北京房价进行预测
- ubuntu matlab 路径不能永久保存的解决办法