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 / server / Perguntas / 883314
Accepted
Gerald Schneider
Gerald Schneider
Asked: 2017-11-14 23:15:02 +0800 CST2017-11-14 23:15:02 +0800 CST 2017-11-14 23:15:02 +0800 CST

Mostrar pacotes atualizados com o gerenciamento de pacotes Ansible

  • 772

Eu tenho um playbook Ansible simples que uso para executar atualizações em todos os servidores que gerencio:

- hosts: ubuntu
  tasks:
  - name: install all updates
    apt:
      upgrade: dist
      update_cache: yes
      autoremove: yes
      autoclean: yes
- hosts: centos
  tasks:
  - name: install all updates
    yum:
      name: '*'
      update_cache: yes
      state: latest
# use debug to show the output
    register: result
  - name: Show Output
    debug: msg="{{ result.stdout_lines }}"

Existe alguma maneira de fazer com que o Ansible me mostre quais pacotes são atualizados no processo? Nem o módulo apt nem o yum fornecem uma opção para isso.

A versão do Ansible atualmente usada é 2.4.

ansible
  • 2 2 respostas
  • 14211 Views

2 respostas

  • Voted
  1. Best Answer
    Gerald Schneider
    2017-11-17T01:24:15+08:002017-11-17T01:24:15+08:00

    Começando com o comentário de HBruijn, estendi meu playbook para mostrar o resultado dos logs de gerenciamento de pacotes posteriormente:

    ---
    
    - hosts: ubuntu
      tasks:
      - name: install all updates
        apt:
          upgrade: dist
          update_cache: yes
          autoremove: yes
          autoclean: yes
        register: result
      - name: List installed and updated packages
        shell: grep -E "^$(date +%Y-%m-%d).+ (install|upgrade) " /var/log/dpkg.log |cut -d " " -f 3-5
        register: result
      - name: Show Output
        debug: msg="{{ result.stdout_lines }}"
    - hosts: centos
      tasks:
      - name: install all updates
        yum:
          name: '*'
          update_cache: yes
          state: latest
      - name: List updated packages
        shell: rpm -qa --last | grep "$(date +%a\ %d\ %b\ %Y)" |cut -f 1 -d " "
        register: result
        args:
          warn: no
      - name: Updates packages
        debug: msg="{{ result.stdout_lines }}"
    

    A saída resultante:

    ok: [ubuntu-host] => {
        "msg": [
            "upgrade python3-problem-report:all 2.14.1-0ubuntu3.25",
            "upgrade python3-apport:all 2.14.1-0ubuntu3.25",
            "upgrade apport:all 2.14.1-0ubuntu3.25",
            "upgrade firefox:i386 56.0+build6-0ubuntu0.14.04.2",
            "upgrade python-problem-report:all 2.14.1-0ubuntu3.25",
            "upgrade python-apport:all 2.14.1-0ubuntu3.25",
            "upgrade xul-ext-ubufox:all 3.4-0ubuntu0.14.04.1"
        ]
    }
    
    ok: [centos-host] => {
        "msg": [
            "kernel-headers-2.6.32-696.16.1.el6.x86_64",
            "lvm2-2.02.143-12.el6_9.1.x86_64",
            "device-mapper-multipath-0.4.9-100.el6_9.1.x86_64",
            "kernel-2.6.32-696.16.1.el6.x86_64",
            "kernel-firmware-2.6.32-696.16.1.el6.noarch",
            "lvm2-libs-2.02.143-12.el6_9.1.x86_64",
            "kpartx-0.4.9-100.el6_9.1.x86_64",
            "device-mapper-multipath-libs-0.4.9-100.el6_9.1.x86_64",
            "device-mapper-event-libs-1.02.117-12.el6_9.1.x86_64",
            "device-mapper-event-1.02.117-12.el6_9.1.x86_64",
            "device-mapper-1.02.117-12.el6_9.1.x86_64",
            "util-linux-ng-2.17.2-12.28.el6_9.1.x86_64",
            "device-mapper-libs-1.02.117-12.el6_9.1.x86_64",
            "libblkid-2.17.2-12.28.el6_9.1.x86_64",
            "libuuid-2.17.2-12.28.el6_9.1.x86_64"
        ]
    }
    

    Esta é uma grande melhoria, mas ainda espero que alguém tenha uma solução melhor.

    • 9
  2. Eric Koldinger
    2019-03-14T15:04:09+08:002019-03-14T15:04:09+08:00

    Adotei a abordagem básica de Gerald Schneider e adicionei algumas condicionais para verificar apenas atualizações se algo mudou. Isso corrige as coisas no caso comum, embora ainda possa gerar um pouco de saída estranha se ocorrer mais de uma atualização por dia.

    - hosts: debian
      become: yes
      tasks:
        - name: Debian/Raspbian Update
          apt:
            update_cache: true
            upgrade: yes
          register: debian
        #- debug:
        #    msg: " {{ debian.stdout_lines }} "
        - name: List installed and updated packages
          shell: grep -E "^$(date +%Y-%m-%d).+ (install|upgrade) " /var/log/dpkg.log |cut -d " " -f 3-5
          register: result
          when: debian.changed
        - name: Show Output
          debug: msg="{{ result.stdout_lines }}"
          when: debian.changed
    

    Gera uma saída muito parecida com:

    TASK [Debian/Raspbian Update] ***************************************************************************************************************************************************************************************************************************************
    ok: [clusterpi-01.local]
    ok: [clusterpi-00.local]
    ok: [clusterpi-03.local]
    ok: [clusterpi-02.local]
    ok: [radpi.local]
    ok: [firefly]
    ok: [blueberrypi.local]
    changed: [blackberrypi.local]
    changed: [snozzberrypi.local]
    ok: [pizero]
    
    TASK [List installed and updated packages] **************************************************************************************************************************************************************************************************************************
    skipping: [radpi.local]
    skipping: [pizero]
    skipping: [blueberrypi.local]
    skipping: [clusterpi-00.local]
    skipping: [clusterpi-01.local]
    skipping: [clusterpi-02.local]
    skipping: [clusterpi-03.local]
    skipping: [firefly]
    changed: [blackberrypi.local]
    changed: [snozzberrypi.local]
    
    TASK [Show Output] **************************************************************************************************************************************************************************************************************************************************
    skipping: [radpi.local]
    ok: [snozzberrypi.local] => {
        "msg": [
            "upgrade rpi-chromium-mods:armhf 20190218",
            "upgrade wiringpi:armhf 2.46"
        ]
    }
    skipping: [pizero]
    ok: [blackberrypi.local] => {
        "msg": [
            "upgrade rpi-chromium-mods:armhf 20190218",
            "upgrade wiringpi:armhf 2.46"
        ]
    }
    skipping: [blueberrypi.local]
    skipping: [clusterpi-00.local]
    skipping: [clusterpi-01.local]
    skipping: [clusterpi-02.local]
    skipping: [clusterpi-03.local]
    skipping: [firefly]
    

    Testes semelhantes também podem ser facilmente adicionados para distribuições baseadas em dnf/yum.

    • 2

