Este é um exemplo de manual de orquestração de servidores e é algo que o Chef inerentemente não se destina a fazer. Conforme observado por Tensibai, um servidor executando o Chef é um sistema convergente que alcança seu próprio estado desejado com base nas definições de configuração definidas por receitas, atributos, data bags, etc. Sem entrar em detalhes específicos sobre sua infraestrutura, algumas abordagens ser capaz de tomar são:
Crie operações independentes independentes
Como você afirmou em sua pergunta, a criação de um estado de operação em que seus nós possam ser executados repetidamente até que todas as tarefas sejam concluídas não é dimensionado corretamente. No entanto, pode ser possível redesenhar seus nós para que isso não importe. Se os nós a e b executam tarefas para produzir seus logs em paralelo, e b é concluído antes de a, ele pode executar a tarefa que o nó a normalmente executaria e vice-versa.
Use um orquestrador externo para delegação
O uso de um nó delegador definitivamente será muito melhor se você pretender ter muitos nós para orquestrar. No entanto, isso pode criar conflitos com a execução do cliente chef nos nós que estão sendo gerenciados pelo delegador. Seria muito difícil verificar se as configurações do nó e as tarefas do nó do delegador não entram em conflito. Uma maneira inteligente de gerenciar isso pode ser incorporar as tarefas na configuração de cada nó e fazer com que o delegador defina um valor em um pacote de dados ou atributo do servidor para sinalizar como ele deve se configurar (ou seja, quais tarefas ele precisa executar) )
Combine sua infraestrutura
Se cada nó executar tarefas em série, dependendo dos outros nós, e você não terá dependências técnicas / de custo em tarefas em execução em nós diferentes, convém considerar a combinação de suas configurações de nó em um único nó. Isso eliminaria quaisquer conflitos de configuração que você teria entre qualquer um dos seus nós. Eu imagino que haja intenções claras para executar suas tarefas em nós diferentes, mas essa é definitivamente uma opção a considerar (talvez mesmo com o tempo gasto para reescrever tarefas para nós diferentes).
Use SaltStack para orquestrar suas execuções de chef.
Sua lógica de orquestração entre nós está aqui https://docs.saltstack.com/en/latest/topics/orchestrate/orchestrate_runner.html#more-complex-orchestration
E você pode declarativamente https://docs.saltstack.com/en/latest/ref/states/all/salt.states.chef.html
ou imperativamente https://docs.saltstack.com/en/latest/ref/modules/all/salt.modules.chef.html
direcione os nós do Chef ao estado desejado.
fonte