PostgreSQL自动安装脚本

Stella981
• 阅读 525

抽空写了一个postgresql的自动安装部署脚本,方便集群化安装

环境:
OS:CentOS 6.3
DB:PostgreSQL 9.3.2

使用步骤:
分两个脚本,一个是执行文件,另一个是初始化脚本,实际只要点击执行文件install_postgres.sh即可。

1.上传这两个文件到/tmp目录下
2.root用户执行sh install_postgres.sh 内容:

1.install_postgres.sh

[root@db tmp]# more install_postgres.sh
#!/bin/bash

######################################################
##
##  Purpose:Install Postgresql Automatically
## 
##  Author :Kenyon
##  
##  Created:2014-02-08
## 
##  Version:1.0.0
#####################################################

echo "--------------------Check current OS datetime---------------------"

DATE=`date +"%Y-%m-%d %H:%M:%S"`

echo "------系统当前时间: $DATE------------------"
echo "------确保系统时间不早于实际时间----------"
echo "------请输入 Y or N 继续-----------------"
read input
if [ "$input" = "N" -o "$input" = "n" ]; then
echo "-------------------Modify OS datetime correctly,exit install!-----"
exit 1

elif [ "$input" = "Y" -o "$input" = "y" ];then
echo "---------------------start install PostgreSQL---------------------"
yum install -y wget perl-ExtUtils-Embed readline-devel zlib-devel pam-devel libxml2-devel libxslt-devel openldap-devel python-devel gcc-c++ openssl-devel cmake
mkdir -p /database/pgdata

echo "---------------------create postgres user if not exist------------"
if [ `grep "postgres" /etc/passwd | wc -l` -eq 0 ];then
echo "adding user postgres"
/usr/sbin/groupadd postgres
/usr/sbin/useradd postgres -g postgres
echo "postgres"|passwd --stdin  postgres
else
echo "--------------  the user of Postgres is already exist,ignore useradd"
fi

cd /database
chown -R postgres:postgres  ./pgdata

echo "---------------------download PostgreSQL source code----------------"
cd /tmp
chown postgres:postgres ./initdb_postgres.sh
chmod u+x ./initdb_postgres.sh
su - postgres -c /tmp/initdb_postgres.sh

else
echo "--------------------输入错误,请输入 Y or N-------------------"
exit 1
fi

2.initdb_postgres.sh

#!/bin/bash

######################################################
##
##  Purpose: Init Postgresql Automatically
## 
##  Author :Kenyon
##  
##  Created:2014-02-08
## 
##  Version:1.0.0
#####################################################

if [ `whoami` != "postgres" ] ; then
echo "------------------Should be postgres user initdb!!----------------"
exit 1

else

ecgo "-------------------init postgres's environment variables-----------"
cat >> ~/.bash_profile << EOF
export PGPORT=1949
export PGHOME=/home/postgres
export PGDATA=/database/pgdata
export PATH=\$PGHOME/bin:\$PATH
export MANPATH=\$PGHOME/share/man:\$MANPATH
export LANG=en_US.utf8
export LD_LIBRARY_PATH=\$PGHOME/lib:\$LD_LIBRARY_PATH

alias pg_stop='pg_ctl -D \$PGDATA stop -m fast'
alias pg_start='pg_ctl -D \$PGDATA start'
alias pg_reload='pg_ctl -D \$PGDATA reload'
EOF

wget http://ftp.postgresql.org/pub/source/v9.3.2/postgresql-9.3.2.tar.gz
echo "tar -zxvf postgresql-9.3.2.tar.gz"
tar -zxvf postgresql-9.3.2.tar.gz
cd postgresql-9.3.2

echo "-------------------Configuring PostgreSQL,please wait---------------"
./configure --prefix=/home/postgres --with-pgport=1949 --with-perl --with-python --with-openssl --with-pam --with-ldap --with-libxml --with-libxslt --enable-thread-safety

if [ $? -ne 0 ];then
echo "Configure Postgresql失败,请检查config日志!"
exit 1
fi

echo "-------------------Installing PostgreSQL,please wait----------------"
gmake world
if [ $? -ne 0 ];then
echo "Gmake Postgresql失败 ,请检查日志!"
exit 1
fi

gmake install-world
if [ $? -ne 0 ];then
echo "Gmake install Postgresql failed ,请检查日志!"
exit 1
fi

echo "-----------------Initing Database----------------------------------"

echo "Tc_Pgsql_ky">/tmp/postgres_pwd.txt
initdb -D /database/pgdata -E UTF8 --locale=C -U postgres --pwfile /tmp/postgres_pwd.txt
if [ $? -eq 0 ];then
  echo "---------------安装PostgreSQL成功---"
  rm -f /tmp/postgres_pwd.txt
else
  echo "--------------安装PostgreSQL失败,请检查日志------------"
  exit 1
fi


fi

其他: 时间关系后期调整一下输入端口选择和密码动态输入

点赞
收藏
评论区
推荐文章
blmius blmius
2年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Wesley13 Wesley13
2年前
java将前端的json数组字符串转换为列表
记录下在前端通过ajax提交了一个json数组的字符串,在后端如何转换为列表。前端数据转化与请求varcontracts{id:'1',name:'yanggb合同1'},{id:'2',name:'yanggb合同2'},{id:'3',name:'yang
Jacquelyn38 Jacquelyn38
2年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Stella981 Stella981
2年前
Android So动态加载 优雅实现与原理分析
背景:漫品Android客户端集成适配转换功能(基于目标识别(So库35M)和人脸识别库(5M)),导致apk体积50M左右,为优化客户端体验,决定实现So文件动态加载.!(https://oscimg.oschina.net/oscnet/00d1ff90e4b34869664fef59e3ec3fdd20b.png)点击上方“蓝字”关注我
Stella981 Stella981
2年前
Redis 三主三从集群搭建
1.安装包依赖yumyinstallgccgcccwgetmaketcl2\.makemakeMALLOClibcmakeinstall3.使用脚本安装服务cdutils/./install\_server.sh4.将src目录下的redis开头的可执行文件全部拷贝到/usr/local/re
Stella981 Stella981
2年前
PostgreSQL Oracle 兼容性之
Oracle使用sys\_guid()用来产生UUID值。 在PostgreSQL中有类似的函数,需要安装uuidossp插件。 如果用户不想修改代码,还是需要使用sys\_guid()函数的话,可以自己写一个。 如下:1.postgres\createextension"uuidossp";2.CREATE
Wesley13 Wesley13
2年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Wesley13 Wesley13
2年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
3个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这