&&를 사용한 awk 명령

&&를 사용한 awk 명령

내가 하고 싶은 것은 호스트 이름과 vlume의 50% 이상을 얻을 수 있도록 Ansible과 함께 awk를 사용하는 것입니다.

그런 다음 다음 명령을 실행하여 볼륨을 50% 이상으로 설정할 수 있습니다.

ansible-playbook pb-servermgmt_runcommand_goce.yml --extra-vars "hostlist=test01 command='df -hlT -x tmpfs -x devtmpfs -x iso9660 --total'" | awk '0+$6 >= 50 {print}'
        "/dev/mapper/rhel-root xfs    50G   35G   16G  70% /",

다음 명령을 실행하여 서버 이름을 표시할 수 있습니다.

ansible-playbook pb-servermgmt_runcommand_goce.yml --extra-vars "hostlist=test01 command='df -hlT -x tmpfs -x devtmpfs -x iso9660 --total'" | awk '/ok/ {print}'
ok: [test01] => {
test01                 : ok=2    changed=1    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0

나는 다음과 같은 출력을 원한다

ok: [test01] => {
        "/dev/mapper/rhel-root xfs    50G   35G   16G  70% /",

나는 그것을보고 있지만 &&쓰기 구문을 얻지 못했습니다. 어떤 아이디어가 있나요?

답변1

묻다:"사용률이 50% 이상인 호스트 이름과 볼륨을 가져옵니다."

답: 그것보다는필터 사용커뮤니티.일반.jc명령의 출력을 구문 분석합니다. 등록 명령의 출력

    - command: "{{ command }}"
      register: out

그리고 변수 선언

    my_df: "{{ out.stdout|community.general.jc('df') }}"

예를 들어 다음 스크립트는

- hosts: "{{ hostlist }}"

  vars:

    my_df: "{{ out.stdout|community.general.jc('df') }}"

  tasks:

    - command: "{{ command }}"
      register: out

    - debug:
        var: my_df

주어진 (요약된)

shell> ansible-playbook pb.yml -e "hostlist=test01 command='df -hlT --total'"

PLAY [test01] *************************************************************************************

TASK [command] ************************************************************************************
changed: [test01]

TASK [debug] **************************************************************************************
ok: [test01] => 
  my_df:
  - available: 1
    filesystem: devtmpfs
    mounted_on: /dev
    size: 1.9G
    type: devtmpfs
    use_percent: 0
    used: 0
  - available: 1
    filesystem: tmpfs
    mounted_on: /dev/shm
    size: 1.9G
    type: tmpfs
    use_percent: 0
    used: 0
  - available: 1
    filesystem: tmpfs
    mounted_on: /run
    size: 1.9G
    type: tmpfs
    use_percent: 11
    used: 193
  - available: 1
    filesystem: tmpfs
    mounted_on: /sys/fs/cgroup
    size: 1.9G
    type: tmpfs
    use_percent: 0
    used: 0
  - available: 2
    filesystem: /dev/mapper/cl-root
    mounted_on: /
    size: 18G
    type: xfs
    use_percent: 86
    used: 15
  - available: 820
    filesystem: /dev/sda2
    mounted_on: /boot
    size: 1014M
    type: xfs
    use_percent: 20
    used: 195
  - available: 592
    filesystem: /dev/sda1
    mounted_on: /boot/efi
    size: 599M
    type: vfat
    use_percent: 2
    used: 7
  - available: 374
    filesystem: tmpfs
    mounted_on: /run/user/1000
    size: 374M
    type: tmpfs
    use_percent: 0
    used: 0
  - available: 12
    filesystem: total
    mounted_on: '-'
    size: 27G
    type: '-'
    use_percent: 58
    used: 16
...

그런 다음 이 목록을 사용할 수 있습니다.my_df그리고선택하다또는거부하다당신은 무엇을 원합니까? 바라보다진자 테스트. 예를 들어 모든 유형의 파일 시스템을 선택합니다.xfs이용률이 50%를 초과했습니다.

    my_df_xfs_50: "{{ my_df|selectattr('type', '==', 'xfs')|
                            selectattr('use_percent', '>', 50)}}"

, 또는 파일 시스템 선택/dev/mapper/cl-루트

    my_df_root: "{{ my_df|selectattr('filesystem', '==', '/dev/mapper/cl-root') }}"

이 예에서는 둘 다 동일한 결과를 제공합니다.

  my_df_xfs_50:
  - available: 2
    filesystem: /dev/mapper/cl-root
    mounted_on: /
    size: 18G
    type: xfs
    use_percent: 86
    used: 15
  my_df_root:
  - available: 2
    filesystem: /dev/mapper/cl-root
    mounted_on: /
    size: 18G
    type: xfs
    use_percent: 86
    used: 15

