大家好,我是字母哥(coder)!

我让公司的小伙伴写一个生产级别的PostgreSQL的安装文档,结果他和我说:“不是用一个命令就能安装好么?还用写文档么?”。我知道他想说的是这个命令:yum install postgresql-server,我也是挺无语的。要知道生产级别的应用安装方式,和自己在练习过程中安装的小玩具相比,要严谨的多,考虑的问题也更多。

  • 首先是安全问题,能不能用root安装?防火墙怎么搞?数据库打开文件以及连接数会不会超过linux默认打开文件句柄数的限制?
  • 其次是合理规划,你的数据放在哪个目录?这个目录是全公司统一的么?linux发行版不一样,软件安装目录一致么?数据目录是单独挂载磁盘么?单独挂载的磁盘做了RAID数据冗余么?
  • 然后是运维方便的问题,你是否配置了合理的环境变量,如果不配置你是不是每次执行命令都要敲全路径?是否PostgreSQL具备开机自启动功能?
  • 数据库用户是否经过合理规划,你的数据操作(增删改查)用户是否能新建表,truncat表,删除表?数据操作用户具备这些功能是不是导致人为误操作的风险增加?
  • 你的数据库安装之后,是否具备企业级的统一管理、故障监控?流程上如何申请?等等等等。

以上的这些问题,都需要写在《数据库安装手册》中,怎么会只有一个命令呢?本文只当抛砖引玉,通过安装PostgreSQL数据库,来说明一下一个完整的《数据库安装手册》该怎么写。 如果有考虑不足不全面之处,欢迎网友们补充。

一、安装包下载

要进行PostgreSQL的安装,首先我们需要先把安装包下载下来。生产环境的postgresql安装一般会使用源码编译的方式进行安装,使用源码编译的安装方式有几个好处(坏处就是相对麻烦):

  • 公司的服务器什么型号,什么操作系统版本的都有。如果使用yum或者apt-get安装,很难统一版本,不同的操作系统发行版带的postgreSQL源是不一样的。即使搞成统一的,不同的操作系统之间也无法统一安装目录的位置、lib存放位置等。
  • postgresql源码编译的方式进行安装,可以灵活的选择我们需要安装的版本,需要哪一个版本就下载哪一个版本。而使用yum或者apt-get进行安装只能源库指定的若干版本。源码安装,我们想指定什么目录就指定什么目录,全公司所有的PostgreSQL都在这个目录,这也是规范的一种。

所以为了适应更多的场景,为了达到公司内运维统一的标准,一般生产环境会使用postgresql源码编译的方式进行安装。PostgreSql官方源码安装包的下载地址是:https://www.postgresql.org/download/



找到如上图所示的“file browser”,点击进入file browser页面,下载以“tar.gz”结尾的安装包即可。

二、必要的准备工作

需要说明的是,准备工作需要使用root用户进行操作。我们以CentOS linux发行版操作系统为例,命令如下。如若是其他的linux发行版,准备工作这一块内容操作步骤是差不多的,linux命令需要调整。

1、安装必要的编译环境

首先需要安装一些必要的依赖,PostgreSQL安装的过程需要使用到这些linux包。

  1. yum install -y cmake make gcc zlib zlib-devel gcc-c++ perl readline readline-devel python36 \
  2. tcl openssl ncurses-devel openldap pam flex

2、创建postgre用户

通过groupadd添加一个用户组postgres,再使用adduser命令添加一个操作系统的postgres用户,该用户的用户组是-g postgres

  1. groupadd postgres
  2. adduser -g postgres postgres

adduser命令在CentOS或者RedHat发行版中,在添加操作系统用户的同时会自动新建一个该用户的主目录/home/postgres,该目录也是我们后续安装PostgreSql的主目录。该目录的权限归属于postgres组的postgres用户。

  1. passwd postgres

新建用户之后,我们使用passwd命令修改操作系统内的postgres用户的密码。

如果你使用的是其他的linux操作系统发行版,这个目录你可能需要手动的去创建,并且手动执行命令为postgres 用户赋权。命令如下

  1. mkdir -p /home/postgres;
  2. chmod -R 775 /home/postgres;
  3. chown -R postgres:postgres /home/postgres;

3、开放防火墙端口

开放防火墙,使用如下2条命令开放postgreSQL的标准端口5432的端口。其实,笔者建议安装postgreSQL的时候,不要使用这个端口,因为端口越固定,被攻击的可能性就越大。我们随机选择一个不常用的端口,安全性会更好一些,这里我还是使用标准端口了。

  1. firewall-cmd --zone=public --add-port=5432/tcp --permanent;
  2. firewall-cmd --reload

4.修改操作系统打开最大文件句柄数

