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 / computer / Perguntas / 1664197
Accepted
rawat
rawat
Asked: 2021-07-23 22:18:07 +0800 CST2021-07-23 22:18:07 +0800 CST 2021-07-23 22:18:07 +0800 CST

Palavra-chave Ansible - acelerador

  • 772

Estou tentando usar e entender como funciona a palavra-chave acelerador.

Abaixo está como estou usando (test-playbook.yaml).

---
- name: Test throttle
  hosts: all
  
  tasks:

    # list of pre tasks
    
    - name: Execute sequentially
      throttle: 1
      block:
        - include_tasks: task-1.yaml
        
        - include_tasks: task-2.yaml
        
        # a task using some module
        
        # a task using some module

    # list of post tasks

Executadoansible-playbook --inventory some-inventory --limit host1:host2:host3

Estou esperando que em task (Execute sequencialmente) , todos os hosts especificados em --limit serão executados sequencialmente, ou seja, host1 concluirá todas as tarefas no bloco, depois host2 seguido por host3

Mas eles são executados em paralelo (comportamento padrão do Ansible).

Alguém pode ajudar a entender o comportamento do acelerador ? Perdi alguma configuração?

forks/serialtêm valores padrão.

E como posso conseguir um comportamento sequencial.

ansible
  • 1 1 respostas
  • 1515 Views

1 respostas

  • Voted
  1. Best Answer
    Vladimir Botka
    2021-07-24T01:12:19+08:002021-07-24T01:12:19+08:00

    O comportamento padrão do ansible-playbook é a estratégia linear :

    A execução da tarefa está em lockstep por lote de host conforme definido por serial (padrão tudo) . Até o limite do fork de hosts, cada tarefa será executada ao mesmo tempo e, em seguida, a próxima série de hosts até que o lote seja concluído, antes de passar para a próxima tarefa .

    O acelerador serve ao propósito de " limitar o número de trabalhadores para uma tarefa específica... Use o acelerador para restringir tarefas que podem consumir muita CPU ou interagir com uma API de limitação de taxa ".

    Por exemplo, por padrão, execute a tarefa em paralelo (limitado por serial até os forks ) hosts

    - hosts: host1,host2,host3
      tasks:
        - command: sleep 1
          register: result
        - debug:
            msg: "{{ inventory_hostname }} task1
                  {{ result.start }} - {{ result.end }}"
    

    Você pode ver que todos os hosts executaram a tarefa em paralelo

    ok: [host2] => 
      msg: host2 task1 2021-07-23 08:56:14.735263 - 2021-07-23 08:56:15.759474
    ok: [host1] => 
      msg: host1 task1 2021-07-23 08:56:14.743419 - 2021-07-23 08:56:15.759518
    ok: [host3] => 
      msg: host3 task1 2021-07-23 08:56:14.475249 - 2021-07-23 08:56:15.551159
    

    Se você limitar a execução por acelerador

        - command: sleep 1
          register: result
          throttle: 1
        - debug:
            msg: "{{ inventory_hostname }} task2
                  {{ result.start }} - {{ result.end }}"
    

    Você pode ver que a execução da tarefa foi serializada

    ok: [host2] => 
      msg: host2 task2 2021-07-23 08:56:20.252623 - 2021-07-23 08:56:21.312210
    ok: [host3] => 
      msg: host3 task2 2021-07-23 08:56:22.688410 - 2021-07-23 08:56:23.744130
    ok: [host1] => 
      msg: host1 task2 2021-07-23 08:56:17.937011 - 2021-07-23 08:56:18.955631
    

    Certifique-se de que a hora foi sincronizada antes de começar a experimentar.


    P: " Usando include_tasks não estou obtendo o mesmo comportamento. Todas as tarefas incluídas estão sendo executadas em paralelo. "

    R: Não consigo reproduzir seu problema. Dados os arquivos

    shell> ansible --version
    ansible 2.10.1
    
    shell> cat test-119-tasks-2.yml
    ---
    - command: sleep 1
      register: result
    - debug:
        msg: "{{ inventory_hostname }} task2
              {{ result.start }} - {{ result.end }}"
    
    shell> cat test-119-tasks-3.yml
    ---
    - command: sleep 1
      register: result
    - debug:
        msg: "{{ inventory_hostname }} task3
              {{ result.start }} - {{ result.end }}"
    

    a tarefa

        - name: Execute sequentially
          throttle: 1
          block:
            - include_tasks: test-119-tasks-2.yml
            - include_tasks: test-119-tasks-3.yml
    

    dá

    TASK [include_tasks] ***********************************************
    included: /export/scratch/tmp8/test-119-tasks-2.yml for host1, host2, host3
    TASK [command] *****************************************************
    changed: [host1]
    changed: [host2]
    changed: [host3]
    
    TASK [debug] *******************************************************
    ok: [host1] => 
      msg: host1 task2 2021-07-25 10:56:11.832219 - 2021-07-25 10:56:12.848834
    ok: [host2] => 
      msg: host2 task2 2021-07-25 10:56:14.312498 - 2021-07-25 10:56:15.330202
    ok: [host3] => 
      msg: host3 task2 2021-07-25 10:56:16.751018 - 2021-07-25 10:56:17.774723
    
    TASK [include_tasks] ***********************************************
    included: /export/scratch/tmp8/test-119-tasks-3.yml for host1, host2, host3
    
    TASK [command] ******************************************************
    changed: [host1]
    changed: [host2]
    changed: [host3]
    
    TASK [debug] ********************************************************
    ok: [host1] => 
      msg: host1 task3 2021-07-25 10:56:20.373052 - 2021-07-25 10:56:21.405847
    ok: [host2] => 
      msg: host2 task3 2021-07-25 10:56:22.761254 - 2021-07-25 10:56:23.788941
    ok: [host3] => 
      msg: host3 task3 2021-07-25 10:56:25.134650 - 2021-07-25 10:56:26.151786
    

    Você pode ver que a execução das tarefas incluídas foi serializada. Isso funciona como esperado porque a palavra-chave acelerador é permitida no bloco . A aplicação dessa palavra-chave a um bloco é a mesma que a aplicação dessa palavra-chave a todas as tarefas do bloco.

    • 2

