postgresql的安裝

最近給某電信公司做了個項目,把原oracle庫遷移到EnterpriseDB之PPAS上,拿回oracle的dump文件忙乎了一圈,想把安裝遷移過程寫一下,就從網上把postgresql的各種安裝過程搬過來,湊個系列。
 

安裝PostgreSQL數據庫不一定需要root用戶權限,普通用戶也可以。安裝方式有多種,一種是編譯安裝,一種是二進制安裝包安裝,還有各種linux系統的包安裝。

一. 源碼編譯安裝
總體流程:
./configure
gmake
su
gmake install
adduser postgres
mkdir /usr/local/pgsql/data
chown postgres /usr/local/pgsql/data
su - postgres
/usr/local/pgsql/bin/initdb -D /usr/local/pgsql/data
/usr/local/pgsql/bin/postgres -D /usr/local/pgsql/data >logfile 2>&1 &
/usr/local/pgsql/bin/createdb test
/usr/local/pgsql/bin/psql test
 
2.安裝的前提條件
要求一:
要求有GNU  make,版本要大於等於 3.76.1,檢查gmake的方法如下:
gmake --version
 
要求二:
編譯器要求是兼容ISO/ANSI C 的編譯器,遵從C89標準。
如果使用gcc,這兩個條件都能支持。而gcc支持大多數的UNIX環境,如Linux、AIX、HPUX、Solaris等。
 
要求三:
由於源代碼包是.tar.gz或.tar.bz2的格式,所以要求平臺下有能解壓縮源代碼包的tar和gzip工具。
 
要求四(非強制):
PostgreSQL默認是使用GNU Readline庫支持在psql的命令行中可以使用光標鍵(↑↓)翻出歷史命令。當然如果沒有GNU Readline庫的話,需要增加without-readline 選項到./configure命令後,當然這樣做後就失去了使用光標鍵(↑↓)翻出歷史命令的功能。也可以使用libedit庫(BSD-licensed)提供類似的功能,這時需要在.configure後增加--with-libedit-preferred 選項。常用的Linux發行版本默認安裝了時都安裝了GNU Readline庫。下面的命令檢查是否安裝了Readline庫:
[[email protected] /usr/src/postgresql-8.4.3]#rpm -qa |grep readline
readline-5.2-13.fc9.i386
 
要求五(非強制):
PostgreSQL默認使用zlib壓縮庫,主要是pg_dump和pg_restore這兩個導入導出工具使用zlib壓縮庫,指定配置選項--without-zlib可以不使用zlib庫,當然這樣pg_dump和pg_restore就沒有了壓縮功能了。
 
要求六(非強制):
主要你需要服務端語言如PL/Perl ,PL/Python PL/Tcl ,當然你需要安裝Perl、Python、Tcl。
如果你需要PostgreSQL能提示中文,你需要實現Gettext API。
 
3.下載PostgreSQL源碼包
www.postgresql.org網站上下載源碼包,然後解壓到一個目錄下:
gunzip postgresql-8.4.3.tar.gz
tar xvf postgresql-8.4.3.tar
如果在Linux下,可以一步解壓:
tar zxvf postgresql-8.4.3.tar.gz
如果是.tar.bz2包:
tar jxvf postgresql-8.4.3.tar.bz2
 
 
4.安裝過程
⑴ ./configure
後面可以跟我們前面講過的一些選項,如--with-libedit-preferred :
./configure --with-libedit-preferred
後面可以跟很多的選項,具體可以參見PostgreSQL提供的官方手冊,這裏介紹幾個常用的選項:
--prefix=PREFIX:指定安裝PostgreSQL的安裝目前,如果沒有指定,則安裝到/usr/local/pgsql目錄下。
--with-pgport=NUMBER:指定PostgreSQL的監聽端口,默認爲5432
--with-wal-segsize=SEGSIZE: 指定WAL日誌文件的大小。
--with-wal-blocksize=BLOCKSIZE:指定WAL日誌的塊大小。
--enable-thread-safety:允許客戶端的庫函數是線程安全的。
執行的時候可能報:
configure: error: readline library not found
這是因爲readline沒有安裝,只要安裝這個庫就可以了,如在ubuntu10.04下可以:
aptitude install libreadline6-dev
 
⑵ 編譯源代碼
gmake
有可能你的機器的沒有gmake命令,而make就是gnu make,這時運行make編譯:
make
 
