Postgresql systemctl 启动设置与问题

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

直接通过命令来判断服务器的启动或关闭的状态

systemctl   is-active postgresql.service

POSTGRESQL  打开、关闭、重启、状态,就都通过systemd 的方式来进行了。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值