Estou prestes a reiniciar o serviço postgresql 12 em execução no Ubuntu 18. Primeiro, verifico seu status sudo service postgresql status
:. Diz:
postgresql.service - PostgreSQL RDBMS
Loaded: loaded (/lib/systemd/system/postgresql.service; disabled; vendor pres
Active: inactive (dead)
lines 1-3/3 (END)...skipping...
postgresql.service - PostgreSQL RDBMS
Loaded: loaded (/lib/systemd/system/postgresql.service; disabled; vendor preset: enabled)
Active: inactive (dead)
Embora pareça estar inativo, ainda consigo me conectar.
Então executo outra verificação: systemctl status postgresql@12-main
. diz :
root@db-services:/# systemctl status postgresql@12-main
● [email protected] - PostgreSQL Cluster 12-main
Loaded: loaded (/etc/systemd/system/[email protected]; enabled; vendor preset: enabled)
Drop-In: /etc/systemd/system/[email protected]
└─override.conf
Active: active (running) since Mon 2022-06-13 09:02:25 WIB; 5 months 27 days ago
Main PID: 5807 (postgres)
Tasks: 86 (limit: 4915)
CGroup: /system.slice/system-postgresql.slice/[email protected]
├─ 1586 postgres: 12/main: postgres db_sync 10.100.3.248(61414) idle
├─ 1588 postgres: 12/main: postgres db_sync 10.100.3.248(61415) idle
├─ 1606 postgres: 12/main: docreg db_docreg 10.100.8.150(18385) idle
├─ 1607 postgres: 12/main: docreg db_docreg 10.100.8.150(18399) idle
├─ 1608 postgres: 12/main: docreg db_docreg 10.100.8.150(18401) idle
├─ 1609 postgres: 12/main: docreg db_docreg 10.100.8.150(18421) idle
├─ 2592 postgres: 12/main: docudigtl db_docudigtl 10.100.8.112(34956) idle
├─ 3518 postgres: 12/main: docudigtl db_docudigtl 127.0.0.1(48290) idle
├─ 5150 postgres: 12/main: docudigtl db_docudigtl 10.100.7.114(61504) idle
├─ 5807 /usr/lib/postgresql/12/bin/postgres -D /data/postgresql/12/main -c config_file=/etc/postgresql/12/main/postgresql.co
├─ 5883 postgres: 12/main: docudigtl db_docudigtl 127.0.0.1(48626) idle
├─ 6316 postgres: 12/main: docudigtl db_docudigtl 127.0.0.1(48704) idle
├─ 7049 postgres: 12/main: docudigtl db_docudigtl 127.0.0.1(48870) idle
├─ 7986 postgres: 12/main: docudigtl db_docudigtl 10.100.7.114(56240) idle
├─ 8146 postgres: 12/main: docudigtl db_docudigtl 10.100.8.114(47432) idle
├─ 8183 postgres: 12/main: docudigtl db_docudigtl 127.0.0.1(49022) idle
├─ 8360 postgres: 12/main: docudigtl db_docudigtl 127.0.0.1(49036) idle
├─ 8445 postgres: 12/main: docudigtl db_docudigtl 10.100.8.114(47478) idle
├─ 9590 postgres: 12/main: docudigtl db_docudigtl 10.100.8.106(56094) idle
├─ 9687 postgres: 12/main: docudigtl db_docudigtl 10.100.8.112(50980) idle
├─10148 postgres: 12/main: docudigtl db_docudigtl 127.0.0.1(40646) idle
├─10324 postgres: 12/main: docudigtl db_docudigtl 127.0.0.1(40680) idle
├─11079 postgres: 12/main: docudigtl db_docudigtl 127.0.0.1(49496) idle
├─11602 postgres: 12/main: docudigtl db_docudigtl 127.0.0.1(58152) idle
├─11886 postgres: 12/main: docudigtl db_docudigtl 127.0.0.1(44674) idle
├─12106 postgres: 12/main: docudigtl db_docudigtl 127.0.0.1(49618) idle
├─13112 postgres: 12/main: docudigtl db_docudigtl 10.100.6.145(55014) idle
├─13122 postgres: 12/main: docudigtl db_docudigtl 10.100.6.145(55015) idle
├─13145 postgres: 12/main: docudigtl db_mysapk 10.100.6.145(55016) idle
├─13202 postgres: 12/main: docudigtl db_docudigtl 10.100.7.114(62073) idle
├─13945 postgres: 12/main: checkpointer
├─13946 postgres: 12/main: background writer
├─13947 postgres: 12/main: walwriter
├─13948 postgres: 12/main: autovacuum launcher
├─13949 postgres: 12/main: stats collector
├─13950 postgres: 12/main: logical replication launcher
Então está realmente ativo!
- Qual é a diferença entre os 2 comandos?
- Qual devo usar para reiniciar:
systemctl restart postgresql@12-main
ORsudo service postgresql restart
?
Responder1
Existem serviços especiais do systemd chamadosserviços de modelo.
Um serviço de modelo pode receber um argumento como este: template_service@argument
.
Um serviço de modelo nunca é iniciado por si só, mas pode ser instanciado com um determinado argumento. Isto significa que o mesmo serviço (modelo) pode estar em execução em múltiplas instâncias, cada uma identificada pelo seu argumento. Por exemplo:
systemctl iniciar template_service@a
systemctl iniciar template_service@b
systemctl iniciar template_service@c
No Debian e em algumas distribuições derivadas (como Ubuntu):
Cada instância (cluster) do PostgreSQL pertence a um postgresql@
serviço de modelo instanciado. O argumento para o postgresql@
serviço assume a forma de version-clustername
.
Assim, por exemplo, postgresql@12-main
é um serviço systemd que representa uma instância do servidor PostgreSQL 12 (cluster), com o nome do cluster main
(que é o padrão).
Existe outro serviço systemd chamado simplesmente postgresql
. Este é um tipo de serviço abrangente. Se você iniciar ou parar, todas as instâncias do PostgreSQL serão iniciadas ou interrompidas (esse comportamento pode ser desabilitado emstart.conf
).
No entanto, você não pode usar systemctl status postgresql
para verificar se algum serviço PostgreSQL está em execução, mesmo se você tiver apenas um único servidor PostgreSQL configurado em seu sistema. Você deve sempre verificar o status do serviço instanciado específico para obter um relatório de status significativo.
Oservice
O comando foi usado para o antigo sistema init (SysV init), antes do surgimento do systemd. Ainda funciona para compatibilidade com versões anteriores, mas você realmente deve usar o systemctl
comando em sistemas onde o systemd está disponível.