relate perguntas

  • Como definir permissões de arquivo em uma árvore no Ansible

  • Edite o arquivo de cofre ansible no código do Visual Studio

  • Como misturar usuários privilegiados e não privilegiados em um playbook?

  • Como usar variáveis ​​de modelo em group_vars

  • O Ansible trava ao executar o playbook pela segunda vez

Sidebar

Stats

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

    Como posso reduzir o consumo do processo `vmmem`?

    • 11 respostas
  • Marko Smith

    Baixar vídeo do Microsoft Stream

    • 4 respostas
  • Marko Smith

    O Google Chrome DevTools falhou ao analisar o SourceMap: chrome-extension

    • 6 respostas
  • Marko Smith

    O visualizador de fotos do Windows não pode ser executado porque não há memória suficiente?

    • 5 respostas
  • Marko Smith

    Como faço para ativar o WindowsXP agora que o suporte acabou?

    • 6 respostas
  • Marko Smith

    Área de trabalho remota congelando intermitentemente

    • 7 respostas
  • Marko Smith

    O que significa ter uma máscara de sub-rede /32?

    • 6 respostas
  • Marko Smith

    Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows?

    • 1 respostas
  • Marko Smith

    O VirtualBox falha ao iniciar com VERR_NEM_VM_CREATE_FAILED

    • 8 respostas
  • Marko Smith

    Os aplicativos não aparecem nas configurações de privacidade da câmera e do microfone no MacBook

    • 5 respostas
  • Martin Hope
    Saaru Lindestøkke Por que os arquivos tar.xz são 15x menores ao usar a biblioteca tar do Python em comparação com o tar do macOS? 2021-03-14 09:37:48 +0800 CST
  • Martin Hope
    CiaranWelsh Como posso reduzir o consumo do processo `vmmem`? 2020-06-10 02:06:58 +0800 CST
  • Martin Hope
    Jim Pesquisa do Windows 10 não está carregando, mostrando janela em branco 2020-02-06 03:28:26 +0800 CST
  • Martin Hope
    v15 Por que uma conexão de Internet gigabit/s via cabo (coaxial) não oferece velocidades simétricas como fibra? 2020-01-25 08:53:31 +0800 CST
  • Martin Hope
    andre_ss6 Área de trabalho remota congelando intermitentemente 2019-09-11 12:56:40 +0800 CST
  • Martin Hope
    Riley Carney Por que colocar um ponto após o URL remove as informações de login? 2019-08-06 10:59:24 +0800 CST
  • Martin Hope
    zdimension Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows? 2019-08-04 06:39:57 +0800 CST
  • Martin Hope
    jonsca Todos os meus complementos do Firefox foram desativados repentinamente, como posso reativá-los? 2019-05-04 17:58:52 +0800 CST
  • Martin Hope
    MCK É possível criar um código QR usando texto? 2019-04-02 06:32:14 +0800 CST
  • Martin Hope
    SoniEx2 Altere o nome da ramificação padrão do git init 2019-04-01 06:16:56 +0800 CST

Hot tag

windows-10 linux windows microsoft-excel networking ubuntu worksheet-function bash command-line hard-drive

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