Removed hardcoded ips for glance
Also added domain, projects, users creation for keystone. This guide was followed: https://docs.openstack.org/ocata/install-guide-ubuntu/keystone-us
This commit is contained in:
parent
062fabd4b6
commit
a25852b39e
2
hosts
2
hosts
@ -38,4 +38,4 @@ run_options=""
|
|||||||
run_options="-e CASSANDRA_SEEDS=172.23.41.1"
|
run_options="-e CASSANDRA_SEEDS=172.23.41.1"
|
||||||
|
|
||||||
[nova-management]
|
[nova-management]
|
||||||
kolla2
|
openstack01-node01
|
||||||
|
@ -1,4 +1,8 @@
|
|||||||
---
|
---
|
||||||
|
- hosts: all
|
||||||
|
name: Dummy to gather facts
|
||||||
|
tasks: []
|
||||||
|
|
||||||
- hosts: nova-management
|
- hosts: nova-management
|
||||||
become: True
|
become: True
|
||||||
roles:
|
roles:
|
||||||
|
@ -27,6 +27,7 @@
|
|||||||
-e "MYSQL_ROOT_PASSWORD=geheim"
|
-e "MYSQL_ROOT_PASSWORD=geheim"
|
||||||
-e "KEYSTONE_HOST={{ hostvars[groups['keystone'][0]]['ansible_default_ipv4']['address'] }}"
|
-e "KEYSTONE_HOST={{ hostvars[groups['keystone'][0]]['ansible_default_ipv4']['address'] }}"
|
||||||
-e "GLANCE_HOST={{ hostvars[groups['glance'][0]]['ansible_default_ipv4']['address'] }}"
|
-e "GLANCE_HOST={{ hostvars[groups['glance'][0]]['ansible_default_ipv4']['address'] }}"
|
||||||
|
-e "GLANCE_USER=glance"
|
||||||
-e "GLANCE_PASSWORD=geheim"
|
-e "GLANCE_PASSWORD=geheim"
|
||||||
hpc/openstack-glance /etc/bootstrap.sh
|
hpc/openstack-glance /etc/bootstrap.sh
|
||||||
tags: bootstrap
|
tags: bootstrap
|
||||||
|
@ -9,7 +9,15 @@ Restart=always
|
|||||||
ExecStartPre=-/usr/bin/docker stop %n
|
ExecStartPre=-/usr/bin/docker stop %n
|
||||||
ExecStartPre=-/usr/bin/docker rm %n
|
ExecStartPre=-/usr/bin/docker rm %n
|
||||||
ExecStart=/usr/bin/docker run --name %n \
|
ExecStart=/usr/bin/docker run --name %n \
|
||||||
--add-host=mariadb:{{ hostvars[groups['databases'][0]]['ansible_default_ipv4']['address'] }} \
|
-e "RABBIT_HOST={{ hostvars[groups['rabbitmq'][0]]['ansible_default_ipv4']['address'] }}" \
|
||||||
|
-e "MEMCACHED_HOST={{ hostvars[groups['memcached'][0]]['ansible_default_ipv4']['address'] }}" \
|
||||||
|
-e "MYSQL_HOST={{ hostvars[groups['databases'][0]]['ansible_default_ipv4']['address'] }}" \
|
||||||
|
-e "MYSQL_ROOT_PASSWORD=geheim" \
|
||||||
|
-e "KEYSTONE_HOST={{ hostvars[groups['keystone'][0]]['ansible_default_ipv4']['address'] }}" \
|
||||||
|
-e "GLANCE_HOST={{ hostvars[groups['glance'][0]]['ansible_default_ipv4']['address'] }}" \
|
||||||
|
-e "GLANCE_USER=glance" \
|
||||||
|
-e "GLANCE_PASSWORD=geheim" \
|
||||||
|
--add-host="controller:{{ hostvars[groups['keystone'][0]]['ansible_default_ipv4']['address'] }}" \
|
||||||
-p 9292:9292 \
|
-p 9292:9292 \
|
||||||
hpc/openstack-glance
|
hpc/openstack-glance
|
||||||
|
|
||||||
|
@ -17,7 +17,7 @@ RUN set -x \
|
|||||||
|
|
||||||
# set admin token TODO: make this a secret
|
# set admin token TODO: make this a secret
|
||||||
# in volume of met env
|
# in volume of met env
|
||||||
ADD keystone.conf /etc/keystone/keystone.conf
|
COPY keystone.conf /etc/keystone/keystone.conf
|
||||||
|
|
||||||
RUN mkdir /etc/keystone/fernet-keys
|
RUN mkdir /etc/keystone/fernet-keys
|
||||||
|
|
||||||
@ -25,5 +25,7 @@ RUN chown keystone: /etc/keystone/fernet-keys
|
|||||||
|
|
||||||
COPY admin-openrc.sh root/admin-openrc.sh
|
COPY admin-openrc.sh root/admin-openrc.sh
|
||||||
|
|
||||||
|
COPY bootstrap.sh /etc/bootstrap.sh
|
||||||
|
|
||||||
#RUN keystone-manage db_sync
|
#RUN keystone-manage db_sync
|
||||||
CMD apachectl -DFOREGROUND
|
CMD apachectl -DFOREGROUND
|
||||||
|
16
roles/keystone/files/bootstrap.sh
Executable file
16
roles/keystone/files/bootstrap.sh
Executable file
@ -0,0 +1,16 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
source /root/admin-openrc.sh
|
||||||
|
|
||||||
|
openstack project create --domain default \
|
||||||
|
--description "Service Project" service
|
||||||
|
|
||||||
|
openstack project create --domain default \
|
||||||
|
--description "Demo Project" demo
|
||||||
|
|
||||||
|
openstack user create --domain default \
|
||||||
|
--password geheim demo
|
||||||
|
|
||||||
|
openstack role create user
|
||||||
|
|
||||||
|
openstack role add --project demo --user demo user
|
@ -35,11 +35,6 @@
|
|||||||
- name: install service file
|
- name: install service file
|
||||||
command: systemctl daemon-reload
|
command: systemctl daemon-reload
|
||||||
|
|
||||||
- name: make sure service is started
|
|
||||||
systemd:
|
|
||||||
name: keystone.service
|
|
||||||
state: restarted
|
|
||||||
|
|
||||||
- name: Initialize db
|
- name: Initialize db
|
||||||
script: scripts/initialize_db.sh {{ hostvars[groups['databases'][0]]['ansible_default_ipv4']['address'] }}
|
script: scripts/initialize_db.sh {{ hostvars[groups['databases'][0]]['ansible_default_ipv4']['address'] }}
|
||||||
|
|
||||||
@ -60,3 +55,14 @@
|
|||||||
--bootstrap-public-url http://{{ hostvars[groups['keystone'][0]]['ansible_default_ipv4']['address'] }}:5000/v3/
|
--bootstrap-public-url http://{{ hostvars[groups['keystone'][0]]['ansible_default_ipv4']['address'] }}:5000/v3/
|
||||||
--bootstrap-region-id RegionOne
|
--bootstrap-region-id RegionOne
|
||||||
|
|
||||||
|
- name: Create a domain, projects users and roles
|
||||||
|
command: >
|
||||||
|
/usr/bin/docker run --rm
|
||||||
|
--add-host=mariadb:{{ hostvars[groups['databases'][0]]['ansible_default_ipv4']['address'] }}
|
||||||
|
-v /srv/keystone/fernet-keys:/etc/keystone/fernet-keys
|
||||||
|
hpc/keystone bash /etc/bootstrap.sh
|
||||||
|
|
||||||
|
- name: make sure service is started
|
||||||
|
systemd:
|
||||||
|
name: keystone.service
|
||||||
|
state: restarted
|
||||||
|
@ -6,8 +6,7 @@ Requires=docker.service
|
|||||||
[Service]
|
[Service]
|
||||||
TimeoutStartSec=0
|
TimeoutStartSec=0
|
||||||
Restart=always
|
Restart=always
|
||||||
ExecStartPre=-/usr/bin/docker stop %n
|
ExecStartPre=-/usr/bin/docker rm -f %n
|
||||||
ExecStartPre=-/usr/bin/docker rm %n
|
|
||||||
ExecStart=/usr/bin/docker run --name %n \
|
ExecStart=/usr/bin/docker run --name %n \
|
||||||
--add-host=mariadb:172.23.41.2 \
|
--add-host=mariadb:172.23.41.2 \
|
||||||
-p 5000:5000 -p 35357:35357 \
|
-p 5000:5000 -p 35357:35357 \
|
||||||
|
@ -1,26 +1,5 @@
|
|||||||
# Build and install a docker image for nova-controller.
|
# Build and install a docker image for nova-controller.
|
||||||
---
|
---
|
||||||
- name: Make build and persistent directories
|
|
||||||
file:
|
|
||||||
path: "{{ item }}"
|
|
||||||
state: directory
|
|
||||||
mode: 0777
|
|
||||||
with_items:
|
|
||||||
- /srv/nova-controller
|
|
||||||
|
|
||||||
# Todo: remove this when we have a docker repo
|
|
||||||
# Disabled because of https://github.com/ansible/ansible/issues/20653
|
|
||||||
#- name: clone docker-glance repo
|
|
||||||
# git:
|
|
||||||
# accept_hostkey: True
|
|
||||||
# repo: ssh://git@git.webhosting.rug.nl:222/HPC/docker-nova-service
|
|
||||||
# dest: /srv/docker-nova-service
|
|
||||||
|
|
||||||
- name: build nova-controller image
|
|
||||||
docker_image:
|
|
||||||
path: /srv/docker-nova-service
|
|
||||||
name: hpc/novacontroller
|
|
||||||
|
|
||||||
- name: install service file.
|
- name: install service file.
|
||||||
template:
|
template:
|
||||||
src: templates/nova-controller.service
|
src: templates/nova-controller.service
|
||||||
|
Loading…
Reference in New Issue
Block a user