commit
4f8a042ba8
2
.gitignore
vendored
2
.gitignore
vendored
@ -33,3 +33,5 @@ bootstrap/solar-master.box
|
||||
vagrant-settings.yml
|
||||
|
||||
.solar_cli_uids
|
||||
|
||||
.ssh/
|
||||
|
22
resources/container_networks/actions/run.yml
Normal file
22
resources/container_networks/actions/run.yml
Normal file
@ -0,0 +1,22 @@
|
||||
- hosts: '*'
|
||||
sudo: yes
|
||||
gather_facts: false
|
||||
# this is default variables, they will be overwritten by resource one
|
||||
vars:
|
||||
networks:
|
||||
mgmt:
|
||||
address: 172.18.10.6
|
||||
bridge: br-test0
|
||||
bridge_address: 172.18.10.252/24
|
||||
interface: eth1
|
||||
netmask: 255.255.255.0
|
||||
type: veth
|
||||
tasks:
|
||||
- shell: ip l add {{item.value.bridge}} type bridge
|
||||
with_dict: networks
|
||||
ignore_errors: true
|
||||
- shell: ip l set {{item.value.bridge}} up
|
||||
with_dict: networks
|
||||
- shell: ip a add dev {{item.value.bridge}} {{item.value.bridge_address}}
|
||||
with_dict: networks
|
||||
ignore_errors: true
|
17
resources/container_networks/meta.yaml
Normal file
17
resources/container_networks/meta.yaml
Normal file
@ -0,0 +1,17 @@
|
||||
id: container_networks
|
||||
handler: ansible_playbook
|
||||
version: 1.0.0
|
||||
actions:
|
||||
input:
|
||||
ip:
|
||||
schema: str!
|
||||
value:
|
||||
ssh_key:
|
||||
schema: str!
|
||||
value:
|
||||
ssh_user:
|
||||
schema: str!
|
||||
value:
|
||||
networks:
|
||||
schema: {}
|
||||
value:
|
25
resources/lxc_container/actions/run.yml
Normal file
25
resources/lxc_container/actions/run.yml
Normal file
@ -0,0 +1,25 @@
|
||||
- hosts: '*'
|
||||
sudo: yes
|
||||
gather_facts: false
|
||||
# this is default variables, they will be overwritten by resource one
|
||||
vars:
|
||||
ansible_ssh_host: 10.0.0.3
|
||||
physical_host: 10.0.0.3
|
||||
container_name: test3
|
||||
inventory_hostname: test3
|
||||
properties:
|
||||
container_release: trusty
|
||||
container_networks:
|
||||
mgmt:
|
||||
address: 172.18.10.6
|
||||
bridge: br-test0
|
||||
bridge_address: 172.18.10.252/24
|
||||
interface: eth1
|
||||
netmask: 255.255.255.0
|
||||
type: veth
|
||||
pub_key: ''
|
||||
pre_tasks:
|
||||
- set_fact:
|
||||
lxc_container_ssh_key: "{{ lookup('file', pub_key) }}"
|
||||
roles:
|
||||
- { role: "lxc_container_create", tags: [ "lxc-container-create" ] }
|
55
resources/lxc_container/meta.yaml
Normal file
55
resources/lxc_container/meta.yaml
Normal file
@ -0,0 +1,55 @@
|
||||
id: lxc_container
|
||||
handler: ansible_playbook
|
||||
version: 1.0.0
|
||||
actions:
|
||||
input:
|
||||
ip:
|
||||
schema: str!
|
||||
value:
|
||||
ssh_key:
|
||||
schema: str!
|
||||
value:
|
||||
ssh_user:
|
||||
schema: str!
|
||||
value:
|
||||
ansible_ssh_host:
|
||||
schema: str!
|
||||
value:
|
||||
user:
|
||||
schema: str!
|
||||
value:
|
||||
user_key:
|
||||
schema: str!
|
||||
value:
|
||||
mgmt_ip:
|
||||
schema: str!
|
||||
value:
|
||||
physical_host:
|
||||
schema: str!
|
||||
value:
|
||||
container_address:
|
||||
schema: str!
|
||||
value:
|
||||
container_name:
|
||||
schema: str!
|
||||
value:
|
||||
inventory_hostname:
|
||||
schema: str!
|
||||
value:
|
||||
container_networks:
|
||||
schema: {}
|
||||
value:
|
||||
properties:
|
||||
schema: {}
|
||||
value:
|
||||
pub_key:
|
||||
schema: str!
|
||||
value:
|
||||
requires:
|
||||
schema: str
|
||||
value:
|
||||
roles:
|
||||
schema: [{value: str}]
|
||||
value:
|
||||
- https://github.com/stackforge/os-ansible-deployment/trunk/playbooks/roles/lxc_container_create
|
||||
- https://github.com/stackforge/os-ansible-deployment/trunk/playbooks/roles/lxc_container_destroy
|
6
resources/lxc_host/actions/run.yml
Normal file
6
resources/lxc_host/actions/run.yml
Normal file
@ -0,0 +1,6 @@
|
||||
- hosts: '*'
|
||||
sudo: yes
|
||||
roles:
|
||||
- { role: "lxc_hosts", tags: [ "lxc-host", "host-setup" ] }
|
||||
post_tasks:
|
||||
- shell: pip install git+https://github.com/lxc/python2-lxc.git#egg=lxc
|
23
resources/lxc_host/meta.yaml
Normal file
23
resources/lxc_host/meta.yaml
Normal file
@ -0,0 +1,23 @@
|
||||
id: lxc_host
|
||||
handler: ansible_playbook
|
||||
version: 1.0.0
|
||||
actions:
|
||||
input:
|
||||
ip:
|
||||
schema: str!
|
||||
value:
|
||||
ssh_key:
|
||||
schema: str!
|
||||
value:
|
||||
ssh_user:
|
||||
schema: str!
|
||||
value:
|
||||
provides:
|
||||
schema: str
|
||||
value: infra
|
||||
roles:
|
||||
schema: [{value: str}]
|
||||
value:
|
||||
- https://github.com/stackforge/os-ansible-deployment/trunk/playbooks/roles/lxc_hosts
|
||||
- https://github.com/stackforge/os-ansible-deployment/trunk/playbooks/roles/pip_install
|
||||
- https://github.com/stackforge/os-ansible-deployment/trunk/playbooks/roles/apt_package_pinning
|
14
resources/ssh_key/actions/run.yml
Normal file
14
resources/ssh_key/actions/run.yml
Normal file
@ -0,0 +1,14 @@
|
||||
- hosts: '*'
|
||||
sudo: yes
|
||||
gather_facts: false
|
||||
# this is default variables, they will be overwritten by resource one
|
||||
vars:
|
||||
keys_dir: /vagrant/.ssh
|
||||
private_key: /vagrant/.ssh/id_rsa
|
||||
passphrase: ''
|
||||
tasks:
|
||||
- shell: mkdir -p {{keys_dir}}
|
||||
- stat: path={{private_key}}
|
||||
register: key
|
||||
- shell: ssh-keygen -t rsa -f {{private_key}} -N ""
|
||||
when: key.stat.exists == False
|
26
resources/ssh_key/meta.yaml
Normal file
26
resources/ssh_key/meta.yaml
Normal file
@ -0,0 +1,26 @@
|
||||
id: ssh_key
|
||||
handler: ansible_playbook
|
||||
version: 1.0.0
|
||||
actions:
|
||||
input:
|
||||
ip:
|
||||
schema: str!
|
||||
value:
|
||||
ssh_key:
|
||||
schema: str!
|
||||
value:
|
||||
ssh_user:
|
||||
schema: str!
|
||||
value:
|
||||
keys_dir:
|
||||
schema: str!
|
||||
value:
|
||||
private_key:
|
||||
schema: str!
|
||||
value:
|
||||
public_key:
|
||||
schema: str!
|
||||
value:
|
||||
passphrase:
|
||||
schema: str
|
||||
value:
|
16
resources/vxlan_mesh/actions/run.yml
Normal file
16
resources/vxlan_mesh/actions/run.yml
Normal file
@ -0,0 +1,16 @@
|
||||
- hosts: '*'
|
||||
sudo: yes
|
||||
vars:
|
||||
id: 42
|
||||
group: 239.1.10.2
|
||||
parent: eth1
|
||||
master: br-test0
|
||||
tasks:
|
||||
- name: add vxlan mesh
|
||||
shell: ip l add vxlan{{id}} type vxlan id {{id}}
|
||||
group {{group}} dev {{parent}}
|
||||
ignore_errors: true
|
||||
- name: set vxlan master
|
||||
shell: ip l set vxlan{{id}} master {{master}}
|
||||
- name: set vxlan tunnel up
|
||||
shell: ip l set vxlan{{id}} up
|
23
resources/vxlan_mesh/meta.yaml
Normal file
23
resources/vxlan_mesh/meta.yaml
Normal file
@ -0,0 +1,23 @@
|
||||
id: vxlan_mesh
|
||||
handler: ansible_playbook
|
||||
version: 1.0.0
|
||||
actions:
|
||||
input:
|
||||
ip:
|
||||
schema: str!
|
||||
value:
|
||||
ssh_key:
|
||||
schema: str!
|
||||
value:
|
||||
ssh_user:
|
||||
schema: str!
|
||||
value:
|
||||
parent:
|
||||
schema: str!
|
||||
value:
|
||||
master:
|
||||
schema: str!
|
||||
value:
|
||||
id:
|
||||
schema: int!
|
||||
value:
|
8
templates/seed_node.yml
Normal file
8
templates/seed_node.yml
Normal file
@ -0,0 +1,8 @@
|
||||
id: seed_node
|
||||
resources:
|
||||
- id: seed_node
|
||||
from: resources/ro_node
|
||||
values:
|
||||
ip: '10.0.0.2'
|
||||
ssh_key: '/vagrant/.vagrant/machines/solar-dev/virtualbox/private_key'
|
||||
ssh_user: 'vagrant'
|
Loading…
x
Reference in New Issue
Block a user