- hosts: new
tasks:
- name: clean no need repo config
command: rm -f /etc/yum.repos.d/*
notify:
- Remove all old repo config
- name: cp rhel.repo
copy: src=rhel.repo dest=/etc/yum.repos.d/rhel.repo owner=root group=root mode=0644
- name: upgrade all packages
yum: name=* state=latest
copy
和yum
模块不能使用notify
,而command
模块可以使用notify
建议不要使用rm
命令,改为使用file
模块的state=absent
,因为执行时候有提示 [WARNING]: Consider using file module with state=absent rather than running rm
- hosts: new
tasks:
- shell: ls -1 /etc/yum.repos.d
register: contents
- file: path=/etc/yum.repos.d/{{ item }} state=absent
with_items: contents.stdout_lines
- name: cp rhel.repo
copy: src=rhel.repo dest=/etc/yum.repos.d/rhel.repo owner=root group=root mode=0644
- name: upgrade all packages
yum: name=* state=latest
- name: cp epel.rpm
copy: src=epel-release-latest-7.noarch.rpm dest=/tmp/epel-release-latest-7.noarch.rpm
- name: Install package.
yum:
name: /tmp/epel-release-latest-7.noarch.rpm
state: present
- shell: ls -1 /some/dir
register: contents
- file: path=/some/dir/{{ item }} state=absent
with_items: contents.stdout_lines
when: item not in managed_files
- shell: (cd /remote; find . -maxdepth 1 -type f) | cut -d'/' -f2
register: files_to_copy
- fetch: src=/remote/{{ item }} dest=/local/
with_items: files_to_copy.stdout_lines
- name: Creates directory
file: path=/src/www state=directory
- name: Copy rpm file to server
copy:
src: package.rpm
dest: /tmp/package.rpm
- name: Install package.
yum:
name: /tmp/package.rpm
state: present
ansible-playbook upgrade_centos.yml -f 10
- name: upgrade all packages
sudo: true
yum: name=* state=latest