亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > PostgreSQL > 正文

postgresql的安裝 深入理解postgresql

2020-03-12 23:54:27
字體:
來源:轉載
供稿:網友

最近給某電信公司做了個項目,把原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.安裝的前提條件

要求一:

要求有GNUmake,版本要大于等于 3.76.1,檢查gmake的方法如下:

gmake --version

要求二:

編譯器要求是兼容ISO/ANSIC的編譯器,遵從C89標準。

如果使用gcc,這兩個條件都能支持。而gcc支持大多數的UNIX環境,如Linux、AIX、HPUX、Solaris等。

要求三:

由于源代碼包是.tar.gz或.tar.bz2的格式,所以要求平臺下有能解壓縮源代碼包的tar和gzip工具。

要求四(非強制):

PostgreSQL默認是使用GNUReadline庫支持在psql的命令行中可以使用光標鍵(↑↓)翻出歷史命令。當然如果沒有GNU Readline庫的話,需要增加without-readline選項到./configure命令后,當然這樣做后就失去了使用光標鍵(↑↓)翻出歷史命令的功能。也可以使用libedit庫(BSD-licensed)提供類似的功能,這時需要在.configure后增加--with-libedit-preferred選項。常用的Linux發行版本默認安裝了時都安裝了GNU Readline庫。下面的命令檢查是否安裝了Readline庫:

[root@osdba/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/PythonPL/Tcl,當然你需要安裝Perl、Python、Tcl。

如果你需要PostgreSQL能提示中文,你需要實現GettextAPI。

3.下載PostgreSQL源碼包

到www.postgresql.org網站上下載源碼包,然后解壓到一個目錄下:

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

后面可以跟我們前面講過的一些選項,如--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:

regsvr32pgsql_library_directory/pgevent.dll

⑷ 卸載

gmake uninstall

5.設置環境變量和共享庫路徑和可執行文件路徑

可以把下面的內容添加到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用戶執行:

/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$PGDATAstart

這時就可以進入psql命令行了:

[postgres@pghostpgdata]$ psql

psql (8.4.3)

Type "help" for help.

postgres=#

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

CREATE DATABASEmydb

二. 圖形安裝:

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

安裝首頁

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

postgresql的安裝 深入理解postgresql
圖:PostgreSQL 安裝首頁

指定安裝目錄

如下圖所示,指定 PostgreSQL 的安裝目錄。然后,單擊“Next”按鈕繼續安裝。

postgresql的安裝 深入理解postgresql
圖:指定安裝目錄

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

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

指定數據存儲目錄

如下圖所示,為數據庫存儲區域指定安裝區域。然后,單擊“Next”按鈕繼續安裝。

postgresql的安裝 深入理解postgresql
圖:指定數據存儲目錄

設置數據庫超級用戶和服務賬戶的密碼

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

postgresql的安裝 深入理解postgresql
圖:設置服務賬戶的密碼

設置服務監聽端口

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

postgresql的安裝 深入理解postgresql
圖:設置服務監聽端口

選擇運行時語言環境

如下圖所示,選擇數據庫存儲區域的運行時語言環境。然后,單擊“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",即不使用區域。

postgresql的安裝 深入理解postgresql
圖:選擇運行時語言環境
postgresql的安裝 深入理解postgresql
圖:安裝進度頁面

結束安裝

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

postgresql的安裝 深入理解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

----------------------------------------------數據庫創建成功時提示--------------------------------------

[postgresql@datatest~]$ 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的安裝 深入理解postgresql

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

postgresql的安裝 深入理解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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美激情一区二区三区久久久| 亚州国产精品久久久| 久久久久久久影院| 国产91色在线免费| 97精品伊人久久久大香线蕉| 国产精品久久久久久久久久| 九九久久久久99精品| 日韩av在线一区| 日本sm极度另类视频| 久久人人爽人人| 91社区国产高清| 久色乳综合思思在线视频| 亚洲成年人在线播放| 91chinesevideo永久地址| 亚洲国产精品成人一区二区| 日韩有码在线视频| 最新的欧美黄色| www.欧美免费| 国产成人综合av| 国产成人综合av| 国产精品国产三级国产专播精品人| 国产精品狼人色视频一区| 精品一区二区三区电影| 久久久之久亚州精品露出| 日韩高清电影免费观看完整| 久久久久久久久久久免费精品| 日韩欧美成人免费视频| 精品自在线视频| 亚洲色图13p| 国产精品一区二区在线| 精品毛片网大全| 国产精品爽爽爽爽爽爽在线观看| 亚洲成人av中文字幕| 欧美丰满老妇厨房牲生活| 好吊成人免视频| 中文字幕日韩欧美在线| 精品国产一区二区三区四区在线观看| 国产精品第一第二| 国产成人91久久精品| 韩日欧美一区二区| 亚洲国产高清高潮精品美女| 久久99热精品这里久久精品| 亚洲视频axxx| 欧美劲爆第一页| 日韩精品久久久久| 久久精品中文字幕| 成人在线视频网站| 91在线免费看网站| 欧美www在线| 国产精品偷伦一区二区| 日韩精品在线观看一区二区| 欧美日韩一区二区免费视频| 久久精品亚洲一区| 亚洲欧美综合图区| 日韩免费看的电影电视剧大全| 国产精品久久网| 狠狠久久五月精品中文字幕| 精品国产乱码久久久久酒店| 一个人www欧美| 欧美视频中文字幕在线| 欧美成人性色生活仑片| 亚洲石原莉奈一区二区在线观看| 日韩欧美成人免费视频| 久久久久这里只有精品| 国产精品一区久久| 国外成人在线播放| 亚洲一区亚洲二区亚洲三区| 久久国产精品99国产精| 亚洲精品网站在线播放gif| 一区二区三区在线播放欧美| 国产精品福利在线观看网址| 日韩av在线网| 精品人伦一区二区三区蜜桃网站| 久久99热精品这里久久精品| 成人欧美在线视频| 久久精品男人天堂| 热久久视久久精品18亚洲精品| 国产日韩在线视频| 亚洲成人av在线| 日韩在线观看电影| 国产精欧美一区二区三区| 91亚洲一区精品| 亚洲欧洲一区二区三区久久| 亚洲激情中文字幕| 久久久91精品国产| 欧美国产精品人人做人人爱| 亚洲自拍偷拍在线| 欧美性极品xxxx娇小| 亚洲成人av在线播放| 国产精品专区第二| 亚洲视频一区二区三区| 亚洲午夜女主播在线直播| 亚洲欧美日韩国产成人| 日韩欧美成人网| 高清亚洲成在人网站天堂| 日韩亚洲欧美成人| 欧美性69xxxx肥| 日本精品一区二区三区在线播放视频| 色妞在线综合亚洲欧美| 热久久这里只有精品| 在线播放国产一区中文字幕剧情欧美| 国产精品视频久久久| 亚洲mm色国产网站| 亚洲综合第一页| 日韩中文综合网| 亲爱的老师9免费观看全集电视剧| 亚洲片国产一区一级在线观看| 亚洲国产精品国自产拍av秋霞| 亚洲精品一区av在线播放| 欧美午夜精品久久久久久人妖| 久久成人av网站| 亚洲午夜精品视频| 亚洲男人第一网站| 成人黄色大片在线免费观看| 欧美性理论片在线观看片免费| 欧美又大又硬又粗bbbbb| 欧美高清激情视频| 日本成人免费在线| 国内揄拍国内精品少妇国语| 2019中文字幕免费视频| 少妇av一区二区三区| 欧美乱大交xxxxx另类电影| 国产成人a亚洲精品| 91久久精品日日躁夜夜躁国产| 91av在线精品| 日韩中文字幕在线看| 国产91av在线| 日本国产一区二区三区| 日韩在线免费观看视频| 国产精品久久久久久久久男| 中文字幕综合在线| 久久99亚洲精品| 欧美在线视频网| 国产精品高清网站| 久久资源免费视频| 国产亚洲精品久久久久动| 91香蕉嫩草影院入口| 亚洲色图综合网| 日韩国产欧美区| 国产精品视频久| 欧美一级电影免费在线观看| 中文在线资源观看视频网站免费不卡| 成人免费视频网| 久久精品国产亚洲精品| 成人免费福利视频| 欧美日韩成人免费| 精品成人国产在线观看男人呻吟| 九九九久久久久久| 国产91网红主播在线观看| 中文字幕亚洲一区二区三区五十路| 成人黄色中文字幕| 国产99久久精品一区二区| www.欧美三级电影.com| 亚洲激情视频网站| 国产日韩在线看片| 国产在线视频不卡| 亚洲精品福利免费在线观看| 欧美成人手机在线| 国产精品黄色影片导航在线观看| 亚洲欧美成人在线| 欧美成人免费小视频| 日韩在线视频一区| 亚洲成av人乱码色午夜| 久久精品这里热有精品|