在/etc/security/limits.conf中进行设置(需要root权限修改该文件),可添加如下两行,表示用户postgres最大打开文件描述符数的soft limit为65535,hard limit为65535。

  1. postgres soft nofile 65535
  2. postgres hard nofile 65535

该配置在关闭linux访问终端session重新登录之后生效,ulimit -n的值会变成65535 。进行这一步操作的目的是防止linux操作系统内打开文件句柄数量的限制,避免不必要的故障。

5、创建必要的目录

创建目录的时候要做好规划,下文中 /home/postgres/postgre14是我规划的postgreSql安装目录; /home/postgres/pgdata是我规划的postgreSql数据存放目录。

  1. mkdir -p /home/postgres/{postgre14,pgdata}

这里需要注意的是, /home/postgres/pgdata这样的目录规划并不标准,这里我只是给大家做演示操作。实际上生产环境,postgreSql数据存放目录应该是服务器单独挂载的一块磁盘,与linux操作系统以及安装程序是分开的。 这样做的好处:一是方便数据备份(硬件层面或软件层面),二是操作系统出现的问题,不影响数据安全。

三、编译并安装

准备工作做好之后我们就开始真正的安装了,安装过程使用postgres用户,使用su命令从root用户切换到postgres用户。并且解压安装包,解压路径是/home/postgres

  1. su - postgres
  2. tar -xzvf ./postgresql-14.4.tar.gz -C /home/postgres

解压之后的文件路径是postgresql-14.4,进入这个目录里面,我们来执行编译安装,编译安装的结果目录我们指定为/home/postgres/postgre14。最后一步make和insatll的过程比较耗时,多等一会。如果没有报错信息,我们的安装就完成了,其实也很快的,并不比yum安装方式麻烦多少。

  1. cd /home/postgres/postgresql-14.4
  2. ./configure --prefix=/home/postgres/postgre14
  3. make && make install

四、配置环境变量

安装完成之后,我们来给postgres配置一些环境变量,比如PGPORT端口、PGDATA数据目录、PGHOME安装目录、LD_LIBRARY_PATH的安装lib目录、PATH命令脚本目录。

  1. cat >> ~/.bash_profile <<"EOF"
  2. export PGPORT=5432
  3. export PGDATA=/home/postgres/pgdata
  4. export PGHOME=/home/postgres/postgre14
  5. export LD_LIBRARY_PATH=$PGHOME/lib:$LD_LIBRARY_PATH
  6. export PATH=$PGHOME/bin:$PATH:.
  7. EOF

配置完成之后,使用如下命令使配置生效。

  1. source ~/.bash_profile

有了环境变量之后,我们的运维工作会更方便。比如:在postgres用户下我们执行命令psql就可以,就不用敲全路径了,比如:/home/postgres/postgre14/bin/psql

五、数据库及参数初始化

数据库安装完成之后,我们需要完成一个数据库初始化工作。指定-D数据目录,-E字符编码, --locale本及语言环境,-U初始化用户信息。

  1. $PGHOME/bin/initdb -D $PGDATA -E UTF8 --locale=en_US.utf8 -U postgres

完成这个操作之后,数据库存在了postgres用户,数据目录PGDATA目录下面初始化了一些配置文件,比如:/home/postgres/pgdata/postgresql.conf参数文件,/home/postgres/pgdata/pg_hba.conf 用户访问权限文件。

我们来修改一下参数文件,以期望它能够适配我们的操作系统和我们的运行需求。下文中命令的含义是将EOF包含的文件内容写入/home/postgres/pgdata/postgresql.conf配置文件。

  1. cat >> /home/postgres/pgdata/postgresql.conf <<"EOF"
  2. listen_addresses = '*'
  3. port=5432
  4. logging_collector = on
  5. log_directory = 'pg_log'
  6. log_filename = 'postgresql-%a.log'
  7. EOF
  • listen_addresses 表示postgre进程监听的网卡地址,配置*表示监听所有。
  • port服务监听端口配置
  • logging_collector=on,启动日志收集器
  • log_directory 表示日志文件在PGDATA目录下的文件夹位置。
  • log_filename表示日志文件的名称

这里只列出一些通常情况下需要修改的参数,性能调优参数就不一一列举了,我后续可能会专门写一篇PostgreSQL性能调优的文章,欢迎大家关注我!

  1. # 数据库能够接受的最大请求连接并发数
  2. max_connections = 100
  3. # 数据库服务器将使用的共享内存缓冲区量。建议值:数据库独立服务器的1/4内存。
  4. shared_buffers =1GB

