首頁 資料庫 mysql教程 postgreSQL pgfincore introduces

postgreSQL pgfincore introduces

Jun 07, 2016 pm 02:58 PM
introduce postgresql

postgreSQL pgfincore introduces pgfincore 和shared buffer不同,是OS层面的缓存,可以把大对象缓存到OS的cache里,其实就是内存,所以机器的内存配置越大越好,至于oracle是缓存到buffer_pool_keep,可以手工刷出,不过这个是database的缓存,和pg的share

postgreSQL pgfincore introduces

 

pgfincore 和shared buffer不同,是OS层面的缓存,可以把大对象缓存到OS的cache里,其实就是内存,所以机器的内存配置越大越好,至于oracle是缓存到buffer_pool_keep,可以手工刷出,不过这个是database的缓存,和pg的shared buffer同理。这里就不再详细介绍。

 

1.下载wget http://pgfoundry.org/frs/download.php/3186/pgfincore-v1.1.1.tar.gz

2.解压下载的安装包tar -zxvf pgfincore-v1.1.1.tar.gz

3.复制解压后的目录到pg源代码目录/contrib

4.安装:

postgres用户:

make clean

make

su - root

source /home/postgres/.bash_profile

make install

根据READ.rst

For PostgreSQL >= 9.1, log in your database and::

  mydb=# CREATE EXTENSION pgfincore;

For other release, create the functions from the sql script (it should be in

your contrib directory)::

  psql mydb -f pgfincore.sql

 

postgres=# select version();

                                                    version                                                    

---------------------------------------------------

 PostgreSQL 9.1.2 on x86_64-unknown-linux-gnu, compiled by gcc (GCC) 4.1.2 20071124 (Red Hat 4.1.2-42), 64-bit

postgres=# CREATE EXTENSION pgfincore;

CREATE EXTENSION

postgres=# select * from pg_extension ;

    extname     | extowner | extnamespace | extrelocatable | extversion | extconfig | extcondition 

----------------+----------+--------------+----------------+------------+-----------+--------------

 plpgsql        |       10 |           11 | f              | 1.0        |           | 

 pg_buffercache |       10 |         2200 | t              | 1.0        |           | 

 pgfincore      |       10 |         2200 | t              | 1.1.1      |           |

pgfincore使用:

pgfincore 对象的cache情况

pgfadvise_willneed 将对象刷入cache

pgfadvise_dontneed 将对象刷出cache

pgfadvise_loader 直接和page cache交互,加载,卸载页面

pgsysconf 操作系统的cache情况

pgsysconf_pretty同上,只不过输更易懂,带上了单位。

 

postgres=# \d t

                         Table "public.t"

 Column |  Type   |                   Modifiers                   

--------+---------+-----------------------------------------------

 s      | integer | not null default nextval('t_s_seq'::regclass)

 i      | integer | 

 postgres=# insert into t(i) values (generate_series(1,10000000));

INSERT 0 10000000

postgres=#  select pg_size_pretty(pg_relation_size('t'));

 pg_size_pretty 

----------------

 346 MB

当前文件系统的使用情况:pgsysconf(),pgsysconf_pretty()

 postgres=#  select * from pgsysconf();

 os_page_size | os_pages_free | os_total_pages 

--------------+---------------+----------------

         4096 |        182787 |        2044328

postgres=# select * from pgsysconf_pretty();

 os_page_size | os_pages_free | os_total_pages 

--------------+---------------+----------------

 4096 bytes   | 721 MB        | 7986 MB

(1 row)

表t的使用情况:pgfincore

postgres=#  select * from pgfincore('t');

     relpath      | segment | os_page_size | rel_os_pages | pages_mem | group_mem | os_pages_free | databit 

------------------+---------+--------------+--------------+-----------+-----------+---------------+---------

 base/12699/16441 |       0 |         4096 |        88496 |     88496 |         1 |        181767 |

os_page_size:文件系统页大小

rel_os_pages:占用文件系统页数量

pages_mem:有多少文件系统页在系统cache

 

刷入cache:pgfadvise_willneed()

postgres=# select * from pgfadvise_willneed('t');

     relpath      | os_page_size | rel_os_pages | os_pages_free 

------------------+--------------+--------------+---------------

 base/12699/16441 |         4096 |        88496 |        186428

(1 row)

postgres=#  select * from pgfincore('t');

     relpath      | segment | os_page_size | rel_os_pages | pages_mem | group_mem | os_pages_free | databit 