50%가 넘는 사용량으로 호스트 이름 및 볼륨에 쓰기

다음 사전을 선언하십시오.

  report: "{{ dict(ansible_play_hosts|
                   zip(ansible_play_hosts|
                       map('extract', hostvars, 'my_df_xfs_50'))) }}"

디버그

    - set_fact:
        my_df_xfs_50: "{{ my_df_xfs_50 }}"
    - debug:
        msg: |
          {{ report }}
      run_once: true

주어진

    test01:
    - available: 2
      filesystem: /dev/mapper/cl-root
      mounted_on: /
      size: 18G
      type: xfs
      use_percent: 86
      used: 15

바라보다:


묻다:"설정 모듈을 통해 가능한 사실로부터 이 정보를 얻는 것이 이미 가능하지 않나요?"

대답: 그렇습니다. 명령보다는df, 사용할 수 있습니다ansible_mounts수집기설정. 이 목록은 사용 비율을 제공하지 않습니다. 목록을 업데이트하려면 이 속성을 사용합니다. 그런 다음 다음 스크립트

shell> cat pb.yml
- hosts: "{{ hostlist }}"

  vars:

    ansible_mounts_update_str: |
      {% for i in ansible_mounts %}
      {% set use_percent = 100 - i.size_available / i.size_total * 100 %}
      - {{ i|combine({'use_percent': use_percent|round|int}) }}
      {% endfor %}
    ansible_mounts_update: "{{ ansible_mounts_update_str|from_yaml }}"

    my_df_xfs_50: "{{ ansible_mounts_update|
                      selectattr('fstype', '==', 'xfs')|
                      selectattr('use_percent', '>', 50) }}"
    my_df_root: "{{ ansible_mounts_update|
                    selectattr('device', '==', '/dev/mapper/cl-root') }}"

    report: "{{ dict(ansible_play_hosts|
                     zip(ansible_play_hosts|
                         map('extract', hostvars, 'my_df_xfs_50'))) }}"

  tasks:

    - setup:
        gather_subset: mounts
    - debug:
        var: ansible_mounts
    - debug:
        var: ansible_mounts_update

    - debug:
        var: my_df_xfs_50
    - debug:
        var: my_df_root

    - set_fact:
        my_df_xfs_50: "{{ my_df_xfs_50 }}"
    - debug:
        msg: |
          {{ report }}
      run_once: true

(요약된) 동일한 결과를 제공합니다.

shell> ansible-playbook pb.yml -e "hostlist=test01"

PLAY [test01] *************************************************************************************

TASK [setup] **************************************************************************************
ok: [test01]

...

TASK [debug] **************************************************************************************
ok: [test01] => 
  my_df_xfs_50:
  - block_available: 617954
    block_size: 4096
    block_total: 4561408
    block_used: 3943454
    device: /dev/mapper/cl-root
    fstype: xfs
    inode_available: 4944209
    inode_total: 5351696
    inode_used: 407487
    mount: /
    options: rw,seclabel,relatime,attr2,inode64,logbufs=8,logbsize=32k,noquota
    size_available: 2531139584
    size_total: 18683527168
    use_percent: 86
    uuid: 2cb4d983-108f-40f3-bc22-8afae8edc80a

TASK [debug] **************************************************************************************
ok: [test01] => 
  my_df_root:
  - block_available: 617954
    block_size: 4096
    block_total: 4561408
    block_used: 3943454
    device: /dev/mapper/cl-root
    fstype: xfs
    inode_available: 4944209
    inode_total: 5351696
    inode_used: 407487
    mount: /
    options: rw,seclabel,relatime,attr2,inode64,logbufs=8,logbsize=32k,noquota
    size_available: 2531139584
    size_total: 18683527168
    use_percent: 86
    uuid: 2cb4d983-108f-40f3-bc22-8afae8edc80a

TASK [set_fact] ***********************************************************************************
ok: [test01]

TASK [debug] **************************************************************************************
ok: [test01] => 
  msg:
    test01:
    - block_available: 617954
      block_size: 4096
      block_total: 4561408
      block_used: 3943454
      device: /dev/mapper/cl-root
      fstype: xfs
      inode_available: 4944209
      inode_total: 5351696
      inode_used: 407487
      mount: /
      options: rw,seclabel,relatime,attr2,inode64,logbufs=8,logbsize=32k,noquota
      size_available: 2531139584
      size_total: 18683527168
      use_percent: 86
      uuid: 2cb4d983-108f-40f3-bc22-8afae8edc80a

PLAY RECAP ****************************************************************************************
test01: ok=7    changed=0    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0

관련 정보