• postgresql-shared_buffers调整


    shared_buffers大小调整:
    SELECT 
    usagecount,count(*),isdirty,
    round((count(*)/ max(total_cache.cnt):: float * 100):: numeric,2)as percent_of_total_cache 
    FROM pg_buffercache,
    (select count(*)as cnt from pg_buffercache)as total_cache 
    GROUP BY isdirty,usagecount 
    ORDER BY isdirty,usagecount;
     
     usagecount | 计数| isdirty | percent_of_total_cache 
    ------------ + -------- + --------- + ----------------- ------- 
              0 | 44204 | f | 16.86 
              1 | 39288 | f | 14.99 
              2 | 18917 | f | 7.22 
              3 | 10702 | f | 4.08 
              4 | 39549 | f | 15.09 
              5 | 109484 | f | 41.76 
    (6行)
     
     usagecount | 计数| isdirty | percent_of_total_cache 
    ------------ + -------- + --------- + ----------------- ------- 
              0 | 44204 | f | 16.86 
              1 | 39288 | f | 14.99
              2 | 18917 | f | 7.22 
              3 | 10702 | f | 4.08 
              4 | 39546 | f | 15.09 
              5 | 109435 | f | 41.75 
              5 | 52 | t | 0.02 
    (7行)
     usagecount | 计数| isdirty | percent_of_total_cache 
    ------------ + -------- + --------- + ----------------- ------- 
              0 | 44204 | f | 16.86 
              1 | 39288 | f | 14.99 
              2 | 18917 | f | 7.22 
              3 | 10702 | f | 4.08 
              4 | 39546 | f | 15.09
              5 | 109487 | f | 41.77 
    (6行)
     
    检查结果,我发现超过50%的buffercache块被累积,使用次数高达4.5。
    这是一个强有力的证据,我需要增加shared_buffer的值。正如我有一个专用数据库服务器32 GBRAM,I增加从值的2 Gb到4GB。
     
    设置shared_buffers太难:
    进出postgres的数据块都通过shared_buffers。只是回顾一下我链接到的博客文章,每当在共享内存中使用一个块时,它就会增加时钟扫描算法,范围从1-5,5是极高的使用数据块。这意味着高使用率块可能会保留在shared_buffers中(如果有空间),如果需要更高使用率的空间,则低使用率块将被移出。我们认为简单的插入或更新会将使用次数设置为1.因此,现在我们看一下当使用次数减少时的差异。
    edb postgresql :
    亚马逊配置75%内存,引发的问题。
     
    测试tps:
    序号 参数配置 第一次 第二次 第三次 平均值
    1 shared_buffers=128MB(默认) 249 126 145 =173
    2 shared_buffers=4GB 357 357 373 = 362
    3 shared_buffers=8GB 362 363 415 =380
    4.shared_buffers=24GB 378 368 397 =381
    预热缓存测试结果:
    序号 参数配置 第一次 第二次 第三次 平均值
    1 shared_buffers=128MB(默认) 211 194 207 204
    2 shared_buffers=4GB 1225 1288 1321 1278
    3 shared_buffers=8GB 1176 1291 1144 1203
    4.shared_buffers=24GB 1285 1250 1309 1281
    当shared_buffers=4GB时,数据不能完全装下,所以优先预热索引,将索引加载到缓存的tps和8GB,24GB表现差别不大
  • 相关阅读:
    C++ Primer 第五版-1.1
    C++ Primer 第五版笔记-1.0
    TouchID
    正则表达式
    duplicate symbol 错误
    第三方登录
    AFNetWorking
    IOS---通知
    左右点击--日期增减
    Xcode相关设置
  • 原文地址:https://www.cnblogs.com/zhangfx01/p/10215693.html
Copyright © 2020-2023  润新知