forked from saratov/infra
just for test
This commit is contained in:
parent
3835aa7df7
commit
8f3b1f124d
@ -22,7 +22,7 @@
|
|||||||
when: nic.value.search is defined
|
when: nic.value.search is defined
|
||||||
|
|
||||||
- name: "{{nic.key}} | set IP addresses (async)"
|
- name: "{{nic.key}} | set IP addresses (async)"
|
||||||
shell: egrep -q "^{{item|ipaddr('address')}}/{{item|ipaddr('prefix')}}$" /etc/net/ifaces/"{{nic.key}}"/ipv4address || { alterator-cmdline -d /net-eth action add_iface_address name "{{nic.key}}" addip "{{item|ipaddr('address')}}" addmask "{{item|ipaddr('prefix')}}" disabled no ipv 4 configuration "static" ipv_enabled "#t"; echo addr_changed; }
|
shell: egrep -q "^{{item|ipaddr('address')}}/{{item|ipaddr('prefix')}}$" /etc/net/ifaces/"{{nic.key}}"/ipv4address || { alterator-cmdline -d /net-eth action add_iface_address name "{{nic.key}}" addip "{{item|ipaddr('address')}}" addmask "{{item|ipaddr('prefix')}}" ipv 4 configuration "static" ipv_enabled "#t"; echo addr_changed; }
|
||||||
register: result
|
register: result
|
||||||
changed_when: result.stdout is defined and '"addr_changed" in result.stdout'
|
changed_when: result.stdout is defined and '"addr_changed" in result.stdout'
|
||||||
notify: restart network
|
notify: restart network
|
||||||
|
@ -90,11 +90,6 @@
|
|||||||
async: 100
|
async: 100
|
||||||
poll: 0
|
poll: 0
|
||||||
|
|
||||||
- name: restart network service
|
|
||||||
service:
|
|
||||||
name: network
|
|
||||||
state: restarted
|
|
||||||
|
|
||||||
- name: update .tmp/ssh_config after NICs reconfiguration
|
- name: update .tmp/ssh_config after NICs reconfiguration
|
||||||
include_role: name="inventory"
|
include_role: name="inventory"
|
||||||
|
|
||||||
|
144
roles/common/tasks/main.yml.orig
Normal file
144
roles/common/tasks/main.yml.orig
Normal file
@ -0,0 +1,144 @@
|
|||||||
|
---
|
||||||
|
- set_fact: ansible_pkg_mgr=apt_rpm
|
||||||
|
- set_fact: node="{{inventory_hostname_short}}"
|
||||||
|
- set_fact: node="{{stack.nodes[inventory_hostname_short]}}"
|
||||||
|
|
||||||
|
- name: wait nodes for connection
|
||||||
|
wait_for_connection:
|
||||||
|
delay: 3
|
||||||
|
timeout: 60
|
||||||
|
|
||||||
|
- name: disable apt-cache in tmpfs
|
||||||
|
block:
|
||||||
|
- lineinfile:
|
||||||
|
path: /etc/rc.d/rc.local
|
||||||
|
regexp: '^/etc/rc\.d/scripts/apt-cache-on-tmp.*'
|
||||||
|
state: absent
|
||||||
|
backrefs: yes
|
||||||
|
- file:
|
||||||
|
path: /etc/apt/apt.conf.d/tmp.cache.conf
|
||||||
|
state: absent
|
||||||
|
|
||||||
|
- name: purge apt.sources
|
||||||
|
shell: find /etc/apt/sources.list.d/ -name '*.list' -delete
|
||||||
|
changed_when: false
|
||||||
|
|
||||||
|
- name: set apt sources
|
||||||
|
template:
|
||||||
|
src: "apt.list.j2"
|
||||||
|
dest: "/etc/apt/sources.list.d/{{item}}.list"
|
||||||
|
with_items: "{{env.apt.sources}}"
|
||||||
|
|
||||||
|
- name: update packages list
|
||||||
|
shell: apt-get update
|
||||||
|
|
||||||
|
- name: include additional apt repos from tasks
|
||||||
|
template:
|
||||||
|
src: "apt.list.tasks.j2"
|
||||||
|
dest: "/etc/apt/sources.list.d/tasks.list"
|
||||||
|
when: stack.apt_sources_from_tasks is defined
|
||||||
|
|
||||||
|
- name: allow apt downgrade packages
|
||||||
|
template:
|
||||||
|
src: "downgrade.j2"
|
||||||
|
dest: "/etc/apt/preferences.d/downgrade"
|
||||||
|
when: node.arch == 'e2k'
|
||||||
|
|
||||||
|
- name: install common packages
|
||||||
|
apt_rpm:
|
||||||
|
pkg: ntpdate,curl
|
||||||
|
state: installed
|
||||||
|
update_cache: yes
|
||||||
|
|
||||||
|
- name: install Alterator`s modules
|
||||||
|
apt_rpm:
|
||||||
|
pkg: alterator,alterator-net-eth
|
||||||
|
# pkg: alterator,alterator-alternatives,alterator-audit,alterator-bind,alterator-datetime,alterator-dhcp,alterator-groups,alterator-mirror,alterator-mkimage,alterator-net-bond,alterator-net-bridge,alterator-net-domain,alterator-net-eth,alterator-net-functions,alterator-net-iptables,alterator-net-routing,alterator-net-vlan,alterator-packages,alterator-services,alterator-sshd,alterator-sysconfig,alterator-users,alterator-vsftpd,alterator-xinetd
|
||||||
|
state: installed
|
||||||
|
|
||||||
|
# FIX: don't know how to switch from dhcp to static via alterator
|
||||||
|
# just remove this line from options file for now
|
||||||
|
- name: remove options for eth0
|
||||||
|
lineinfile:
|
||||||
|
dest: /etc/net/ifaces/eth0/options
|
||||||
|
regexp: '^BOOTPROTO=dhcp.*'
|
||||||
|
backrefs: yes
|
||||||
|
state: absent
|
||||||
|
|
||||||
|
- name: disable IPv6
|
||||||
|
sysctl: name={{ item }} value=1 state=present
|
||||||
|
with_items:
|
||||||
|
- net.ipv6.conf.all.disable_ipv6
|
||||||
|
- net.ipv6.conf.default.disable_ipv6
|
||||||
|
- net.ipv6.conf.lo.disable_ipv6
|
||||||
|
|
||||||
|
- name: blacklisting IPv6 module
|
||||||
|
template:
|
||||||
|
src: ipv6-disable.conf.j2
|
||||||
|
dest: /etc/modprobe.d/options-local.conf
|
||||||
|
|
||||||
|
- name: configure NICs
|
||||||
|
include_tasks: configure_nics.yml
|
||||||
|
with_dict: "{{node.net}}"
|
||||||
|
loop_control:
|
||||||
|
loop_var: nic
|
||||||
|
# when: node.net is defined
|
||||||
|
|
||||||
|
- name: apply NICs config
|
||||||
|
command: alterator-cmdline /net-eth action write commit "#t"
|
||||||
|
changed_when: false
|
||||||
|
async: 100
|
||||||
|
poll: 0
|
||||||
|
|
||||||
|
- name: update .tmp/ssh_config after NICs reconfiguration
|
||||||
|
include_role: name="inventory"
|
||||||
|
|
||||||
|
- name: wait for the host`s NIC to come back
|
||||||
|
wait_for_connection:
|
||||||
|
delay: 2
|
||||||
|
timeout: 300
|
||||||
|
|
||||||
|
# TODO: need to make it idempotent!
|
||||||
|
- name: set hostname
|
||||||
|
shell: '[[ $(hostname -s) == "{{inventory_hostname_short}}" ]] || { alterator-cmdline -d /net-eth action write computer_name "{{inventory_hostname_short}}" commit "#t"; echo changed; }'
|
||||||
|
register: result
|
||||||
|
notify: restart network
|
||||||
|
changed_when: '"changed" in result.stdout'
|
||||||
|
|
||||||
|
- name: set domainname
|
||||||
|
# shell: '[[ $(domainname) == "{{stack.domain}}" ]] || { alterator-cmdline -d /net-domain action write domain "{{stack.domain}}" domain_type "dns" commit "#t"; echo changed; }'
|
||||||
|
shell: '[[ $(domainname) == "{{stack.domain}}" ]] || { domainname "{{stack.domain}}"; echo changed; }'
|
||||||
|
register: result
|
||||||
|
notify: restart network
|
||||||
|
changed_when: '"changed" in result.stdout'
|
||||||
|
|
||||||
|
- name: delete .bash_logout
|
||||||
|
file:
|
||||||
|
path: /root/.bash_logout
|
||||||
|
state: absent
|
||||||
|
|
||||||
|
- meta: flush_handlers
|
||||||
|
|
||||||
|
- setup:
|
||||||
|
|
||||||
|
- name: register users keys
|
||||||
|
template:
|
||||||
|
dest: /etc/openssh/authorized_keys/root
|
||||||
|
src: authorized_keys
|
||||||
|
owner: root
|
||||||
|
group: root
|
||||||
|
mode: 0644
|
||||||
|
|
||||||
|
- name: fetch ssh host keys
|
||||||
|
fetch:
|
||||||
|
src: /etc/openssh/ssh_host_rsa_key.pub
|
||||||
|
dest: ".tmp/{{ inventory_hostname_short }}.ssh_host_rsa_key.pub"
|
||||||
|
|
||||||
|
- name: mount nfs shares
|
||||||
|
mount:
|
||||||
|
src: "{{item.from}}"
|
||||||
|
path: "{{item.to}}"
|
||||||
|
fstype: "{{item.fstype}}"
|
||||||
|
state: mounted
|
||||||
|
with_items: "{{node.mounts}}"
|
||||||
|
when: node.mounts is defined
|
Loading…
x
Reference in New Issue
Block a user