⑶ 安裝編譯生成的文件
gmake install
 
如果僅安裝客戶端程序:
gmake -C src/bin install gmake -C src/include install gmake -C src/interfaces install gmake -C doc install
如果是在windows平臺,可以註冊event log:
regsvr32 pgsql_library_directory/pgevent.dll
 
⑷ 卸載
gmake uninstall
 
 
5.設置環境變量和共享庫路徑和可執行文件路徑
可以把下面的內容添加到UNIX用戶的~/.bash_profile或~/.profile文件中,或如果對所有用戶生效,可以添加到/etc/profile文件中:
 
在Bourne shells (shkshbashzsh):
LD_LIBRARY_PATH=/usr/local/pgsql/lib export LD_LIBRARY_PATH
PATH=/usr/local/pgsql/bin:$PATH export PATH
MANPATH=/usr/local/pgsql/man:$MANPATH export MANPATH

or in csh or tcsh:

setenv LD_LIBRARY_PATH /usr/local/pgsql/lib
set path = ( /usr/local/pgsql/bin $path )
 

BSD/OSLinux, or SunOS 4平臺下,使用root用戶執行:

/sbin/ldconfig /usr/local/pgsql/lib
On FreeBSD, NetBSD, and OpenBSD:
/sbin/ldconfig -m /usr/local/pgsql/lib
 
6.安裝contrib目錄下的一些工具
源代碼目錄下有一個contrib目錄,是一些第三方組織貢獻出來的一些工具代碼,這些工具在日常維護中也很有用,建議安裝上。
cd /usr/src/postgresql-8.4.3/contrib
make
make install
 
7.創建數據庫
建postgres用戶:
useradd -m -u 701 postgres
建postgres數據庫的目錄,假設數據庫建在/opt/pgdata目錄下:
mkdir /opt/pgdata
chown postgres:postgres /opt/pgdata
 
在postgres用戶下的.bash_profile文件中添加如下內容,方便以後啓動數據庫和關閉數據庫:
su - postgres
export PGDATA=/opt/pgdata
alias pgstart='pg_ctl -D $PGDATA start'
alias pgstop='pg_ctl kill INT `head -1 $PGDATA/postmaster.pid`'
如果你要建utf8的數據庫,注意設置LANG環境變量爲utf8的,把下面的內容加到.bash_profile文件中:
export LANG=en_US.utf8
 
初使化數據庫目錄:
su - postgres
/usr/local/pgsql/bin/initdb -D $PGDATA
 
修改數據庫參數:
按需要修改$PGDATA/postgresql.conf中的參數,如:
logging_collector = on
log_rotation_age = 1d

log_rotation_size = 10MB

啓動數據庫:
/usr/local/pgsql/bin/pg_ctl -D $PGDATA start

這時就可以進入psql命令行了:
[[email protected] pgdata]$ psql
psql (8.4.3)
Type "help" for help.

postgres=#

這時可以創建用戶數據庫了:

CREATE DATABASE mydb

 

二. 圖形安裝:

