AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / unix / Perguntas / 481535
Accepted
user288221
user288221
Asked: 2018-11-14 09:41:36 +0800 CST2018-11-14 09:41:36 +0800 CST 2018-11-14 09:41:36 +0800 CST

O systemd pode 'adotar' ou 'herdar' um processo ou cgroup?

  • 772

Tenho um serviço que gostaria de gerenciar através do systemd - vamos chamá-lo de foo. Eu escrevi arquivos de unidade, e eles estão funcionando muito bem. Portanto, se eu executar systemctl start foo, o serviço será iniciado corretamente e posso ver seu status com systemctl status foo.

No entanto, um programa externo também pode iniciar o serviço e não usa o systemd para iniciar o serviço. Portanto, o serviço pode estar em execução, mas como não foi iniciado pelo systemd, o systemd não sabe disso. Nesse caso, systemctl status fooinforma que o serviço falhou, embora esteja sendo executado corretamente.

Existe uma maneira de fazer com que o systemd 'herda' ou 'adote' este serviço, para systemctl status fooinformar corretamente que o serviço está em execução, mesmo quando o systemd não o iniciou? Com SysV, eu escreveria um pequeno script de 'status', então eu poderia /etc/init.d/foo status, mas isso não parece se encaixar no modelo systemd.

Para ser claro, quando o programa externo inicia o serviço, os processos do serviço ainda são filhos de PID 1/systemd. Mas o systemd não os reconhece como parte do serviço foo, pois o systemd não os iniciou e os registrou.

As tecnologias específicas são:

  • Oracle WebLogic (o serviço é uma Instância WebLogic Gerenciada)
  • Oracle NodeManager (este é o programa externo que também pode iniciar o serviço)
  • systemd 219
systemd oracle-linux
  • 2 2 respostas
  • 750 Views

2 respostas

  • Voted
  1. Best Answer
    JdeBP
    2018-11-14T10:47:17+08:002018-11-14T10:47:17+08:00

    Não. O processo será executado em um contexto diferente no que diz respeito ao systemd.

    Esta é, de fato, uma das razões pelas quais a ativação do serviço Desktop Bus deve ser evitada. Os processos de serviço gerados diretamente pelo agente do Desktop Bus fazem parte de seu serviço, no que diz respeito ao systemd.

    Pode-se mover processos entre grupos de controle, com privilégios apropriados. Mas isso é apenas metade do trabalho, e a outra metade, a de convencer o systemd de que iniciou uma unidade quando não o fez e reescrever as partes necessárias de suas estruturas de dados internas, não está prevista.

    Este não é apenas o modelo do systemd, não é o modelo da maioria dos subsistemas de gerenciamento de serviços.

    As unidades de serviço "muito boas" de muitas pessoas para softwares Oracle na verdade não são, a propósito, e estão no território da House of Horror .

    Leitura adicional

    • systemctl não relata com precisão o status dos daemons se eles foram iniciados por meio de um mecanismo diferente do systemctl
    • configurar daemon java com systemd
    • https://unix.stackexchange.com/a/437461/5132
    • Jonathan de Boyne Pollard (2016). Evite a ativação do barramento Desktop Bus (D-Bus) . nosh. Programas.
    • Jonathan de Boyne Pollard (2015). O sistema House of Horror . Respostas Frequentes.
    • 4
  2. filbranden
    2018-11-14T11:27:55+08:002018-11-14T11:27:55+08:00

    Em resumo, não há como fazer com que o systemd considere um serviço a ser iniciado, a menos que tenha sido iniciado pelo próprio systemd. Um dos principais pontos do systemd é a consistência no gerenciamento de serviços e ter formas separadas de iniciar um serviço vai contra essa ideia.

    Agora, o systemd tem uma provisão para gerenciar processos que são iniciados externamente, o que parece ser adequado para o caso que você descreve. Na verdade, esse é um tipo separado de unidade, uma unidade de escopo .

    O uso de uma unidade de osciloscópio ainda requer que seu sistema externo interaja com o systemd, pois uma unidade de osciloscópio só pode ser iniciada com uma solicitação D-Bus ao systemd, na qual é passado um PID que é usado como processo inicial no osciloscópio. Além disso, quando uma unidade de escopo é iniciada, o systemd ainda deseja criar os próprios cgroups (ele então moverá o PID passado para os cgroups criados). como escopo.

    Resumindo, evite ter duas maneiras separadas de iniciar um serviço. Se você precisar usar o gerenciador de serviços de terceiros, use apenas isso.

    Se o problema que você está tentando resolver é iniciar o serviço durante a inicialização, então:

    1. Verifique se o gerenciador de terceiros (no seu caso, Oracle NodeManager) oferece suporte à configuração de serviços durante a inicialização. Como está gerenciando o serviço, ele também deve gerenciar o serviço durante a inicialização.

    2. Se você envolver o systemd, use uma oneshotunidade de serviço simples que simplesmente solicite que o gerente de terceiros inicie o serviço. Isso significa entrar em contato com o gerenciador de terceiros (no seu caso, Oracle NodeManager) por meio de uma API ou RPC de algum tipo, talvez por meio de HTTP, e dizer a ele para iniciar o serviço.

    Se você usar o systemd oneshotpara inicialização, nomeie sua unidade apropriadamente (como "start-foo" ou "initial-foo" ou "foo-startup") para deixar claro que não ficará "up" e mantenha RemainAfterExit=como no( o padrão), portanto, verificar o status dessa unidade apenas dirá que foi concluído com êxito, portanto, não há confusão sobre isso refletir o status do serviço em execução no gerenciador de terceiros.

    • 1

