MySQL配置文件mysql.ini参数详解(mysql优化)

DogJay 2019-12-04 系统运维 8214人已围观

my.ini(Linux系统下是my.cnf),当mysql服务器启动时它会读取这个文件,设置相关的运行环境参数。

my.ini分为两块:Client Section和Server Section。
Client Section用来配置MySQL客户端参数。
要查看配置参数可以用下面的命令:

1
<span><span>show</span> variables <span>like</span> <span>'%innodb%'</span>;</span> # 查看innodb相关配置参数
1
<span><span>show</span> status <span>like</span> <span>'%innodb%'</span>;</span> # 查看innodb相关的运行时参数(比如当前正在打开的表的数量,当前已经打开的表的数量)
1
<span><span>show</span> <span>global</span> status <span>like</span> <span>'open%tables'</span>;</span> # 查看全局的运行时参数,加上global是对当前mysql服务器中运行的所有数据库实例进行统计。不加global则只对当前数据库实例进行统计。

1、Client Section

1
2
[client]
  port = <span>3306</span> <span># 设置mysql客户端连接服务端时默认使用的端口</span> [mysql] <span>default</span>-character-<span>set</span>=utf8 <span># 设置mysql客户端默认字符集</span>

2、Server Section

1
<span>[mysqld]</span> <span>port=<span><span>3306</span> # mysql服务端默认监听(listen <span>on</span>)的TCP/IP端口</span></span> <span>basedir=<span><span>"C:/Program Files/MySQL/Mysql server 5.5/"</span> # 基准路径,其他路径都相对于这个路径</span></span> <span>datadir=<span><span>"C:/Program Files/MySQL/MySQL Server 5.5/Data"</span> # mysql数据库文件所在目录</span></span> <span>character-set-server=<span>latin1 # 服务端使用的字符集默认为<span>8</span>比特编码的latin1字符集</span></span> <span>default-storage-engine=<span>INNODB # 创建新表时将使用的默认存储引擎</span></span> <span>sql-mode=<span><span>"STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"</span> # SQL模式为strict模式</span></span> <span>max_connections=<span><span>100</span> # mysql服务器支持的最大并发连接数(用户数)。但总会预留其中的一个连接给管理员使用超级权限登录,即使连接数目达到最大限制。如果设置得过小而用户比较多,会经常出现“Too many connections”错误。</span></span> <span>query_cache_size=<span><span>0</span> # 查询缓存大小,用于缓存SELECT查询结果。如果有许多返回相同查询结果的SELECT查询,并且很少改变表,可以设置query_cache_size大于<span>0</span>,可以极大改善查询效率。而如果表数据频繁变化,就不要使用这个,会适得其反</span></span> <span>table_cache=<span><span>256</span> # 这个参数在<span>5.1</span>.<span>3</span>之后的版本中叫做table_open_cache,用于设置table高速缓存的数量。由于每个客户端连接都会至少访问一个表,因此此参数的值与 max_connections有关。当某一连接访问一个表时,MySQL会检查当前已缓存表的数量。如果该表已经在缓存中打开,则会直接访问缓存中的表已加快查询速度;如果该表未被缓存,则会将当前的表添加进缓存并进行查询。在执行缓存操作之前,table_cache用于限制缓存表的最大数目:如果当前已经缓存的表未达到table_cache,则会将新表添加进来;若已经达到此值,MySQL将根据缓存表的最后查询时间、查询率等规则释放之前的缓存。</span></span> <span>tmp_table_size=<span><span>34</span>M # 内存中的每个临时表允许的最大大小。如果临时表大小超过该值,临时表将自动转为基于磁盘的表(Disk Based Table)。</span></span> <span>thread_cache_size=<span><span>8</span> # 缓存的最大线程数。当客户端连接断开时,如果客户端总连接数小于该值,则处理客户端任务的线程放回缓存。在高并发情况下,如果该值设置得太小,就会有很多线程频繁创建,线程创建的开销会变大,查询效率也会下降。一般来说如果在应用端有良好的多线程处理,这个参数对性能不会有太大的提高。</span></span>

MyISAM相关参数

1
2
3
4
5
myisam_max_sort_file_size=<span>100</span>G <span># mysql重建索引时允许使用的临时文件最大大小</span> myisam_sort_buffer_size=<span>68</span>M
 
key_buffer_size=<span>54</span>M <span># Key Buffer大小,用于缓存MyISAM表的索引块。决定数据库索引处理的速度(尤其是索引读)</span> <span>read</span>_buffer_size=<span>64</span>K <span># 用于对MyISAM表全表扫描时使用的缓冲区大小。针对每个线程进行分配(前提是进行了全表扫描)。进行排序查询时,MySql会首先扫描一遍该缓冲,以避免磁盘搜索,提高查询速度,如果需要排序大量数据,可适当调高该值。但MySql会为每个客户连接发放该缓冲空间,所以应尽量适当设置该值,以避免内存开销过大。</span> <span>read</span>_rnd_buffer_size=<span>256</span>K
 
sort_buffer_size=<span>256</span>K <span># connection级参数(为每个线程配置),500个线程将消耗500*256K的sort_buffer_size。</span>

InnoDB相关参数

1
innodb_additional_mem_pool_size=<span>3</span>M <span># InnoDB用于存储元数据信息的内存池大小,一般不需修改</span> innodb_flush_log_at_trx_commit =<span>1</span> <span># 事务相关参数,如果值为1,则InnoDB在每次commit都会将事务日志写入磁盘(磁盘IO消耗较大),这样保证了完全的ACID特性。而如果设置为0,则表示事务日志写入内存log和内存log写入磁盘的频率都为1次/秒。如果设为2则表示事务日志在每次commit都写入内存log,但内存log写入磁盘的频率为1次/秒。</span> innodb_log_buffer_size=<span>2</span>M <span># InnoDB日志数据缓冲大小,如果缓冲满了,就会将缓冲中的日志数据写入磁盘(flush)。由于一般至少都1秒钟会写一次磁盘,所以没必要设置过大,即使是长事务。</span> innodb_buffer_pool_size=<span>105</span>M <span># InnoDB使用缓冲池来缓存索引和行数据。该值设置的越大,则磁盘IO越少。一般将该值设为物理内存的80%。</span> innodb_log_file_size=<span>53</span>M <span># 每一个InnoDB事务日志的大小。一般设为innodb_buffer_pool_size的25%到100%</span> innodb_thread_concurrency=<span>9</span> <span># InnoDB内核最大并发线程数。</span>

在Apache, PHP, MySQL的体系架构中,MySQL对于性能的影响最大,也是关键的核心部分。对于Discuz!论坛程序也是如此,MySQL的设置是否合理优化,直接影响到论坛的速度和承载量!同时,MySQL也是优化难度最大的一个部分,不但需要理解一些MySQL专业知识,同时还需要长时间的观察统计并且根据经验进行判断,然后设置合理的参数。 下面我们了解一下MySQL优化的一些基础,MySQL的优化我分为两个部分,一是服务器物理硬件的优化,二是MySQL自身(my.cnf)的优化。

一、服务器硬件对MySQL性能的影响

①磁盘寻道能力(磁盘I/O),以目前高转速SCSI硬盘(7200转/秒)为例,这种硬盘理论上每秒寻道7200次,这是物理特性决定的,没有办法改变。MySQL每秒钟都在进行大量、复杂的查询操作,对磁盘的读写量可想而知。所以,通常认为磁盘I/O是制约MySQL性能的最大因素之一,对于日均访问量在100万PV以上的Discuz!论坛,由于磁盘I/O的制约,MySQL的性能会非常低下!解决这一制约因素可以考虑以下几种解决方案: 使用RAID-0+1磁盘阵列,注意不要尝试使用RAID-5,MySQL在RAID-5磁盘阵列上的效率不会像你期待的那样快。

②CPU 对于MySQL应用,推荐使用S.M.P.架构的多路对称CPU,例如:可以使用两颗Intel Xeon 3.6GHz的CPU,现在我较推荐用4U的服务器来专门做数据库服务器,不仅仅是针对于mysql。

③物理内存对于一台使用MySQL的Database Server来说,服务器内存建议不要小于2GB,推荐使用4GB以上的物理内存,不过内存对于现在的服务器而言可以说是一个可以忽略的问题,工作中遇到了高端服务器基本上内存都超过了16G。


二、MySQL自身因素当解决了上述服务器硬件制约因素后,让我们看看MySQL自身的优化是如何操作的。对MySQL自身的优化主要是对其配置文件my.cnf中的各项参数进行优化调整。下面我们介绍一些对性能影响较大的参数。 由于my.cnf文件的优化设置是与服务器硬件配置息息相关的,因而我们指定一个假想的服务器硬件环境:CPU: 2颗Intel Xeon 2.4GHz 内存: 4GB DDR 硬盘: SCSI 73GB(很常见的2U服务器)。

下面,我们根据以上硬件配置结合一份已