該部分介紹 PostgreSQL 程序的安裝過程。基於 SuperMap 的 SDX+ for PostgreSQL 對 PostgreSQL 8.2版本不支持,建議安裝 PostgreSQL 8.3 及以上版本。

  1. 安裝首頁

    打開 PostgreSQL 產品的安裝目錄後,雙擊「postgresql-9.0.2-1-windows.exe」程序,出現如下圖所示的 PostgreSQL 安裝首頁,單擊「Next」按鈕繼續安裝。

    圖:PostgreSQL 安裝首頁
  2. 指定安裝目錄

    如下圖所示,指定 PostgreSQL 的安裝目錄。然後,單擊「Next」按鈕繼續安裝。

    圖:指定安裝目錄

    安裝 PostgreSQL 的分區最好是 NTFS 格式的。PostgreSQL 首要任務是要保證數據的完整性,而 FAT 和 FAT32 文件系統不能提供這樣的可靠性保障,而且 FAT 文件系統缺乏安全性保障,無法保證原始數據在未經授權的情況下被更改。此外,PostgreSQL 所使用的"多分點"功能完成表空間的這一特徵在FAT文件系統下無法實現。

    然而,在某些系統中,只有一種 FAT 分區,這種情況下,可以正常安裝 PostgreSQL,但不要進行數據庫的初始化工作。安裝完成後,在 FAT 分區上手動執行 initdb.exe 程序即可,但不能保證其安全性和可靠性,並且建立表空間也會失敗。

  3. 指定數據存儲目錄

    如下圖所示,爲數據庫存儲區域指定安裝區域。然後,單擊「Next」按鈕繼續安裝。

    圖:指定數據存儲目錄
  4. 設置數據庫超級用戶和服務賬戶的密碼

    數據庫超級用戶是一個非管理員賬戶,這是爲了減少黑客利用在 PostgreSQL 發現的缺陷對系統造成損害,因此需要對數據庫超級用戶設置密碼,如下圖所示,安裝程序自動建立的服務用戶的用戶名默認爲 postgres。然後,單擊「Next」按鈕繼續安裝。

    圖:設置服務賬戶的密碼
  5. 設置服務監聽端口

    如下圖所示,指定數據庫服務器的端口,默認是「5432」,用戶可根據自己端口的使用情況進行設置。然後,單擊「Next」按鈕繼續安裝。

    圖:設置服務監聽端口
  6. 選擇運行時語言環境

    如下圖所示,選擇數據庫存儲區域的運行時語言環境。然後,單擊「Next」按鈕,進入安裝進度頁面,等待 PostgreSQL 安裝完畢。

    注意,在選擇語言環境時,若選擇"default locale"會導致安裝不正確;同時,PostgreSQL 不支持 GBK 和 GB18030 作爲字符集,如果選擇其它四個中文字符集:中文繁體 香港(Chinese[Traditional], Hong Kong S.A.R.)、中文簡體 新加坡(Chinese[Simplified], Singapore)、中文繁體 臺灣(Chinese[Traditional], Taiwan)和中文繁體 澳門(Chinese[Traditional], Marco S.A.R.),會導致查詢結果和排序效果不正確。建議選擇"C",即不使用區域。

    圖:選擇運行時語言環境
    圖:安裝進度頁面
  7. 結束安裝

    上面的安裝步驟執行完成後,會彈出如下圖所示的完成對話框。這裏可以選擇安裝完成後是否運行 Stack Builder 嚮導來安裝附加軟件,以完善 PostgreSQL 的安裝。該操作必須在聯網狀態下執行。

    圖:結束安裝

 

三. redhat上包安裝:

一.安裝postgresql
   需要包:
       1. rpm -ivh postgresql-libs
       2. rpm -ivh postgresql
       3. rpm -ivh postgresql-server
       4. rpm -ivh postgresql-contrib
       5. rpm -ivh postgresql-devel
二.建立postgresql用戶
   useradd postgres
   passwd postgres
三.建立postgresql數據文件存放目錄並設置postgresql用戶訪問權限
   mkdir postgresql
   cd postgresql
   mkdir data
   chown -R postgresql:postgresql /postgresql
   chmod -R 775 /postgresql
四.設置環境postgresql環境變量
   # vi ~postgresql/.bash_profile
   添加:

   PGLIB=/usr/pgsql-版本號/lib
  
   PGDATA=/postgresql/data
   PATH=/usr/pgsql-版本號/bin:$PATH
   MANPATH=$MANPATH:/usr/pgsql-版本號
   export PGLIB PGDATA PATH MANPATH
五.啓動數據庫引擎
   1.進入postgresql
    su - postgresql
   2.啓動數據庫引擎
    initdb  

----------------------------------------------數據庫創建成功時提示--------------------------------------
[[email protected] ~]$ initdb
屬於此數據庫系統的文件宿主爲用戶 "postgresql".
此用戶也必須爲服務器進程的宿主.
數據庫簇將帶有 locale zh_CN.UTF-8 初始化.
默認的數據庫編碼已經相應的設置爲 UTF8.

