Linx下自动化之路:PostgreSQL 安装包精准自动化部署至指定路径并注册成服务全解析

目录

安装包下载

安装脚本

服务常用命令

安装包下载

https://ftp.postgresql.org/pub/source/v15.3/postgresql-15.3.tar.gz

安装脚本

  • 将脚本(postgresql-install.sh)和安装包(postgresql-15.3.tar.gz)放置/data路径

  • 运行脚本sh postgresql-install.sh

  • INSTALL_DIR为安装目录,$INSTALL_DIR/data为数据存放位置

    #!/bin/bash -e

    PASSWORD="123456"
    INSTALL_DIR="/data/postgresql-15.3"

    解压缩文件

    tar -zxvf postgresql-15.3.tar.gz || { echo "解压文件失败"; exit 1; }

    检查是否安装了readline-devel

    rpm -qa | grep readline-devel || { echo "readline-devel未安装"; exit 1; }

    安装readline-devel

    yum install readline-devel -y || { echo "安装readline-devel失败"; exit 1; }

    编译安装

    cd postgresql-15.3
    ./configure --prefix=$INSTALL_DIR && make && make install || { echo "编译安装失败"; exit 1; }

    配置环境变量

    echo "export PATH=INSTALL_DIR/bin:\$PATH" >> /etc/profile || { echo "配置环境变量失败"; exit 1; } echo "export LD_LIBRARY_PATH=INSTALL_DIR/lib:$LD_LIBRARY_PATH" >> /etc/profile || { echo "配置环境变量失败"; exit 1; }
    source /etc/profile

    将postgresql注册为服务

    cd INSTALL_DIR/contrib/start-scripts/ chmod a+x linux || { echo "修改权限失败"; exit 1; } cp linux /etc/init.d/postgresql || { echo "复制文件失败"; exit 1; } sed -i "s#prefix=/usr/local/pgsql#prefix=INSTALL_DIR#g" /etc/init.d/postgresql || { echo "修改文件失败"; exit 1; }
    sed -i "s#PGDATA="/usr/local/pgsql/data"#PGDATA=$INSTALL_DIR/data#" /etc/init.d/postgresql || { echo "修改文件失败"; exit 1; }

    创建用户

    if ! id -u postgres > /dev/null 2>&1; then
    useradd postgres
    fi

    创建数据目录,并赋予权限

    chown -R postgres:postgres INSTALL_DIR mkdir INSTALL_DIR/data || { echo "创建数据目录失败"; exit 1; }
    chown -R postgres:postgres $INSTALL_DIR/data

    切换用户初始化数据库

    su - postgres -c "INSTALL_DIR/bin/initdb -D INSTALL_DIR/data/" || { echo "初始化数据库失败"; exit 1; }

    修改配置文件

    echo "host all all 0.0.0.0/0 password" >> $INSTALL_DIR/data/pg_hba.conf || { echo "修改配置文件失败"; exit 1; }

    修改listen_addresses为*

    sed -i "s/^#listen_addresses = .*/listen_addresses = '*'/g" INSTALL_DIR/data/postgresql.conf || { echo "修改配置文件失败"; exit 1; }

    修改max_connection为1000

    sed -i 's/^#max_connections = .*/max_connections = 1000/' INSTALL_DIR/data/postgresql.conf || { echo "修改配置文件失败"; exit 1; }

    设置开机自启

    chkconfig --add postgresql || { echo "设置开机自启失败"; exit 1; }

    启动服务

    service postgresql start || { echo "启动服务失败"; exit 1; }

    显示状态

    service postgresql status || { echo "显示状态失败"; exit 1; }

    修改密码

    su - postgres -c "INSTALL_DIR/bin/psql -c \"ALTER USER postgres WITH PASSWORD 'PASSWORD';"" || { echo "修改密码失败"; exit 1; }

服务常用命令

复制代码
# 启动服务
service postgresql start

# 停止服务
service postgresql stop

# 显示状态
service postgresql status

# 重新加载配置(这个命令用于重新加载 PostgreSQL 的配置文件,而不需要完全重启服务。当只修改了一些可以动态加载的配置参数(如日志级别等)时,使用这个命令可以在不中断服务运行的情况下使新配置生效)
service postgresql reload
相关推荐
罗政4 小时前
AI工作流实现Excel全自动化(支持SQL)-案例:医院门诊排班表
人工智能·自动化·excel
izcll4 小时前
ubuntu系统安装软件的方法
linux·运维·ubuntu
IvorySQL4 小时前
PostgreSQL 技术日报 (6月16日)|Neon 自动化再进一步,逻辑复制冲突日志迎来 v50 更新
数据库·postgresql·自动化
倒流时光三十年4 小时前
PostgreSQL 聊一下索引和排序规则
postgresql
云飞云共享云桌面12 小时前
传统工作站 vs 云飞云共享云桌面:制造业设计云桌面选型深度对比
运维·服务器·前端·网络·3d·架构·制造
Maynor99615 小时前
我用 Codex 给自己的网站上线了一个智能体客服:从 Dify 到服务器部署,全程实战复盘
运维·服务器
java_cj16 小时前
深入kubectl create源码:从YAML到Pod的完整链路拆解
运维·云原生·容器·kubernetes
深圳恒讯17 小时前
越南服务器BGP多线和单线有什么区别?
运维·服务器
志栋智能17 小时前
超自动化运维如何提升安全合规水平?
运维·安全·自动化
A_humble_scholar18 小时前
Linux(九) 进程管理完全指南:从入门到实战
linux·运维·chrome