relate perguntas

  • Tarefas Ansible Recorrentes

  • Não é possível formar um link de um arquivo que está em sites disponíveis para um diretório habilitado para sites no servidor remoto usando ansible?

  • como executar um determinado papel do ansible?

  • Ansible e rbash

Sidebar

Stats

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

    Você pode passar usuário/passar para autenticação básica HTTP em parâmetros de URL?

    • 5 respostas
  • Marko Smith

    Ping uma porta específica

    • 18 respostas
  • Marko Smith

    Verifique se a porta está aberta ou fechada em um servidor Linux?

    • 7 respostas
  • Marko Smith

    Como automatizar o login SSH com senha?

    • 10 respostas
  • Marko Smith

    Como posso dizer ao Git para Windows onde encontrar minha chave RSA privada?

    • 30 respostas
  • Marko Smith

    Qual é o nome de usuário/senha de superusuário padrão para postgres após uma nova instalação?

    • 5 respostas
  • Marko Smith

    Qual porta o SFTP usa?

    • 6 respostas
  • Marko Smith

    Linha de comando para listar usuários em um grupo do Windows Active Directory?

    • 9 respostas
  • Marko Smith

    O que é um arquivo Pem e como ele difere de outros formatos de arquivo de chave gerada pelo OpenSSL?

    • 3 respostas
  • Marko Smith

    Como determinar se uma variável bash está vazia?

    • 15 respostas
  • Martin Hope
    Davie Ping uma porta específica 2009-10-09 01:57:50 +0800 CST
  • Martin Hope
    kernel O scp pode copiar diretórios recursivamente? 2011-04-29 20:24:45 +0800 CST
  • Martin Hope
    Robert ssh retorna "Proprietário incorreto ou permissões em ~/.ssh/config" 2011-03-30 10:15:48 +0800 CST
  • Martin Hope
    Eonil Como automatizar o login SSH com senha? 2011-03-02 03:07:12 +0800 CST
  • Martin Hope
    gunwin Como lidar com um servidor comprometido? 2011-01-03 13:31:27 +0800 CST
  • Martin Hope
    Tom Feiner Como posso classificar a saída du -h por tamanho 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich O que é um arquivo Pem e como ele difere de outros formatos de arquivo de chave gerada pelo OpenSSL? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent Como determinar se uma variável bash está vazia? 2009-05-13 09:54:48 +0800 CST

Hot tag

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 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