zoukankan      html  css  js  c++  java
  • 对PostgreSQL中bufmgr.c 的BgBufferSync的静态变量学习 prev_strategy_buf_id

    开始

    bool                
    BgBufferSync(void)                
    {                
        ……            
        /*            
         * Information saved between calls so we can determine the strategy            
         * point's advance rate and avoid scanning already-cleaned buffers.            
         */            
        static           bool          saved_info_valid = false;            
        static           int        prev_strategy_buf_id;    
        static          uint32         prev_strategy_passes;    
        static          int        next_to_clean;    
        static     uint32     next_passes;  
                    
        /* Moving averages of allocation rate and clean-buffer density */            
        static     float     smoothed_alloc = 0;    
        static     float     smoothed_density = 10.0;    
                    
        ……         
                    
        if (saved_info_valid)            
        {            
            ……        
            strategy_delta = strategy_buf_id - prev_strategy_buf_id;        
            strategy_delta += (long) passes_delta *NBuffers;        
            ……     
        }            
        else            
        {            
            ……        
        }            
        
    fprintf(stderr,"before saving, prev_strategy_buf_id is %d \n", prev_strategy_buf_id);
    /* Update saved info for next time */ prev_strategy_buf_id = strategy_buf_id; prev_strategy_passes = strategy_passes; saved_info_valid = true; …… fprintf(stderr,"prev_strategy_buf_id is %d \n", prev_strategy_buf_id); /* Return true if OK to hibernate */ return (bufs_to_lap == 0 && recent_alloc == 0); }

    执行的结果显示,即使我用psql 变更了某行的值,直到最后,prev_strategy_buf_id 的值也没有发生根本性的变化。

    [postgres@localhost bin]$ ./postgres -D /usr/local/pgsql/data        
    LOG:  database system was shut down at 2012-11-02 15:30:38 CST        
    saved_info_valid false.        
    before saving,prev_strategy_buf_id is: 0        
    prev_strategy_buf_id is 0         
    LOG:  autovacuum launcher started        
    LOG:  database system is ready to accept connections        
    before saving,prev_strategy_buf_id is: 0        
    prev_strategy_buf_id is 0         
    before saving,prev_strategy_buf_id is: 0        
    prev_strategy_buf_id is 0         
    before saving,prev_strategy_buf_id is: 0        
    prev_strategy_buf_id is 0         
    before saving,prev_strategy_buf_id is: 0        
    prev_strategy_buf_id is 0         
    before saving,prev_strategy_buf_id is: 0        
    prev_strategy_buf_id is 0         
            
    ……        
            
            
    before saving,prev_strategy_buf_id is: 0        
    prev_strategy_buf_id is 0         
    LOG:  received fast shutdown request        
    LOG:  aborting any active transactions        
    LOG:  autovacuum launcher shutting down        
    LOG:  shutting down        
    LOG:  database system is shut down        
    [postgres@localhost bin]$         

    [作者:技术者高健@博客园  mail: luckyjackgao@gmail.com ]

    结束

  • 相关阅读:
    Windows下安装ZooKeeper
    解决不同库之间$对象的冲突
    Entity Framework的基本操作
    IIS6与IIS7中的w3wp工作进程
    Asp.Net网站的的编译与发布原理
    MVC中JavaScript和CSS的自动打包与压缩
    EF CodeFirst示例
    EF CodeFirst下的自动迁移
    分布式调度平台XXL-JOB源码分析-时序图
    分布式调度平台XXL-JOB源码分析-执行器端
  • 原文地址:https://www.cnblogs.com/gaojian/p/2751375.html
Copyright © 2011-2022 走看看