Misc Configuration Parameters

relcache_expire ( integer )

Specifies the relation cache expiration time in seconds. The relation cache is used for caching the query result of PostgreSQL system catalogs that is used by Pgpool-II to get various informations including the table structures and to check table types(e.g. To check if the referred table is a temporary table or not). The cache is maintained in the local memory space of Pgpool-II child process and its lifetime is same as of the child process. The cache is also maintained in shared memory to share among child processes,if enable enable_shared_relcache . So If the table is modified using ALTER TABLE or some other means, the relcache becomes inconsistent. For this purpose, relcache_expire controls the life time of the cache. Default is 0, which means the cache never expires.

This parameter can only be set at server start.

relcache_size ( integer )

Specifies the number of relcache entries. Default is 256. The cache is created about 10 entries per table. So you can estimate the required number of relation cache at "number of using table * 10".

Note: If the below message frequently appears in the Pgpool-II log, you may need to increase the relcache_size for better performance.

       "pool_search_relcache: cache replacement happened"
      

This parameter can only be set at server start.

enable_shared_relcache ( boolean )

Setting to on, relation cache shared among Pgpool-II child processes using the query cache. Default is on. Each child process executed same query to refer to system catalog from PostgreSQL , but using query cache can expect to execute only same query once. Expiration time on query cache is relcache_expire parameter. This parameter enables even if memory_cache_enabled is off. In this case some query cache parameters( memqcache_method , memqcache_maxcache and each cache storage parameter) is used together.

Pgpool-II search relation cache on local for a cache entry first, if this is on. When it is not found on relation cache, query cache is searched for it next. If it is found on query cache, it is copied to relation cache on local. if a cache entry is not found on anywhere, execute the query for PostgreSQL , the result is registered with relation cache and local cache.

This parameter can only be set at server start.

relcache_query_target ( enum )

The target node to send queries to create relation cache entries. If set to master , queries will be sent to master (primary) node. This is the default and recommended to most users because the query could get the latest information. If you want to lower the load of master (primary) node, you can set the parameter to load_balance_node , which will send queries to the load balance node. This is especially useful for such a system where Pgpool-II /primary server is on a continent A while other Pgpool-II /standby server is on other continent B. Clients on B want read data from the standby because it's much geographically closer. In this case you can set backend_weight0 (this represents primary) to 0, backend_weight1 to 1 (this represents standby) and set relache_query_target to load_balance_node .

Note, however, if you send query to the standby node, recently created tables and rows might not be available on the standby server yet because of replication delay. Thus such a configuration is not recommended for systems where data modification activity is high.

This parameter can be changed by reloading the Pgpool-II configurations.

check_temp_table ( enum )

Setting to catalog or trace , enables the temporary table check in the SELECT statements. To check the temporary table Pgpool-II queries the system catalog of primary/master PostgreSQL backend if catalog is specified, which increases the load on the primary/master server.

If trace is set, Pgpool-II traces temporary table creation and dropping to obtain temporary table info. So no need to access system catalogs. However, if temporary table creation is invisible to Pgpool-II (done in functions or triggers, for example), Pgpool-II cannot recognize the creation of temporary tables.

If you are absolutely sure that your system never uses temporary tables, then you can safely set to none.

Note: For a backward compatibily sake for 4.0 or before, Pgpool-II accepts on , which is same as catalog and off , which is same as none , they may be deleted in the future version.

Default is catalog .

This parameter can be changed by reloading the Pgpool-II configurations. You can also use PGPOOL SET command to alter the value of this parameter for a current session.

check_unlogged_table ( boolean )

Setting to on, enables the unlogged table check in the SELECT statements. To check the unlogged table Pgpool-II queries the system catalog of primary/master PostgreSQL backend which increases the load on the primary/master server. If you are absolutely sure that your system never uses the unlogged tables (for example, you are using 9.0 or earlier version of PostgreSQL ) then you can safely turn off the check_unlogged_table . Default is on.

This parameter can be changed by reloading the Pgpool-II configurations. You can also use PGPOOL SET command to alter the value of this parameter for a current session.

pid_file_name ( string )

Specifies the full path to a file to store the Pgpool-II process id. The pid_file_name path can be specified as relative to the location of pgpool.conf file or as an absolute path Default is "/var/run/pgpool/pgpool.pid" .

This parameter can only be set at server start.

logdir ( string )

Specifies the full path to a directory to store the pgpool_status . Default is '/tmp' .

This parameter can only be set at server start.