Postgresql 需要打开和关闭,一般我们都使用 pg_ctl 命令来进行,实际上一般我们的LINUX 上的系统的一般是可以通过 systemctl 的方式来启动和关闭以及操纵一些相关的功能。
在开始POSTGRESQL systemctl 工作前,我们需要说一下LINUX 的 systemd , systemd 是linux 系统中最新的初始化系统 init ,目前所有的LINUX 系统包含 UBUNTU 或者 CENTOS 等都采用了systemd 的方式来启动服务,提高了系统的启动速度,systemd 的概念来源与评估的MAC OS 系统的launchd, 好处是通过systemd ,迁移之前的启动的方式简单,并且尽量使用并行的方式进行系统的启动。
systemctl 的启动文件,一般存放在/usr/lib/systemd/system 文件夹下,文件的模块主要分为3个。
1 Unit
2 Unit 类型
3 install
通过 systemctl 命令来对启动文件的加载,起用, 和命令的执行进行执行和管理。
下面是一个postgresql systemd 启动文件
1 单元unit 是对这个启动文件进行一个介绍这个启动文件是什么
after 是注明此服务启动前必须的启动项.
其中还有其他的一些启动项选择
before, requires , wants , conflicts
[Unit]
Description=PostgreSQL database server
After=network.target
[Service]
Type=forking
simple:默认值,这个服务主要由 ExecStart 设置的程序来启动,启动后常驻于内存中。 forking:由 ExecStart 指定的启动的程序通过 spawns 产生子进程提供服务,然后父进程退出。 oneshot:与 simple 类似,不过这个程序在工作完毕后就结束了,不会常驻在内存中。 dbus:与 simple 类似,但这个服务必须要在取得一个 D-Bus 的名称后,才会继续运行!因此设置这个项目时,通常也要设置 BusName= 才行。 idle:与 simple 类似,意思是,要执行这个服务必须要所有的工作都顺利执行完毕后才会执行。这类的服务通常是开机到最后才执行即可的服务。 notify:与 simple 类似,但这个服务必须要收到一个 sd_notify() 函数发送的消息后,才会继续运行
User=postgres
Group=postgres
启动此应用的服务器用户与服务器组
关于在内存OOM的情况下, 这个应用程序是否要被KILL ,值从1000到-1000开始, 这边我们设置在缺乏内存的情况下,不KILL Postgresql 的服务.
OOMScoreAdjust=-1000
Environment=PG_OOM_ADJUST_FILE=/proc/self/oom_score_adj
Environment=PG_OOM_ADJUST_VALUE=0
# PGSTARTTIMEOUT should be less than TimeoutSec value.
Environment=PGSTARTTIMEOUT=300
Environment=PGDATA=/pgdata/data
ExecStart=/usr/local/postgres/bin/pg_ctl start -D {PGDATA} -s -w -t {PGSTARTTIMEOUT}
ExecStop=/usr/local/postgres/bin/pg_ctl stop -D ${PGDATA} -s -m fast
ExecReload=/usr/local/postgres/bin/pg_ctl reload -D ${PGDATA} -s
ExecStart 就是实际执行此服务的程序。接受 "命令 参数 参数..." 的格式,不能接受 <, >, >>, |, & 等特殊字符,很多的 bash 语法也不支持。所以,要使用这些特殊的字符时,最好直接写入到脚本里面去!
ExecStop 用来实现 systemctl stop 命令,关闭服务。
ExecReload 用来实现 systemctl reload 命令,重新加载服务的配置信息。
TimeoutSec=300
设置如果在关闭或打开服务时并不顺利,则强制打开或关闭在300秒后开始
KillMode=mixed
- control-group(默认值):当前控制组里面的所有子进程,都会被杀掉
- process:只杀主进程
- mixed:主进程将收到 SIGTERM 信号,子进程收到 SIGKILL 信号
- none:没有进程会被杀掉,只是执行服务的 stop 命令。
[Install]
WantedBy=multi-user.target
在建立文件后, postgresql.serivce 需要将文件
加载进systemctl 并且在打开 enable
sudo systemctl daemon-reload
sudo systemctl enable postgresql
直接通过命令来判断服务器的启动或关闭的状态
代码语言:javascript复制systemctl is-active postgresql.service
POSTGRESQL 打开、关闭、重启、状态,就都通过systemd 的方式来进行了。
代码语言:javascript复制