Ubuntu 16.04 LTS mudando OOMScoreAdjust em /lib/systemd/system/[email protected] não tem efeito

1

Como título, tenho meu postgresql @ .service feito da seguinte maneira:

 # systemd service template for PostgreSQL clusters. The actual instances will
# be called "postgresql@version-cluster", e.g. "[email protected]". The
# variable %i expands to "version-cluster", %I expands to "version/cluster".
# (%I breaks for cluster names containing dashes.)

[Unit]
Description=PostgreSQL Cluster %i
ConditionPathExists=/etc/postgresql/%I/postgresql.conf
PartOf=postgresql.service
ReloadPropagatedFrom=postgresql.service
Before=postgresql.service

[Service]
Type=forking
# @: use "postgresql@%i" as process name
ExecStart=@/usr/bin/pg_ctlcluster postgresql@%i --skip-systemctl-redirect %i start
ExecStop=/usr/bin/pg_ctlcluster --skip-systemctl-redirect -m fast %i stop
ExecReload=/usr/bin/pg_ctlcluster --skip-systemctl-redirect %i reload
PIDFile=/var/run/postgresql/%i.pid
SyslogIdentifier=postgresql@%i
# prevent OOM killer from choosing the postmaster (individual backends will
# reset the score to 0)
OOMScoreAdjust=-999
# restarting automatically will prevent "pg_ctlcluster ... stop" from working,
# so we disable it here. Also, the postmaster will restart by itself on most
# problems anyway, so it is questionable if one wants to enable external
# automatic restarts.
#Restart=on-failure
# (This should make pg_ctlcluster stop work, but doesn't:)
#RestartPreventExitStatus=SIGINT SIGTERM

[Install]
WantedBy=multi-user.target

Então eu cato o / proc / pid / oom_score_adj, ele sempre mostra o valor padrão que é -900. Eu me pergunto o que deu errado?

    
por William Yeung 31.08.2016 / 12:20

2 respostas

1

O serviço definido por /lib/systemd/system/[email protected] start-up /usr/bin/pg_ctlcluster . Por dentro de pg_ctlcluster encontramos isso:

if ($action eq 'start' and $version >= '9.0' and not $PgCommon::rpm) {
    if (-w '/proc/self/oom_score_adj') {
        open F, '>/proc/self/oom_score_adj';
        print F "-900\n";
        close F;
    } 
}

Parece que os próprios scripts do Postgres definem o valor ao iniciar. Eu o editei para -999 e ele fez o trabalho.

    
por 13.09.2016 / 16:42
0

Você precisa recarregar o serviço depois de fazer alterações ou ter certeza absoluta de que a alteração leva os efeitos, interromper o serviço e iniciá-lo novamente.

# maybe
systemctl reload [email protected]

# definitely
systemctl stop [email protected]
systemctl start [email protected]
    
por 31.08.2016 / 19:50