dja*_*aho 3 memory mariadb buffer
我一直在寻找这个问题的答案,但在任何地方都找不到。
我想减少每个数据库连接的内存使用量。以下是 mysql 调优器目前对我的一个数据库的内存使用情况的描述:
[--] Physical Memory : 985.2M
[--] Max MySQL memory : 950.4M
[--] Other process memory: 0B
[--] Total buffers: 292.0M global + 18.8M per thread (35 max threads)
[--] P_S Max memory usage: 0B
[--] Galera GCache Max memory usage: 0B
[OK] Maximum reached memory usage: 310.8M (31.55% of installed RAM)
[!!] Maximum possible memory usage: 950.4M (96.47% of installed RAM)
Run Code Online (Sandbox Code Playgroud)
可以看到每个线程的内存使用量相当高18.8M。这是我的其他服务器之一的输出:
[--] Total buffers: 400.0M global + 2.8M per thread (250 max threads)
Run Code Online (Sandbox Code Playgroud)
你可以看到这里的内存使用量低了很多(只有 2.8M),因此我可以有更多的数据库连接。
我试图找出哪个变量控制每个线程的内存使用量,但找不到任何东西。我认为它与 sort_buffer_size 或 read_buffer_size 有关,但是当我更改这些变量之一时,每个线程的使用量似乎并没有下降。
在我看来,它根本不是我可以修改的东西,并且可能是根据每个线程的实际内存使用情况计算的?
我可以采取什么措施来减少每个线程的缓冲区内存使用量?
编辑(2020-06-10):这两个数据库之间的区别在于,第一个数据库的版本为MariaDB 10.4.12,而第二个数据库的版本为MariaDB 10.1.38。如果我比较注释中提到的 sort_buffer_size、read_buffer_size、key_buffer_size 等变量,我看到的只是它们设置为相同的值。
好吧,经过更多调查,我终于弄清楚为什么这两个数字如此不同。
问题是我在服务器上使用旧版本的 mysqltuner.pl,其中每个线程的最大内存使用量仅为 2.8 MB。6 个月前,mysqltuner.pl 也开始在每个线程的使用量计算中使用max_allowed_packet变量值,这会额外增加 16 MB 并达到 18.8 MB。这是 github 上的更改:https://github.com/major/MySQLTuner-perl/commit/c5765f02133259b40d9932eb7d35ba5c1665bad9 运行更新版本的 mysqltuner.pl 后,RAM 使用情况如下所示:
[--] Total buffers: 400.0M global + 18.8M per thread (250 max threads)
Run Code Online (Sandbox Code Playgroud)
这些是用于计算每个线程的缓冲区使用量的变量(对于相对较新的 MariaDB 版本):
read_buffer_size,
read_rnd_buffer_size,
sort_buffer_size,
thread_stack,
max_allowed_packet,
join_buffer_size
Run Code Online (Sandbox Code Playgroud)
只有@Wilson Hauck 提到了 max_allowed_packet 变量;)
如果有人需要的话,这是检查这些值的查询:
SHOW GLOBAL VARIABLES WHERE variable_name IN('read_buffer_size', 'read_rnd_buffer_size', 'sort_buffer_size', 'thread_stack', 'max_allowed_packet', 'join_buffer_size');
Run Code Online (Sandbox Code Playgroud)
因此,经过所有这些研究,我发现第二台服务器上允许的数据库连接数量太多(250)。如果总共使用的话,我的数据库可以使用 5GB RAM,而我在这个系统上只有 2GB。
对最初问题的实际回答: 因此,如果我想降低每个线程或每个连接的内存使用量(正如你们中的一些人提到的),我可能必须降低 max_allowed_packet 值,但我不确定这是否是一个好主意。
感谢大家的帮助。
| 归档时间: |
|
| 查看次数: |
3440 次 |
| 最近记录: |