relate perguntas

  • Níveis diferenciadores no journalctl

  • Altere o editor padrão para vim para _ sudo systemctl edit [unit-file] _

  • systemd: como posso executar um script no início de um serviço, sem editar a definição do serviço

  • Use o suporte de watchdog do systemd para reiniciar o aplicativo

  • Inicie/pare o serviço systemd usando o atalho de teclado [fechado]

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Como exportar uma chave privada GPG e uma chave pública para um arquivo

    • 4 respostas
  • Marko Smith

    ssh Não é possível negociar: "nenhuma cifra correspondente encontrada", está rejeitando o cbc

    • 4 respostas
  • Marko Smith

    Como podemos executar um comando armazenado em uma variável?

    • 5 respostas
  • Marko Smith

    Como configurar o systemd-resolved e o systemd-networkd para usar o servidor DNS local para resolver domínios locais e o servidor DNS remoto para domínios remotos?

    • 3 respostas
  • Marko Smith

    Como descarregar o módulo do kernel 'nvidia-drm'?

    • 13 respostas
  • Marko Smith

    apt-get update error no Kali Linux após a atualização do dist [duplicado]

    • 2 respostas
  • Marko Smith

    Como ver as últimas linhas x do log de serviço systemctl

    • 5 respostas
  • Marko Smith

    Nano - pule para o final do arquivo

    • 8 respostas
  • Marko Smith

    erro grub: você precisa carregar o kernel primeiro

    • 4 respostas
  • Marko Smith

    Como baixar o pacote não instalá-lo com o comando apt-get?

    • 7 respostas
  • Martin Hope
    rocky Como exportar uma chave privada GPG e uma chave pública para um arquivo 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Wong Jia Hau ssh-add retorna com: "Erro ao conectar ao agente: nenhum arquivo ou diretório" 2018-08-24 23:28:13 +0800 CST
  • Martin Hope
    Evan Carroll status systemctl mostra: "Estado: degradado" 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim Como podemos executar um comando armazenado em uma variável? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S Por que /dev/null é um arquivo? Por que sua função não é implementada como um programa simples? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 Como ver as últimas linhas x do log de serviço systemctl 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - pule para o final do arquivo 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla Por que verdadeiro e falso são tão grandes? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis Substitua a string em um arquivo de texto enorme (70 GB), uma linha 2017-12-30 06:58:33 +0800 CST
  • Martin Hope
    Bagas Sanjaya Por que o Linux usa LF como caractere de nova linha? 2017-12-20 05:48:21 +0800 CST

Hot tag

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve