search
HomeDatabaseMysql TutorialMysql memory parameter optimization

1. Key buffer

A. The parameter key_buffer_size only affects the table of the myisam engine;

B. It determines the speed of index processing, especially the speed of index reading;

C. You can check whether this parameter is set appropriately to evaluate it. Two status values ​​show status like '%key_read%';

D. Key_read_requests represents the total number of requests, key_reads represents the number of read disks;

E. key_reads / key_read_requests should be as low as possible, at least 1:100. 1:1000 is better;

F. Another way to estimate key_buffer_size is to add up the space occupied by the indexes of each table in your database.

2. Query cache

A. The query cache mainly stores SELECT statements and query results in the buffer;

B. The reasonable setting of the parameter query_cache_size can be used to check the status of the db: show status like '%qcache%' ​​​​Indicates the currently cached items Number

Qcache inserts 20649006

Qcache hits 79060095 It seems that the repeated query rate is quite high

Qcache lowmem PRunes 617913 There have been so many cases where the cache is too low

Qcache not cached 189896

Q cache free memory 18573912 currently remaining Cache space

Qcache free blocks 5328 This number seems a bit large and has many fragments

Qcache total blocks 30953

F. The results show that the query cache value needs to be set larger;

G. Qcache_free_blocks, if the value is very large , it indicates that there are many fragments in the buffer

H. The value of Qcache_lowmem_prunes is very large, which indicates that there is often insufficient buffering. At the same time, the value of Qcache_hits is very large, which indicates that the query buffer is used very frequently. At this time, the buffer size of Qcache_hits needs to be increased. If the value is small, it means that your query repetition rate is very low. In this case, using query buffering will affect efficiency, so you can consider not using query buffering. In addition, adding SQL_NO_CACHE to the SELECT statement can clearly indicate that the query buffer is not used.

3. Table cache

A. table_cache specifies the size of the table cache;

B. Whenever MySQL accesses a table, if there is space in the table buffer, the table is opened and placed in it. This allows faster access to table contents;

C. By checking the status values ​​Open_tables and Opened_tables at peak times, you can decide whether you need to increase the value of table_cache. If you find that open_tables is equal to table_cache, and open_tables is constantly growing, then you need to increase the value of table_cache;

D. Note that table_cache cannot be set to a large value blindly. If set too high, it may cause insufficient file descriptors, resulting in unstable performance or connection failure.

4. Innodb buffer

A. innodb_buffer_pool_size - This is very important for Innodb tables. Innodb tables are more sensitive to buffering than MyISAM tables. MyISAM can run fine under the default key_buffer_size setting, but Innodb runs like a snail under the default innodb_buffer_pool_size setting.

B. Since Innodb caches both data and indexes, there is no need to leave too much MySQL database memory to the operating system. Therefore, if you only need to use Innodb, you can set it up to 70-80% of the available memory.

C. If your data volume is not large and will not increase dramatically, then there is no need to set innodb_buffer_pool_size too large.

D. innodb_log_file_size is important in case of high write load especially large data sets. The larger the value, the better the performance, but be aware that recovery time may increase. I usually set it to 64-512MB, depending on the server size. The default setting of innodb_log_buffer_size provides acceptable server performance under moderate write load and short transactions.

E. Are you worried that Innodb_flush_logs_at_trx_commit is 1000 times slower than MyISAM? It seems that maybe you forgot to modify this parameter. The default value is 1, which means that every committed update transaction (or every statement outside of a transaction) is flushed to disk, which is quite resource-intensive, especially without a battery-backed cache. Many applications, especially those converted from MyISAM, will be fine by setting its value to 2, which means that the log will not be flushed to disk, but only to the operating system cache. The log is still flushed to disk every second, so the cost of 1-2 updates per second is usually not lost. If it is set to 0, it will be much faster, but it will also be relatively unsafe. Some transactions will be lost when the MySQL server crashes. A setting of 2 causes the portion of the transaction that is flushed to the operating system cache to be lost.

The above is the content of Mysql memory parameter optimization. For more related articles, please pay attention to the PHP Chinese website (www.php.cn)!

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
图文详解mysql架构原理图文详解mysql架构原理May 17, 2022 pm 05:54 PM

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于架构原理的相关内容,MySQL Server架构自顶向下大致可以分网络连接层、服务层、存储引擎层和系统文件层,下面一起来看一下,希望对大家有帮助。

mysql的msi与zip版本有什么区别mysql的msi与zip版本有什么区别May 16, 2022 pm 04:33 PM

mysql的msi与zip版本的区别:1、zip包含的安装程序是一种主动安装,而msi包含的是被installer所用的安装文件以提交请求的方式安装;2、zip是一种数据压缩和文档存储的文件格式,msi是微软格式的安装包。

mysql怎么去掉第一个字符mysql怎么去掉第一个字符May 19, 2022 am 10:21 AM

方法:1、利用right函数,语法为“update 表名 set 指定字段 = right(指定字段, length(指定字段)-1)...”;2、利用substring函数,语法为“select substring(指定字段,2)..”。

mysql怎么替换换行符mysql怎么替换换行符Apr 18, 2022 pm 03:14 PM

在mysql中,可以利用char()和REPLACE()函数来替换换行符;REPLACE()函数可以用新字符串替换列中的换行符,而换行符可使用“char(13)”来表示,语法为“replace(字段名,char(13),'新字符串') ”。

mysql怎么将varchar转换为int类型mysql怎么将varchar转换为int类型May 12, 2022 pm 04:51 PM

转换方法:1、利用cast函数,语法“select * from 表名 order by cast(字段名 as SIGNED)”;2、利用“select * from 表名 order by CONVERT(字段名,SIGNED)”语句。

MySQL复制技术之异步复制和半同步复制MySQL复制技术之异步复制和半同步复制Apr 25, 2022 pm 07:21 PM

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于MySQL复制技术的相关问题,包括了异步复制、半同步复制等等内容,下面一起来看一下,希望对大家有帮助。

mysql怎么判断是否是数字类型mysql怎么判断是否是数字类型May 16, 2022 am 10:09 AM

在mysql中,可以利用REGEXP运算符判断数据是否是数字类型,语法为“String REGEXP '[^0-9.]'”;该运算符是正则表达式的缩写,若数据字符中含有数字时,返回的结果是true,反之返回的结果是false。

带你把MySQL索引吃透了带你把MySQL索引吃透了Apr 22, 2022 am 11:48 AM

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了mysql高级篇的一些问题,包括了索引是什么、索引底层实现等等问题,下面一起来看一下,希望对大家有帮助。

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Tools

mPDF

mPDF

mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

SublimeText3 Linux new version

SublimeText3 Linux new version

SublimeText3 Linux latest version

SublimeText3 English version

SublimeText3 English version

Recommended: Win version, supports code prompts!