------------------+---------+--------------+--------------+-----------+-----------+---------------+---------

 base/12699/16441 |       0 |         4096 |        88496 |     88496 |         1 |        186397 | 

(1 row)

 

 刷出cache:    

postgres=# select * from pgfadvise_dontneed('t');

     relpath      | os_page_size | rel_os_pages | os_pages_free 

------------------+--------------+--------------+---------------

 base/12699/16441 |         4096 |        88496 |        275021

(1 row)

postgres=# select * from pgfincore('t');

     relpath      | segment | os_page_size | rel_os_pages | pages_mem | group_mem | os_pages_free | databit 

------------------+---------+--------------+--------------+-----------+-----------+---------------+---------

 base/12699/16441 |       0 |         4096 |        88496 |         0 |         0 |        275052 | 

(1 row)

 

pgfadvise_loader:

postgres=# select * from pgfadvise_loader('t', 0, true, true, B'111000');

     relpath      | os_page_size | os_pages_free | pages_loaded | pages_unloaded 

------------------+--------------+---------------+--------------+----------------

 base/12699/16441 |         4096 |        186626 |            3 |              3

(1 row)

loading:

postgres=# select * from pgfadvise_loader('t', 0, true, false, B'111000');

     relpath      | os_page_size | os_pages_free | pages_loaded | pages_unloaded 

------------------+--------------+---------------+--------------+----------------

 base/12699/16441 |         4096 |        186460 |            3 |              0

(1 row)

unloading:

postgres=# select * from pgfadvise_loader('t', 0, false, true, B'111000');

     relpath      | os_page_size | os_pages_free | pages_loaded | pages_unloaded 

------------------+--------------+---------------+--------------+----------------

 base/12699/16441 |         4096 |        186557 |            0 |              3

(1 row)

pgfadvise_NORMAL

pgfadvise_SEQUENTIAL

pgfadvise_RANDOM

这几个可以指定当前内存的属性,正常,顺序,还是随机。

快照与恢复:

做快照:

create table pgfincore_snapshot as

select 't'::text as relname,*,now() as date_snapshot

from pgfincore('t',true);

应用快照:

select * from pgfadvise_loader('t', 0, true, true,

                          (select databit from  pgfincore_snapshot

                           where relname='t' and segment = 0));

     relpath      | os_page_size | os_pages_free | pages_loaded | pages_unloaded 

------------------+--------------+---------------+--------------+----------------

 base/12699/16441 |         4096 |        186259 |        88490 |              6

(1 row)

postgres=#  select * from pgfincore('t');

     relpath      | segment | os_page_size | rel_os_pages | pages_mem | group_mem | os_pages_free | databit 

------------------+---------+--------------+--------------+-----------+-----------+---------------+---------

 base/12699/16441 |       0 |         4096 |        88496 |     88490 |         2 |        186097 | 

(1 row)

可以看到 88496 和88490,有几个页面是刷出cache,所以不相等

select * from pgfadvise_willneed('t');

postgres=# select * from pgfincore('t');

     relpath      | segment | os_page_size | rel_os_pages | pages_mem | group_mem | os_pages_free | databit 

------------------+---------+--------------+--------------+-----------+-----------+---------------+---------

 base/12699/16441 |       0 |         4096 |        88496 |     88496 |         1 |        186227 | 

(1 row)

 

限制:

*PgFincore needs mincore() and POSIX_FADVISE.

*PgFincore has a limited mode when POSIX_FADVISE is not provided by the platform.

*PgFincore needs PostgreSQL >= 8.3

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

MySQL與PostgreSQL:效能對比與最佳化技巧 MySQL與PostgreSQL:效能對比與最佳化技巧 Jul 13, 2023 pm 03:33 PM

MySQL與PostgreSQL:效能比較與最佳化技巧在開發web應用程式時,資料庫是不可或缺的組成部分。而在選擇資料庫管理系統時,MySQL和PostgreSQL是兩個常見的選擇。他們都是開源的關係型資料庫管理系統(RDBMS),但在效能和最佳化方面有一些不同之處。本文將比較MySQL和PostgreSQL的效能,並提供一些最佳化技巧。性能對比在比較兩個資料庫管

MySQL和PostgreSQL:在Web開發中的最佳實踐 MySQL和PostgreSQL:在Web開發中的最佳實踐 Jul 14, 2023 pm 02:34 PM

