首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >缓存中的线程仍然使用内存吗?

缓存中的线程仍然使用内存吗?
EN

Database Administration用户
提问于 2014-10-01 15:37:57
回答 1查看 427关注 0票数 1

我正在研究如何和多少内存分配给每个连接线程,并在MySQL教程中找到:

http://dev.mysql.com/doc/refman/5.1/en/memory-use.html

以下有一点我是无法理解的。

  • 当线程不再需要时,分配给它的内存将被释放并返回给系统,除非线程返回到线程缓存中。在这种情况下,内存仍然是分配的。

我所关注的问题如下:

  • 这是否意味着线程占用内存,甚至系统也在使用缓存中的线程?
  • 线程中的缓存还在使用内存吗?
EN

回答 1

Database Administration用户

回答已采纳

发布于 2014-10-01 17:33:13

我写了这些帖子

并讨论了为每个连接分配的许多缓冲区。它们是RAM的一部分,而不是封装在缓存中。由于缓冲区是根据my.cnf中定义的缓冲区设置的,如果不是,则是默认的缓冲区,因此,如果需要重用线程,则释放内存是没有意义的,并且会再次将缓冲区设置为相同的大小。正如我在打开和关闭DB连接的成本有多高?中提到的,释放并立即分配缓冲区将是一项昂贵的操作。

因此,关于你的实际问题

这是否意味着线程占用内存,甚至系统也在使用缓存中的线程?线程中的缓存还在使用内存吗?

两者的答案都是肯定的

票数 1
EN
页面原文内容由Database Administration提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://dba.stackexchange.com/questions/78167

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档