離線安裝Postgres悼做、時序庫(timescaledb)

1、準備

Postgres下載 10.19
CMake下載 3.16.2
TimescaleDB下載 1.4.0

相關(guān)RPM包下載 openssl-devel gcc-c++

yum install yum-plugin-downloadonly
yum install --downloadonly --downloaddir=/home/dependency/ openssl-devel
yum install --downloadonly --downloaddir=/home/dependency/ gcc-c++
image.png

2哗魂、手動安裝

將上述文件都拷貝到目標服務(wù)器
首先到RMP目錄下安裝相關(guān)依賴

rpm -Uvh --force --nodeps *.rpm
image.png

創(chuàng)建軟件安裝目錄

mkdir -pv /opt/software

postgres安裝包解壓

tar zxvf postgresql-10.19-1-linux-x64-binaries.tar.gz -C /opt/software/

創(chuàng)建數(shù)據(jù)目錄并授權(quán)

#進入postgres安裝目錄
pushd  /opt/software/pgsql/
mkdir pgsql_data
useradd postgres
echo "password" | passwd postgres --stdin > /dev/null 2>&1
chown postgres /opt/software/pgsql/pgsql_data/

添加環(huán)境變量

echo 'export PATH=/opt/software/pgsql/bin:$PATH' >>/etc/profile;
echo 'export PGDATA=/opt/software/pgsql/pgsql_data'>>/etc/profile;
#生效環(huán)境變量
source /etc/profile
#退回安裝包目錄
popd

解壓cmake

tar -zxvf cmake-3.16.2.tar.gz -C /opt/software/pgsql/

編譯cmake

pushd /opt/software/pgsql/cmake-3.16.2
./bootstrap
gmake
make install
popd

解壓timescaledb

tar -zxvf timescaledb.tar.gz -C /opt/software/pgsql

編譯timescaledb

pushd /opt/software/pgsql/timescaledb
./bootstrap
cd build && make
make install
popd

修改密碼肛走、初始化postgres

su - postgres
/opt/software/pgsql/bin/initdb -D /opt/software/pgsql/pgsql_data
/opt/software/pgsql/bin/pg_ctl -D /opt/software/pgsql/pgsql_data/ start
cd /opt/software/pgsql/bin
./psql
ALTER USER postgres WITH PASSWORD 'your passd';
\q
/opt/software/pgsql/bin/pg_ctl stop
#退出用戶
exit;

修改postgresql.conf配置文件,找到data_directory和shared_preload_libraries录别,放開注釋朽色,分別填入填入上面創(chuàng)建的數(shù)據(jù)目錄和timescaledb安裝目錄名(不用絕對路徑)


image.png
image.png

編寫開機自啟動腳本

vi /usr/lib/systemd/system/postgresql.service

[Unit]
Description=PostgreSQL 10.11 database server
Documentation=https://www.postgresql.org/docs/10/index.html
After=syslog.target
After=network.target

[Service]
Type=forking

User=postgres
Group=postgres

# Location of database directory
Environment=PGDATA=/opt/software/pgsql/pgsql_data/
OOMScoreAdjust=-1000

ExecStart=/opt/software/pgsql/bin/pg_ctl start -D ${PGDATA} -s -w -t 300
ExecStop=/opt/software/pgsql/pg_ctl stop -D ${PGDATA} -s -m fast
ExecReload=/opt/software/pgsql/bin/pg_ctl reload -D ${PGDATA} -s

TimeoutSec=0

[Install]
WantedBy=multi-user.target

修改腳本權(quán)限,并加入開機自啟動

chmod 754 /usr/lib/systemd/system/postgresql.service
systemctl enable postgresql.service
systemctl start postgresql.service

查看服務(wù)是否啟動成功

systemctl status postgresql.service

3组题、腳本自動安裝

shell腳本(基于準備的包)

#!/bin/bash

#使用root用戶操作
if [ "$(id -u)" != "0" ]; then 
echo "You need to be 'root' dude." 1>&2 
exit 1
fi

