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)!

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

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

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

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

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

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

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

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


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

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
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

SublimeText3 Linux new version
SublimeText3 Linux latest version

SublimeText3 English version
Recommended: Win version, supports code prompts!