基础运行参数配置完成之后,还需要配置一些访问权限。如下所示使用cat命令将EOF包含的文件内容,写入/home/postgres/pgdata/pg_hba.conf 配置文件:

  1. cat > /home/postgres/pgdata/pg_hba.conf << EOF
  2. # TYPE DATABASE USER ADDRESS METHOD
  3. local all all trust
  4. host all all 0.0.0.0/0 md5
  5. EOF
  • 第一行的内容表示local本机,all所有用户可以访问postgre的所有数据库,并且密码发送方式不需要加密(trust)。
  • 第二行的内容用于远程访问,指定了可以访问postgreSql数据库的远程用户的ip范围, 0.0.0.0/0 表示所有ip都可以。如果你希望指定ip段,可以像这样去配置192.168.3.1/24(表示的ip范围是:192.168.3.1到192.168.3.255)。md5表示数据库访问密码使用md5的加密方式发送。

六、启动数据库新建用户

完成以上的所有的操作之后,我们就可以启动数据库了,使用如下的这些命令启停数据库。

  1. #启动命令
  2. pg_ctl start
  3. #重启命令
  4. pg_ctl restart
  5. #查看数据库运行状态
  6. pg_ctl status
  7. #停止数据库
  8. pg_ctl stop

数据库启动之后,我们查看一些数据库运行的进程如下所示:



数据库启动成功,我们输入psql命令,进入数据库管理命令行

  1. $ psql

数据库初始化的过程,新建了一个用户postgres,我们给它修改一下密码。

  1. alter user postgres with password '你设置的密码';

一般来说,我们的程序在运行过程中,不会直接使用postgres用户,而是新建一个用户。

  1. #新建一个用户 acai
  2. CREATE USER acai WITH password '密码';
  3. #新建一个数据库acaidb,属主是acai
  4. CREATE DATABASE acaidb OWNER acai;
  5. # 为用户acai赋权,all表示所有权限,acaidb的管理用户
  6. GRANT all ON DATABASE acaidb TO acai;

实际上在生产环境中,我们需要创建两个用户,一个数据库管理用户用于管理表、视图等操作;另一个是程序用户,用于操作数据库表里面的数据,完成增删改查。

  1. CREATE USER acaiuser WITH password '********';
  2. GRANT update,delete,insert,select ON ALL TABLES IN SCHEMA public TO acaiuser;

七、开机自启动

为了让PostgreSQL在以后每次服务器重启之后,都能够自动启动,我们写一个自启动配置文件。下面的命令需要使用root用户执行

  1. cat > /etc/systemd/system/postgre14.service <<"EOF"
  2. [Unit]
  3. Description=PostgreSQL database server 14.4
  4. Documentation=man:postgres(1)
  5. After=network.target
  6. [Service]
  7. Type=forking
  8. User=postgres
  9. Group=postgres
  10. Environment=PGPORT=5432
  11. Environment=PGDATA=/home/postgres/pgdata
  12. ExecStart=/home/postgres/postgre14/bin/pg_ctl start -D ${PGDATA} -s -o "-p ${PGPORT}" -w -t 300
  13. ExecStop=/home/postgres/postgre14/bin/pg_ctl stop -D ${PGDATA} -s -m fast
  14. ExecReload=/home/postgres/postgre14/bin/pg_ctl reload -D ${PGDATA} -s
  15. KillMode=mixed
  16. KillSignal=SIGINT
  17. TimeoutSec=120
  18. [Install]
  19. WantedBy=multi-user.target
  20. EOF

执行下列命令,使得PostgreSQL数据库开机自启动脚本生效。

  1. systemctl daemon-reload
  2. systemctl enable postgre14

后续再启停数据库,查看数据库状态,就可以使用下面的这些命令了

  1. systemctl start postgre14
  2. systemctl stop postgre14
  3. systemctl status postgre14

欢迎关注我的公告号:字母哥杂谈,回复003赠送作者专栏《docker修炼之道》的PDF版本,30余篇精品docker文章。字母哥博客:zimug.com

