源码编译安装PostgreSQL以及多实例




#!/bin/bash
# 设置PostgreSQL的版本和下载路径
POSTGRESQL_VERSION="12.3"
DOWNLOAD_URL="https://ftp.postgresql.org/pub/source/v${POSTGRESQL_VERSION}/postgresql-${POSTGRESQL_VERSION}.tar.gz"
 
# 安装编译依赖
sudo apt-get update
sudo apt-get install -y build-essential zlib1g-dev libssl-dev libreadline-dev libbz2-dev libsqlite3-dev wget curl llvm libncurses5-dev xz-utils tk-dev libxml2-dev libxmlsec1-dev libffi-dev liblzma-dev
 
# 创建PostgreSQL用户和组
sudo groupadd -r postgres
sudo useradd -r -g postgres postgres
 
# 创建安装目录和数据目录
sudo mkdir -p /opt/postgresql /var/lib/postgresql
sudo chown -R postgres:postgres /opt/postgresql /var/lib/postgresql
sudo chmod -R 700 /var/lib/postgresql
 
# 下载并解压PostgreSQL源码
cd /opt
wget "$DOWNLOAD_URL"
tar -zxvf "postgresql-${POSTGRESQL_VERSION}.tar.gz"
 
# 编译和安装PostgreSQL
cd "postgresql-${POSTGRESQL_VERSION}"
./configure --prefix=/opt/postgresql --bindir=/opt/postgresql/bin --datadir=/var/lib/postgresql --libdir=/opt/postgresql/lib --includedir=/opt/postgresql/include --sysconfdir=/opt/postgresql/etc --docdir=/opt/postgresql/doc --mandir=/opt/postgresql/man --enable-depend --enable-cassert --enable-debug --with-openssl --with-pam --with-ldap --with-libxml --with-libxslt --enable-thread-safety
gmake
sudo gmake install
 
# 配置环境变量
echo 'export PATH=/opt/postgresql/bin:$PATH' >> ~/.bashrc
source ~/.bashrc
 
# 初始化数据库
/opt/postgresql/bin/initdb -D /var/lib/postgresql
 
# 启动PostgreSQL服务
/opt/postgresql/bin/pg_ctl -D /var/lib/postgresql -l logfile start
 
# 创建多实例目录和配置多实例
for PORT in 5433 5434; do
    DATA_DIR="/var/lib/postgresql/${PORT}"
    CONF_FILE="/opt/postgresql/etc/postgresql.conf.${PORT}"
    echo "Creating instance for port ${PORT}..."
    sudo mkdir -p "${DATA_DIR}"
    sudo chown -R postgres:postgres "${DATA_DIR}"
    sudo chmod -R 700 "${DATA_DIR}"
 
    # 配置文件模板并修改端口
    cp /opt/postgresql/etc/postgresql.conf "${CONF_FILE}"
    sed -i "s/port = 5432/port = ${PORT}/" "${CONF_FILE}"
    sed -i "s/data_directory = '\/var\/lib\/postgresql'/data_directory = '\/var\/lib\/postgresql\/${PORT}'/" "${CONF_FILE}"
    sed -i "s/hba_file = '\/var\/lib\/postgresql\/hba.conf'/hba_file = '\/var\/lib\/postgresql\/${PORT}\/hba.conf'/" "${CONF_FILE}"
    sed -i "s/ident_file = '\/var\/lib\/postgresql\/pg_ident.conf'/ident_file = '\/var\/lib\/postgresql\/${PORT}\/pg_ident.conf'/" "${CONF_FILE}"
 
   

评论已关闭

推荐阅读

Vue中使用mind-map实现在线思维导图
2024年08月04日
VUE
Web前端最全Vue实现免密登录跳转的方式_vue怎么样不登录返回首页,最强技术实现
2024年08月04日
VUE
vue3 项目搭建教程(基于create-vue,vite,Vite + Vue)
2024年08月04日
VUE
Vue-颜色选择器实现方案——>Vue-Color( 实战*1+ Demo*7)
2024年08月04日
VUE
Vue项目卡顿慢加载?这些优化技巧告诉你!_vue数据多渲染卡顿
2024年08月04日
VUE
vue中的keep-alive详解与应用场景
2024年08月04日
VUE
Vue、React实现excel导出功能(三种实现方式保姆级讲解)
2024年08月04日
vue-office/docx插件实现docx文件预览
2024年08月04日
VUE
java调用js文件的两种方法(支持V8引擎)
2024年08月04日
JavaScript:解决计算精度问题/mathjs/bignumber.js/big.js/decimal.js
2024年08月04日
两周从爬虫小白变大神 _yjs_js_security_passport
2024年08月04日
JS笔记(对象、函数、数组)
2024年08月04日
Markdown.js:强大的纯JavaScript Markdown解析器
2024年08月04日
Vue项目:js模拟点击a标签下载文件并重命名,URL文件地址下载方法、请求接口下载文件方法总结。
2024年08月04日
vue 父组件怎么获取子组件里面的data数据
2024年08月04日
VUE
个人开发实现AI套壳网站快速搭建(Vue+elementUI+SpringBoot)
2024年08月04日
el-table 表格封装并改造实现单元格可编辑
2024年08月04日
none
nodejs环境下创建vue项目、SSH密钥登陆!!!
2024年08月04日
vue+quill+element-ui实现视频、图片上传及缩放保姆级教程,轻松使用富文本
2024年08月04日
【three.js】22. Imported Models导入模型
2024年08月04日