修復已存在目錄 /postgresql/data 的權限 ... 成功
創建目錄 /postgresql/data/global ... 成功
創建目錄 /postgresql/data/pg_xlog ... 成功
創建目錄 /postgresql/data/pg_xlog/archive_status ... 成功
創建目錄 /postgresql/data/pg_clog ... 成功
創建目錄 /postgresql/data/pg_subtrans ... 成功
創建目錄 /postgresql/data/pg_twophase ... 成功
創建目錄 /postgresql/data/pg_multixact/members ... 成功
創建目錄 /postgresql/data/pg_multixact/offsets ... 成功
創建目錄 /postgresql/data/base ... 成功
創建目錄 /postgresql/data/base/1 ... 成功
創建目錄 /postgresql/data/pg_tblspc ... 成功
選擇默認最大聯接數 (max_connections) ... 100
選擇默認共享緩衝區大小 (shared_buffers) ... 1000
創建配置文件 ... 成功
在 /postgresql/data/base/1 中創建 template1 數據庫 ... 成功
initializing pg_authid ... 成功
啓動不限制系統錶行大小 ... 成功
initializing dependencies ... 成功
創建系統視圖 ... 成功
加載 pg_description ... 成功
創建字符集轉換 ... 成功
對內建對象設置權限 ... 成功
創建信息模式 ... 成功
清理數據庫 template1 ... 成功
拷貝 template1 到 template0 ... 成功
copying template1 to postgres ... 成功

警告: 爲本地連接啓動了 "trust" 認證.
你可以通過編輯 pg_hba.conf 更改或你下
次運行 initdb 時使用 -A 選項.

Success. You can now start the database server using:

    postmaster -D /postgresql/data
or
    pg_ctl -D /postgresql/data -l logfile start

 

六.啓動數據庫
   1.root用戶下運行
     如在root用戶下啓動則需要將啓動文件中默認的PGDATA和PGPORT變量值修改。
    /etc/init.d/postgresql-版本號 start
   2.postgres用戶下運行
   pg_ctl -D /postgresql/data -l logfile start

七.建立數據庫

   createdb MTPS
八.進入pssql交互工具

   psql MTPS

九.執行數據庫操作
   create table test(i varchar(10));

十.退出pssql
  \q

十一.設置外端連接
   1)修改postgresql.conf配置文件
   
   vi /postgresql/data/postgresql.conf
   將#listen_addresses=’localhost’修改爲listen_addresses=‘*’
   啓用默認端口

   2)在pg_hba.conf中設置可連接客戶端IP
   vi /postgresql/datapg_hba.conf
   添加host  all   all  192.168.10.0/24   true
  
   3)重啓數據庫

 

四. ubantu上包安裝:

安裝環境:

      Ubuntu 10.04-desktop-i386

      PostgreSQL 8.4

 

1. 安裝PostgreSQL

  輸入如下命令

 sudo apt-get install postgresql

 

系統會提示安裝所需磁盤空間,輸入"y",安裝程序會自動完成。 安裝完畢後,系統會創建一個數據庫超級用戶「postgres」, 密碼爲空。這個用戶既是不可登錄的操作系統用戶,也是數據庫用戶。

 

2. 修改Linux用戶postgres的密碼

  輸入如下命令

 sudo passwd postgres

3. 修改數據庫超級用戶postgres的密碼

1) 切換到Linux下postgres用戶

 sudo su postgres

2) 登錄postgres數據庫

 

psql postgres

這樣你會看到postgres提示信息如下:

psql (8.4.4)

Type "help" for help.

並出現postgres的命令行提示符號:

postgres=#

3) 輸入如下命令

 ALTER USER postgres with PASSWORD 'password'

 鍵入「exit」返回到Linux命令行。

 

4. 添加自己定義的用戶和數據庫

1) 添加新用戶

 createuser -drSP fedoraAdmin

   按照提示輸入該用戶的密碼。

2) 創建一個屬於自定義用戶fedoraAdmin的數據庫

 createdb -O fedoraAdmin mydb

通過如上設置,可以在Java中通過以下配置來連接PostgresSQL數據庫

user:fedoraAdmin

password: your password

url: jdbc:postgresql://localhost:5432/mydb

 

5. 安裝pgAdmin3

1) 鍵入如下命令安裝pgAdmin3

 sudo apt-get install pgadmin3

2) 鍵入如下命令運行pgAdmin3 

 pgadmin3

 你就會看到pgAdmin3的主界面如下所示:

添加相應的參數以創建一個到PostgreSql的連接:

6. 設置其它機器上對postgres的訪問

修改/etc/postgresql/8.4/main/pg_hba.conf:

host all all 0.0.0.0/0 md5  #0.0.0.0爲地址段,0爲多少二進制位

例如:192.168.0.0/16代表192.168.0.1-192.168.255.254

 

修改/etc/postgresql/8.4/main/postgresql.conf

listen_address = '*'

 

重啓數據庫

sudo /etc/init.d/postgresql-8.4 restart