MySQL和PostgreSQL:在Web開發中的最佳實務引言:在現代的Web開發領域中,資料庫是不可或缺的組成部分。在選擇資料庫時,常見的選擇是MySQL和PostgreSQL。本文將介紹在Web開發中使用MySQL和PostgreSQL的最佳實踐,並提供一些程式碼範例。一、適用場景MySQL適用於大多數Web應用程序,特別是那些需要高性能、可擴展性和易於使

學習Go語言中的資料庫函數並實作PostgreSQL資料的增刪改查操作 學習Go語言中的資料庫函數並實作PostgreSQL資料的增刪改查操作 Jul 31, 2023 pm 12:54 PM

學習Go語言中的資料庫函數並實作PostgreSQL資料的增刪改查操作在現代的軟體開發中,資料庫是不可或缺的一部分。 Go語言作為一門強大的程式語言,提供了豐富的資料庫操作函數和工具包,可以輕鬆實現資料庫的增刪改查操作。本文將介紹如何學習Go語言中的資料庫函數,並使用PostgreSQL資料庫進行實際的操作。第一步:安裝資料庫驅動程式在Go語言中,每個資料庫

MySQL與PostgreSQL:資料安全與備份策略 MySQL與PostgreSQL:資料安全與備份策略 Jul 13, 2023 pm 03:31 PM

MySQL與PostgreSQL:資料安全與備份策略引言:在現代社會中,資料成為了企業和個人生活中不可或缺的一部分。對於資料庫管理系統來說,資料安全與備份策略是至關重要的,既能保護資料免受遺失或損壞,也能確保恢復資料的可靠性和完整性。本文將重點放在MySQL和PostgreSQL兩種主流關係型資料庫系統的資料安全性和備份策略。一、資料安全性方面:(一)用戶權

如何在PHP程式設計中使用PostgreSQL資料庫? 如何在PHP程式設計中使用PostgreSQL資料庫? Jun 12, 2023 am 09:27 AM

隨著資料庫技術的發展,資料庫管理系統也呈現出多種多樣的選擇,開發人員可以根據自己的需求和喜好選擇最適合自己的資料庫。而PostgreSQL作為一種先進的開源關係型資料庫系統,越來越受到開發人員的關注與使用。那麼,在PHP程式設計中如何使用PostgreSQL資料庫呢?一、安裝和設定PostgreSQL資料庫在使用PostgreSQL之前,需要先安裝並設定它。首先

在Go語言中使用PostgreSQL:完整指南 在Go語言中使用PostgreSQL:完整指南 Jun 18, 2023 am 09:28 AM

Go語言是一種快速、有效率的程式語言,適合建立Web服務和後端應用程式。而PostgreSQL是一個開源的關聯式資料庫管理系統,承諾提供更高的可靠性、可擴展性和資料安全性。在本文中,我們將深入探討如何在Go語言中使用PostgreSQL,並提供一些實用的程式碼範例和技巧。安裝和設定PostgreSQL首先,我們需要安裝和設定PostgreSQL。可以在官方網

MySQL和PostgreSQL:如何優化資料庫查詢效能? MySQL和PostgreSQL:如何優化資料庫查詢效能? Jul 12, 2023 pm 03:15 PM

MySQL和PostgreSQL:如何優化資料庫查詢效能?概述:在開發應用程式時,資料庫查詢效能是一個重要的考慮因素。良好的查詢效能可以提高應用程式的回應速度和使用者體驗。本文將介紹一些最佳化資料庫查詢效能的方法,重點涵蓋MySQL和PostgreSQL兩種常用資料庫。資料庫索引的最佳化:資料庫索引是提高查詢效能的重要因素。索引可以加快資料的查找速度,減少查詢時掃

資料庫容量規劃與擴展:MySQL vs. PostgreSQL 資料庫容量規劃與擴展:MySQL vs. PostgreSQL Jul 12, 2023 pm 01:43 PM

資料庫容量規劃與擴展:MySQLvs.PostgreSQL引言:隨著網際網路的快速發展和大數據時代的到來,資料庫的容量規劃和擴展變得越來越重要。 MySQL和PostgreSQL是兩個流行的關聯式資料庫管理系統(RDBMS),它們在資料庫容量規劃和擴充方面有著不同的特性和適用場景。本文將對這兩個資料庫進行比較,並給出一些程式碼範例來展示它們的差異。一、MySQ

See all articles