离线安装Postgres、时序库(timescaledb)

1、准备

Postgres下载 10.19
CMake下载 3.16.2
TimescaleDB下载 1.4.0

相关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、手动安装

将上述文件都拷贝到目标服务器
首先到RMP目录下安装相关依赖

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

创建软件安装目录

mkdir -pv /opt/software

postgres安装包解压

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

创建数据目录并授权

#进入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/

添加环境变量

echo 'export PATH=/opt/software/pgsql/bin:$PATH' >>/etc/profile;
echo 'export PGDATA=/opt/software/pgsql/pgsql_data'>>/etc/profile;
#生效环境变量
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,放开注释,分别填入填入上面创建的数据目录和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

修改脚本权限,并加入开机自启动

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

查看服务是否启动成功

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数据库
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数据库#######"
        #解压缩
        tar -zxvf $pkgDir/postgresql-10.19-1-linux-x64-binaries.tar.gz -C /opt/software/
        cd /opt/software/pgsql
        #创建数据目录并授权
        mkdir -pv pgsql_data
        useradd postgres
        echo "your passd" | passwd postgres --stdin > /dev/null 2>&1
        chown postgres /opt/software/pgsql/pgsql_data/
        #切换用户初始化数据库
        echo "#######正在初始化postgreSql#######"
        #添加环境变量
        echo 'export PATH=/opt/software/pgsql/bin:$PATH' >>/etc/profile;
        echo 'export PGDATA=/opt/software/pgsql/pgsql_data'>>/etc/profile;
        #生效环境变量
        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
        #安装时序数据库
        tar -zxvf $pkgDir/timescaledb.tar.gz -C /opt/software/pgsql
        cd /opt/software/pgsql/timescaledb
        ./bootstrap
        cd build && make
        make install
        
        #设置开机自启动(自启动脚本参考手动安装)
        \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
#创建数据库,用于下方导入数据
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
        
        #导入数据库(自己的数据库初始文件)
        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连接数据库)

# "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
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,590评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 86,808评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,151评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,779评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,773评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,656评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,022评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,678评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,038评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,659评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,756评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,411评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,005评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,973评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,053评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,495评论 2 343

推荐阅读更多精彩内容