echo "=================================================="
echo "           welcome to the postgres installer           "
echo "                                                  "

path=`pwd`  
#判斷字符串是否相等
if [ "$path" = "/" ];then
    path=''
fi  
#安裝包目錄
pkgDir="$pwd/pkg"
#依賴目錄
depenDir="$pkgDir/dependency"

#安裝postgres數(shù)據(jù)庫
function postgresFun()
{
    #離線安裝依賴包
    rpm -Uvh --force --nodeps $dependencyDir/*.rpm

    #檢測linux是否安裝postgreSql
    PGSQL_VERSION=`psql --version 2>&1`
    resultPGsqlInfo=$(echo $PGSQL_VERSION | grep "${ErrorInfo}")
    if [[ "$resultPGsqlInfo" != "" ]]
    then
        echo "#######安裝postgreSql數(shù)據(jù)庫#######"
        #解壓縮
        tar -zxvf $pkgDir/postgresql-10.19-1-linux-x64-binaries.tar.gz -C /opt/software/
        cd /opt/software/pgsql
        #創(chuàng)建數(shù)據(jù)目錄并授權(quán)
        mkdir -pv pgsql_data
        useradd postgres
        echo "your passd" | passwd postgres --stdin > /dev/null 2>&1
        chown postgres /opt/software/pgsql/pgsql_data/
        #切換用戶初始化數(shù)據(jù)庫
        echo "#######正在初始化postgreSql#######"
        #添加環(huán)境變量
        echo 'export PATH=/opt/software/pgsql/bin:$PATH' >>/etc/profile;
        echo 'export PGDATA=/opt/software/pgsql/pgsql_data'>>/etc/profile;
        #生效環(huán)境變量
        source /etc/profile
        
        #判斷cmake是否安裝
        MAKE_VERSION=`cmake --version 2>&1`
        resultMAKEInfo=$(echo $MAKE_VERSION | grep "${ErrorInfo}")
        if [[ "$resultMAKEInfo" != "" ]]
        then
            echo "######正在初始化CMAKE#######"
            tar -zxvf $pkgDir/cmake-3.16.2.tar.gz -C /opt/software/pgsql/
            cd cmake-3.16.2
            ./bootstrap
            gmake
            make install
        fi
        #安裝時序數(shù)據(jù)庫
        tar -zxvf $pkgDir/timescaledb.tar.gz -C /opt/software/pgsql
        cd /opt/software/pgsql/timescaledb
        ./bootstrap
        cd build && make
        make install
        
        #設(shè)置開機自啟動(自啟動腳本參考手動安裝)
        \cp -rf "$docDir/psql/postgresql.service" /usr/lib/systemd/system/
        chmod 754 /usr/lib/systemd/system/postgresql.service
        systemctl enable postgresql.service
        #修改密碼
su - postgres <<CONSOLE
/opt/software/pgsql/bin/initdb -D /opt/software/pgsql/pgsql_data
sed -i "$a\要插入的文字" /opt/software/pgsql/pgsql_data/postgresql.conf
#\cp -rf "$docDir/psql/pg_hba.conf" /opt/software/pgsql/pgsql_data/
echo "data_directory='/opt/software/pgsql/pgsql_data'" >> /opt/software/pgsql/pgsql_data/postgresql.conf
echo "shared_preload_libraries = 'timescaledb' " >> /opt/software/pgsql/pgsql_data/postgresql.conf
/opt/software/pgsql/bin/pg_ctl -D /opt/software/pgsql/pgsql_data/ start
cd /opt/software/pgsql/bin
./psql <<PG
#創(chuàng)建數(shù)據(jù)庫葫男,用于下方導入數(shù)據(jù)
CREATE DATABASE test;
ALTER USER postgres WITH PASSWORD 'your passd';
\q
PG
/opt/software/pgsql/bin/pg_ctl stop
#退出用戶
exit;
CONSOLE

        systemctl start postgresql.service
        
        #導入數(shù)據(jù)庫(自己的數(shù)據(jù)庫初始文件)
        pg_restore -h 127.0.0.1 -p 5432 -U postgres -w -d test -v "$docDir/psql/test.backup"
        echo "#######finish postgreSql#######"
    else
            echo "#######postgreSql already installed#######"
    fi
}

修改pg_hba.conf(僅可使用SSH連接數(shù)據(jù)庫)

# "local" is for Unix domain socket connections only
local   all             all                                     trust
# IPv4 local connections:
host    all             all             127.0.0.1/32            trust
host    all             all                0.0.0.0/0        password
# IPv6 local connections:
host    all             all             ::1/128                 trust
# Allow replication connections from localhost, by a user with the
# replication privilege.
local   replication     all                                     trust
host    replication     all             127.0.0.1/32            trust
host    replication     all             ::1/128                 trust
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市崔列,隨后出現(xiàn)的幾起案子梢褐,更是在濱河造成了極大的恐慌,老刑警劉巖赵讯,帶你破解...
    沈念sama閱讀 216,692評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件盈咳,死亡現(xiàn)場離奇詭異,居然都是意外死亡边翼,警方通過查閱死者的電腦和手機鱼响,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,482評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來组底,“玉大人丈积,你說我怎么就攤上這事≌Γ” “怎么了江滨?”我有些...
    開封第一講書人閱讀 162,995評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長厌均。 經(jīng)常有香客問我牙寞,道長,這世上最難降的妖魔是什么莫秆? 我笑而不...
    開封第一講書人閱讀 58,223評論 1 292
  • 正文 為了忘掉前任间雀,我火速辦了婚禮,結(jié)果婚禮上镊屎,老公的妹妹穿的比我還像新娘惹挟。我一直安慰自己,他們只是感情好缝驳,可當我...
    茶點故事閱讀 67,245評論 6 388
  • 文/花漫 我一把揭開白布连锯。 她就那樣靜靜地躺著归苍,像睡著了一般。 火紅的嫁衣襯著肌膚如雪运怖。 梳的紋絲不亂的頭發(fā)上拼弃,一...
    開封第一講書人閱讀 51,208評論 1 299
  • 那天,我揣著相機與錄音摇展,去河邊找鬼吻氧。 笑死,一個胖子當著我的面吹牛咏连,可吹牛的內(nèi)容都是我干的盯孙。 我是一名探鬼主播,決...
    沈念sama閱讀 40,091評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼祟滴,長吁一口氣:“原來是場噩夢啊……” “哼振惰!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起垄懂,我...
    開封第一講書人閱讀 38,929評論 0 274
  • 序言:老撾萬榮一對情侶失蹤骑晶,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后草慧,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體透罢,經(jīng)...
    沈念sama閱讀 45,346評論 1 311
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,570評論 2 333
  • 正文 我和宋清朗相戀三年冠蒋,在試婚紗的時候發(fā)現(xiàn)自己被綠了羽圃。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,739評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡抖剿,死狀恐怖朽寞,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情斩郎,我是刑警寧澤脑融,帶...
    沈念sama閱讀 35,437評論 5 344
  • 正文 年R本政府宣布,位于F島的核電站缩宜,受9級特大地震影響肘迎,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜锻煌,卻給世界環(huán)境...
    茶點故事閱讀 41,037評論 3 326
  • 文/蒙蒙 一妓布、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧宋梧,春花似錦匣沼、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,677評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽加叁。三九已至,卻和暖如春唇撬,著一層夾襖步出監(jiān)牢的瞬間它匕,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,833評論 1 269
  • 我被黑心中介騙來泰國打工窖认, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留豫柬,地道東北人。 一個月前我還...
    沈念sama閱讀 47,760評論 2 369
  • 正文 我出身青樓耀态,卻偏偏與公主長得像轮傍,于是被迫代替她去往敵國和親暂雹。 傳聞我的和親對象是個殘疾皇子首装,可洞房花燭夜當晚...
    茶點故事閱讀 44,647評論 2 354

推薦閱讀更多精彩內(nèi)容