我有一个DB,除其他外,它存储图像(如果这很有趣的话)。它还存储用户的元数据、活动日志等,但是图像目前在总共600 of的数据中占了500 of。
我是一个完全的新手,但如果我正确理解PG有两个缓冲池(至少),一个用于索引,一个用于“堆”(数据)。
我想象我的映像“污染”了堆缓存,几乎没有任何其他缓存(缓存显然不够大,无法容纳所有映像)。
我能否仅停止图像块(我不介意缓存的图像索引)被缓存?
发布于 2013-08-30 12:54:59
我认为第一个问题是系统有多少内存。如果您有足够的数据库可以很好地适应RAM,那么这不是一个主要的问题。基本上,OS磁盘缓存非常快,如果数据库处于有效的位置,那么您就没有什么可担心的了。如果您在一个系统上运行,比方说,4GB内存,而不是所有其他运行,我不会担心。
当这种情况不正确时,问题就会发生,然后共享缓冲区试图保存最常用的信息。我希望缓存在那里也是可以的。您必须记住的是,PostgreSQL缓存比OS缓存慢,因为它提供了将经常使用的数据保存在缓存中的特性。
当然,上述所有内容都高度依赖于您的查询模式。
https://dba.stackexchange.com/questions/37665
复制相似问题