最近給某電信公司做了個項(xiàng)目,把原oracle庫遷移到EnterpriseDB之PPAS上,拿回oracle的dump文件忙乎了一圈,想把安裝遷移過程寫一下,就從網(wǎng)上把postgresql的各種安裝過程搬過來,湊個系列。
安裝PostgreSQL數(shù)據(jù)庫不一定需要root用戶權(quán)限,普通用戶也可以。安裝方式有多種,一種是編譯安裝,一種是二進(jìn)制安裝包安裝,還有各種linux系統(tǒng)的包安裝。
一. 源碼編譯安裝
總體流程:
./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.安裝的前提條件
要求一:
要求有GNUmake,版本要大于等于 3.76.1,檢查gmake的方法如下:
gmake --version
要求二:
編譯器要求是兼容ISO/ANSIC的編譯器,遵從C89標(biāo)準(zhǔn)。
如果使用gcc,這兩個條件都能支持。而gcc支持大多數(shù)的UNIX環(huán)境,如Linux、AIX、HPUX、Solaris等。
要求三:
由于源代碼包是.tar.gz或.tar.bz2的格式,所以要求平臺下有能解壓縮源代碼包的tar和gzip工具。
要求四(非強(qiáng)制):
PostgreSQL默認(rèn)是使用GNUReadline庫支持在psql的命令行中可以使用光標(biāo)鍵(↑↓)翻出歷史命令。當(dāng)然如果沒有GNU Readline庫的話,需要增加without-readline選項(xiàng)到./configure命令后,當(dāng)然這樣做后就失去了使用光標(biāo)鍵(↑↓)翻出歷史命令的功能。也可以使用libedit庫(BSD-licensed)提供類似的功能,這時需要在.configure后增加--with-libedit-preferred選項(xiàng)。常用的Linux發(fā)行版本默認(rèn)安裝了時都安裝了GNU Readline庫。下面的命令檢查是否安裝了Readline庫:
[root@osdba/usr/src/postgresql-8.4.3]#rpm -qa |grep readline
readline-5.2-13.fc9.i386
要求五(非強(qiáng)制):
PostgreSQL默認(rèn)使用zlib壓縮庫,主要是pg_dump和pg_restore這兩個導(dǎo)入導(dǎo)出工具使用zlib壓縮庫,指定配置選項(xiàng)--without-zlib可以不使用zlib庫,當(dāng)然這樣pg_dump和pg_restore就沒有了壓縮功能了。
非強(qiáng)制):
要求六(
主要你需要服務(wù)端語言如PL/Perl,PL/PythonPL/Tcl,當(dāng)然你需要安裝Perl、Python、Tcl。
如果你需要PostgreSQL能提示中文,你需要實(shí)現(xiàn)GettextAPI。
3.下載PostgreSQL源碼包
到www.postgresql.org網(wǎng)站上下載源碼包,然后解壓到一個目錄下:
gunzip postgresql-8.4.3.tar.gz
tar xvf postgresql-8.4.3.tar
如果在Linux下,可以一步解壓:
tar zxvfpostgresql-8.4.3.tar.gz
如果是.tar.bz2包:
tar jxvf postgresql-8.4.3.tar.bz2
4.安裝過程
⑴ ./configure
后面可以跟我們前面講過的一些選項(xiàng),如--with-libedit-preferred:
./configure--with-libedit-preferred
后面可以跟很多的選項(xiàng),具體可以參見PostgreSQL提供的官方手冊,這里介紹幾個常用的選項(xiàng):
--prefix=PREFIX:指定安裝PostgreSQL的安裝目前,如果沒有指定,則安裝到/usr/local/pgsql目錄下。
--with-pgport=NUMBER:指定PostgreSQL的監(jiān)聽端口,默認(rèn)為5432
--with-wal-segsize=SEGSIZE:指定WAL日志文件的大小。
--with-wal-blocksize=BLOCKSIZE:指定WAL日志的塊大小。
--enable-thread-safety:允許客戶端的庫函數(shù)是線程安全的。
執(zhí)行的時候可能報:
configure: error: readline library not found
這是因?yàn)閞eadline沒有安裝,只要安裝這個庫就可以了,如在ubuntu10.04下可以:
aptitude install libreadline6-dev
⑵ 編譯源代碼
gmake
有可能你的機(jī)器的沒有g(shù)make命令,而make就是gnu make,這時運(yùn)行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:
regsvr32pgsql_library_directory/pgevent.dll
⑷ 卸載
gmake uninstall
5.設(shè)置環(huán)境變量和共享庫路徑和可執(zhí)行文件路徑
可以把下面的內(nèi)容添加到UNIX用戶的~/.bash_profile或~/.profile文件中,或如果對所有用戶生效,可以添加到/etc/profile文件中:
在Bourne shells (sh,ksh,bash,zsh):
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 incshortcsh:
setenv LD_LIBRARY_PATH /usr/local/pgsql/lib
set path = ( /usr/local/pgsql/bin $path )
在BSD/OS,Linux, orSunOS 4平臺下,使用root用戶執(zhí)行:
/sbin/ldconfig /usr/local/pgsql/lib
On FreeBSD, NetBSD, and OpenBSD:
/sbin/ldconfig -m /usr/local/pgsql/lib
6.安裝contrib目錄下的一些工具
源代碼目錄下有一個contrib目錄,是一些第三方組織貢獻(xiàn)出來的一些工具代碼,這些工具在日常維護(hù)中也很有用,建議安裝上。
cd /usr/src/postgresql-8.4.3/contrib
make
make install
7.創(chuàng)建數(shù)據(jù)庫
建postgres用戶:
useradd -m -u 701 postgres
建postgres數(shù)據(jù)庫的目錄,假設(shè)數(shù)據(jù)庫建在/opt/pgdata目錄下:
mkdir /opt/pgdata
chown postgres:postgres /opt/pgdata
在postgres用戶下的.bash_profile文件中添加如下內(nèi)容,方便以后啟動數(shù)據(jù)庫和關(guān)閉數(shù)據(jù)庫:
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的數(shù)據(jù)庫,注意設(shè)置LANG環(huán)境變量為utf8的,把下面的內(nèi)容加到.bash_profile文件中:
export LANG=en_US.utf8
初使化數(shù)據(jù)庫目錄:
su - postgres
/usr/local/pgsql/bin/initdb -D $PGDATA
修改數(shù)據(jù)庫參數(shù):
按需要修改$PGDATA/postgresql.conf中的參數(shù),如:
logging_collector = on
log_rotation_age = 1d
log_rotation_size = 10MB
啟動數(shù)據(jù)庫:
/usr/local/pgsql/bin/pg_ctl -D$PGDATAstart
這時就可以進(jìn)入psql命令行了:
[postgres@pghostpgdata]$ psql
psql (8.4.3)
Type "help" for help.
postgres=#
這時可以創(chuàng)建用戶數(shù)據(jù)庫了:
CREATE DATABASEmydb
二. 圖形安裝:
該部分介紹 PostgreSQL 程序的安裝過程?;?SuperMap 的 SDX+ for PostgreSQL 對 PostgreSQL 8.2版本不支持,建議安裝 PostgreSQL 8.3 及以上版本。
安裝首頁
打開 PostgreSQL 產(chǎn)品的安裝目錄后,雙擊“postgresql-9.0.2-1-windows.exe”程序,出現(xiàn)如下圖所示的 PostgreSQL 安裝首頁,單擊“Next”按鈕繼續(xù)安裝。
![]() |
| 圖:PostgreSQL 安裝首頁 |
指定安裝目錄
如下圖所示,指定 PostgreSQL 的安裝目錄。然后,單擊“Next”按鈕繼續(xù)安裝。
![]() |
| 圖:指定安裝目錄 |
安裝 PostgreSQL 的分區(qū)最好是 NTFS 格式的。PostgreSQL 首要任務(wù)是要保證數(shù)據(jù)的完整性,而 FAT 和 FAT32 文件系統(tǒng)不能提供這樣的可靠性保障,而且 FAT 文件系統(tǒng)缺乏安全性保障,無法保證原始數(shù)據(jù)在未經(jīng)授權(quán)的情況下被更改。此外,PostgreSQL 所使用的"多分點(diǎn)"功能完成表空間的這一特征在FAT文件系統(tǒng)下無法實(shí)現(xiàn)。
然而,在某些系統(tǒng)中,只有一種 FAT 分區(qū),這種情況下,可以正常安裝 PostgreSQL,但不要進(jìn)行數(shù)據(jù)庫的初始化工作。安裝完成后,在 FAT 分區(qū)上手動執(zhí)行 initdb.exe 程序即可,但不能保證其安全性和可靠性,并且建立表空間也會失敗。
指定數(shù)據(jù)存儲目錄
如下圖所示,為數(shù)據(jù)庫存儲區(qū)域指定安裝區(qū)域。然后,單擊“Next”按鈕繼續(xù)安裝。
![]() |
| 圖:指定數(shù)據(jù)存儲目錄 |
設(shè)置數(shù)據(jù)庫超級用戶和服務(wù)賬戶的密碼
數(shù)據(jù)庫超級用戶是一個非管理員賬戶,這是為了減少黑客利用在 PostgreSQL 發(fā)現(xiàn)的缺陷對系統(tǒng)造成損害,因此需要對數(shù)據(jù)庫超級用戶設(shè)置密碼,如下圖所示,安裝程序自動建立的服務(wù)用戶的用戶名默認(rèn)為 postgres。然后,單擊“Next”按鈕繼續(xù)安裝。
![]() |
| 圖:設(shè)置服務(wù)賬戶的密碼 |
設(shè)置服務(wù)監(jiān)聽端口
如下圖所示,指定數(shù)據(jù)庫服務(wù)器的端口,默認(rèn)是“5432”,用戶可根據(jù)自己端口的使用情況進(jìn)行設(shè)置。然后,單擊“Next”按鈕繼續(xù)安裝。
![]() |
| 圖:設(shè)置服務(wù)監(jiān)聽端口 |
選擇運(yùn)行時語言環(huán)境
如下圖所示,選擇數(shù)據(jù)庫存儲區(qū)域的運(yùn)行時語言環(huán)境。然后,單擊“Next”按鈕,進(jìn)入安裝進(jìn)度頁面,等待 PostgreSQL 安裝完畢。
注意,在選擇語言環(huán)境時,若選擇"default locale"會導(dǎo)致安裝不正確;同時,PostgreSQL 不支持 GBK 和 GB18030 作為字符集,如果選擇其它四個中文字符集:中文繁體 香港(Chinese[Traditional], Hong Kong S.A.R.)、中文簡體 新加坡(Chinese[Simplified], Singapore)、中文繁體 臺灣(Chinese[Traditional], Taiwan)和中文繁體 澳門(Chinese[Traditional], Marco S.A.R.),會導(dǎo)致查詢結(jié)果和排序效果不正確。建議選擇"C",即不使用區(qū)域。
![]() |
| 圖:選擇運(yùn)行時語言環(huán)境 |
![]() |
| 圖:安裝進(jìn)度頁面 |
結(jié)束安裝
上面的安裝步驟執(zhí)行完成后,會彈出如下圖所示的完成對話框。這里可以選擇安裝完成后是否運(yùn)行 Stack Builder 向?qū)戆惭b附加軟件,以完善 PostgreSQL 的安裝。該操作必須在聯(lián)網(wǎng)狀態(tài)下執(zhí)行。
![]() |
| 圖:結(jié)束安裝 |
三. 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數(shù)據(jù)文件存放目錄并設(shè)置postgresql用戶訪問權(quán)限
mkdir postgresql
cd postgresql
mkdir data
chown -R postgresql:postgresql /postgresql
chmod -R 775 /postgresql
四.設(shè)置環(huán)境postgresql環(huán)境變量
# 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
五.啟動數(shù)據(jù)庫引擎
1.進(jìn)入postgresql
su - postgresql
2.啟動數(shù)據(jù)庫引擎
initdb
----------------------------------------------數(shù)據(jù)庫創(chuàng)建成功時提示--------------------------------------
[postgresql@datatest~]$ initdb
屬于此數(shù)據(jù)庫系統(tǒng)的文件宿主為用戶 "postgresql".
此用戶也必須為服務(wù)器進(jìn)程的宿主.
數(shù)據(jù)庫簇將帶有 locale zh_CN.UTF-8 初始化.
默認(rèn)的數(shù)據(jù)庫編碼已經(jīng)相應(yīng)的設(shè)置為 UTF8.
修復(fù)已存在目錄 /postgresql/data 的權(quán)限 ... 成功
創(chuàng)建目錄 /postgresql/data/global ... 成功
創(chuàng)建目錄 /postgresql/data/pg_xlog ... 成功
創(chuàng)建目錄 /postgresql/data/pg_xlog/archive_status ... 成功
創(chuàng)建目錄 /postgresql/data/pg_clog ... 成功
創(chuàng)建目錄 /postgresql/data/pg_subtrans ... 成功
創(chuàng)建目錄 /postgresql/data/pg_twophase ... 成功
創(chuàng)建目錄 /postgresql/data/pg_multixact/members ... 成功
創(chuàng)建目錄 /postgresql/data/pg_multixact/offsets ... 成功
創(chuàng)建目錄 /postgresql/data/base ... 成功
創(chuàng)建目錄 /postgresql/data/base/1 ... 成功
創(chuàng)建目錄 /postgresql/data/pg_tblspc ... 成功
選擇默認(rèn)最大聯(lián)接數(shù) (max_connections) ... 100
選擇默認(rèn)共享緩沖區(qū)大小 (shared_buffers) ... 1000
創(chuàng)建配置文件 ... 成功
在 /postgresql/data/base/1 中創(chuàng)建 template1 數(shù)據(jù)庫 ... 成功
initializing pg_authid ... 成功
啟動不限制系統(tǒng)表行大小 ... 成功
initializing dependencies ... 成功
創(chuàng)建系統(tǒng)視圖 ... 成功
加載 pg_description ... 成功
創(chuàng)建字符集轉(zhuǎn)換 ... 成功
對內(nèi)建對象設(shè)置權(quán)限 ... 成功
創(chuàng)建信息模式 ... 成功
清理數(shù)據(jù)庫 template1 ... 成功
拷貝 template1 到 template0 ... 成功
copying template1 to postgres ... 成功
警告: 為本地連接啟動了 "trust" 認(rèn)證.
你可以通過編輯 pg_hba.conf 更改或你下
次運(yùn)行 initdb 時使用 -A 選項(xiàng).
Success. You can now start the database server using:
postmaster -D /postgresql/data
or
pg_ctl -D /postgresql/data -l logfile start
六.啟動數(shù)據(jù)庫
1.root用戶下運(yùn)行
如在root用戶下啟動則需要將啟動文件中默認(rèn)的PGDATA和PGPORT變量值修改。
/etc/init.d/postgresql-版本號 start
2.postgres用戶下運(yùn)行
pg_ctl -D /postgresql/data -l logfile start
七.建立數(shù)據(jù)庫
createdb MTPS
八.進(jìn)入pssql交互工具
psql MTPS
九.執(zhí)行數(shù)據(jù)庫操作
create table test(i varchar(10));
十.退出pssql
/q
十一.設(shè)置外端連接
1)修改postgresql.conf配置文件
vi /postgresql/data/postgresql.conf
將#listen_addresses=’localhost’修改為listen_addresses=‘*’
啟用默認(rèn)端口
2)在pg_hba.conf中設(shè)置可連接客戶端IP
vi /postgresql/datapg_hba.conf
添加host all all 192.168.10.0/24 true
3)重啟數(shù)據(jù)庫
四. ubantu上包安裝:
安裝環(huán)境:
Ubuntu 10.04-desktop-i386
PostgreSQL 8.4
1. 安裝PostgreSQL
輸入如下命令
sudo apt-get install postgresql
系統(tǒng)會提示安裝所需磁盤空間,輸入"y",安裝程序會自動完成。 安裝完畢后,系統(tǒng)會創(chuàng)建一個數(shù)據(jù)庫超級用戶“postgres”, 密碼為空。這個用戶既是不可登錄的操作系統(tǒng)用戶,也是數(shù)據(jù)庫用戶。
2. 修改Linux用戶postgres的密碼
輸入如下命令
sudo passwd postgres
3. 修改數(shù)據(jù)庫超級用戶postgres的密碼
1) 切換到Linux下postgres用戶
sudo su postgres
2) 登錄postgres數(shù)據(jù)庫
psql postgres
這樣你會看到postgres提示信息如下:
psql (8.4.4)
Type "help" for help.
并出現(xiàn)postgres的命令行提示符號:
postgres=#
3) 輸入如下命令
ALTER USER postgres with PASSWORD 'password'
鍵入“exit”返回到Linux命令行。
4. 添加自己定義的用戶和數(shù)據(jù)庫
1) 添加新用戶
createuser -drSP fedoraAdmin
按照提示輸入該用戶的密碼。
2) 創(chuàng)建一個屬于自定義用戶fedoraAdmin的數(shù)據(jù)庫
createdb -O fedoraAdmin mydb
通過如上設(shè)置,可以在Java中通過以下配置來連接PostgresSQL數(shù)據(jù)庫
user:fedoraAdmin
password: your password
url: jdbc:postgresql://localhost:5432/mydb
5. 安裝pgAdmin3
1) 鍵入如下命令安裝pgAdmin3
sudo apt-get install pgadmin3
2) 鍵入如下命令運(yùn)行pgAdmin3
pgadmin3
你就會看到pgAdmin3的主界面如下所示:
添加相應(yīng)的參數(shù)以創(chuàng)建一個到PostgreSql的連接:
6. 設(shè)置其它機(jī)器上對postgres的訪問
修改/etc/postgresql/8.4/main/pg_hba.conf:
host all all 0.0.0.0/0 md5 #0.0.0.0為地址段,0為多少二進(jìn)制位
例如:192.168.0.0/16代表192.168.0.1-192.168.255.254
修改/etc/postgresql/8.4/main/postgresql.conf
listen_address = '*'
重啟數(shù)據(jù)庫
sudo /etc/init.d/postgresql-8.4 restart
新聞熱點(diǎn)
疑難解答
圖片精選