[PostgreSql]生产级别数据库安装要考虑哪些问题?的更多相关文章

  1. Greenplum 数据库安装部署(生产环境)

    Greenplum 数据库安装部署(生产环境) 硬件配置: 16 台 IBM X3650, 节点配置:CPU 2 * 8core,内存 128GB,硬盘 16 * 900GB,万兆网卡. 万兆交换机. ...

  2. 转_Greenplum 数据库安装部署(生产环境)

    Greenplum 数据库安装部署(生产环境) 硬件配置: 16 台 IBM X3650, 节点配置:CPU 2 * 8core,内存 128GB,硬盘 16 * 900GB,万兆网卡. 万兆交换机. ...

  3. PostGreSQL数据库安装教程

    windows 10 x64 pro 1703安装postgresql-9.6.3-2-windows-x64.exe数据库,步骤如下: 第一:下载数据库安装程序,下载地址为:https://www. ...

  4. PostGreSQL数据库安装配置说明

    windows 10 x64 pro 1703安装postgresql-9.6.3-2-windows-x64.exe数据库,步骤如下: 第一:下载数据库安装程序,下载地址为:https://www. ...

  5. PostgreSQL数据库安装

    PostgreSQL数据库安装 postgresqllinux9.6.0 2018年01月31日 10时53分13秒 编译以及安装 源码编译 程序安装 数据库的启动和停止 启动数据库 关闭数据库 数据 ...

  6. PostgreSQL数据库安装Version10.5

    PostgreSQL数据库安装,基于版本10.5安装, 在Linux系统上使用*.gz二进制压缩包手动安装. 操作系统:Red Hat Enterprise Linux Server release ...

  7. MongoDB学习笔记——数据库安装及配置

    MongoDB数据库安装 MongoDB官方下载地址:https://www.mongodb.com/download-center 首先需要根据Windows版本选择正确的MongoDB版本进行安装 ...

  8. Mysql单实例数据库安装

    第1章 MySQL数据库安装 在当今的大中型互联网企业里,MySQL数据库服务几乎都是运行在Linux系列操作系统上,当然,你在可以运行在Windows/Unix等商业操作系统上,大中型互联网企业使用 ...

  9. Linux环境PostgreSQL源码编译安装

    Linux环境PostgreSQL源码编译安装 Linux版本: Red Hat 6.4 PostgreSQL版本: postgresql-9.3.2.tar.gz 数据存放目录: /var/post ...

随机推荐

  1. csv.reader(f)和f.readlines()、追加数据

    假如某个文档f中存储如下内容: 你好,中国. 1,2,3,4 共两行内容. 当你使用csv.reader(f),则会存储为如下形式: [['你','好','中','国'] ['1','2','3',' ...

  2. 洛谷 P2629 好消息,坏消息 题解

    暴力算法的时间复杂度是O(n^2),考虑优化: 先导入一种思想--断环为链.说通俗点就是在原数组后面再接上下标为1--(n - 1)的元素: 以样例为例:-3 5 1 2:我们将其断环为链后可以得到这 ...

  3. ExtJS 布局-Card 布局(Card layout)

    更新记录: 2022年6月1日 开始. 2022年6月6日 发布. 1.说明 卡片布局类似牌堆,每次只有一个子组件可见,子组件几乎填满了整个容器.卡片布局常用于向导(Wizard)和选项卡(Tabs) ...

  4. SQL Server各版本序列号/激活码/License/秘钥

    SQL Server 2019 Enterprise:HMWJ3-KY3J2-NMVD7-KG4JR-X2G8G Enterprise Core:2C9JR-K3RNG-QD4M4-JQ2HR-846 ...

  5. AsList()方法详解

    AsList()方法详解 在Java中,我们应该如何将一个数组array转换为一个List列表并赋初始值?首先想到的肯定是利用List自带的add()方法,先new一个List对象,再使用add()方 ...

  6. 21.LVS负载均衡群集-DR群集

    LVS负载均衡群集-DR群集 目录 LVS负载均衡群集-DR群集 数据包流向分析 DR模式的特点 LVS-DR中的ARP问题 IP地址冲突 解决办法 路由根据ARP表项,会将新来的请求报文转发给Rea ...

  7. RPA应用场景-信用卡交易争议后续流程

    RPA应用场景-信用卡交易争议后续流程 场景概述 信用卡交易争议后续流程 所涉系统名称 客服系统,邮件 人工操作(时间/次) 4小时 所涉人工数量20操作频率 不定时 场景流程 1.RPA自动接收客户 ...

  8. CesiumJS 2022^ 源码解读[6] - 三维模型(ModelExperimental)新架构

    目录 1. ModelExperimental 的缓存机制 1.1. 缓存池 ResourceCache 1.2. 缓存对象的键设计 ResourceCacheKey 2. 三维模型的加载与解析 2. ...

  9. 开发人员要学的Docker从入门到日常命令使用(通俗易懂),专业运维人员请勿点!

    一.介绍Docker  1.引言 问题1:开发人员告诉测试说自己的项目已经做好了,给你一个发布包,你去测试吧. ## 测试人员,为什么我运行会报错? ## 开发人员说,我本地运行没有问题呀!   解答 ...

  10. 让你的Nginx支持分布式追踪

    Background NGINX 是一个通用且流行的应用程序.也是最流行的 Web 服务器,它可用于提供静态文件内容,但也通常与其他服务一起用作分布式系统中的组件,在其中它用作反向代理.负载均衡 或 ...