MySQL参数学习(一)

时间:2022-02-13 02:12:00

(1)MySQL参数文件my.cnf

MySQL默认参数文件的位置有4个,如果有多个参数文件,则参数采用覆盖原则,后面文件的参数会将前面配置文件的参数覆盖掉。

[[email protected] bin]# mysqld --help -v| grep my.cnf /etc/my.cnf /etc/mysql/my.cnf /usr/local/mysql/etc/my.cnf ~/.my.cnf

DBA也可以通过"defaults_file"自定义参数文件的位置,从而不读取系统默认配置文件。

[[email protected] etc]$ mysql --help |grep defaults-file --defaults-file=# 
Only read default options from the given file #. 

如何使用自定义的参数文件呢?

cd /usr/local/mysql
 bin/mysqld --defaults-file=/opt/mysql/mysql/etc/my.cnf  --initialize --user=mysql

 

(2)MySQL参数配置

MySQL参数从作用域上可分为2类:global和session,从修改类型上又可以分为:可修改和只读参数,用户可以在线修改非只读参数,对于只读参数,可以通过配置文件修改并重启。

(2.1)查看参数设置

show variables like %log%;

或者:

-- session级别参数
mysql> select @@autocommit;
 -------------- 
| @@autocommit |
 -------------- 
|            0 |
 -------------- 
1 row in set (0.00 sec)

-- global级别参数
mysql> select @@global.autocommit;
 --------------------- 
| @@global.autocommit |
 --------------------- 
|                   1 |
 --------------------- 
1 row in set (0.00 sec)

(2.2)修改参数

-- 会话参数修改 
mysql> set autocommit=0; 

-- 全局参数修改 
mysql> set global autocommit = 0;

对于会话级别参数的修改,只针对当前会话有效;对于全局参数的修改,对后续新建立的连接有效。但是重启数据库之后,参数均会变为修改前的值,即所有参数的修改都不能持久化,重启之后还是按照配置文件来。如果要保持参数持久有效,需要修改参数文件my.cnf并重启数据库。