All changes in the merlin branches.

This commit is contained in:
Egon Rijpkema 2018-04-23 15:07:18 +02:00
parent b6c6533824
commit 791595dcdf
11 changed files with 109 additions and 58 deletions

View File

@ -15,7 +15,8 @@ RUN set -x \
python-openstackclient \ python-openstackclient \
python-oslo.cache \ python-oslo.cache \
lvm2 \ lvm2 \
tgt \ python-ceph \
python-rbd \
&& apt-get -y clean && apt-get -y clean
@ -28,8 +29,6 @@ COPY bootstrap.sh /etc/bootstrap.sh
COPY run.sh /etc/run.sh COPY run.sh /etc/run.sh
COPY lvm.conf /etc/lvm/lvm.conf
RUN chown root.root /etc/bootstrap.sh && chmod a+x /etc/bootstrap.sh RUN chown root.root /etc/bootstrap.sh && chmod a+x /etc/bootstrap.sh
RUN chown root.root /etc/run.sh && chmod a+x /etc/run.sh RUN chown root.root /etc/run.sh && chmod a+x /etc/run.sh

View File

@ -22,6 +22,6 @@ source /root/admin-openrc.sh
# create a LVM physical volume and volume group. # create a LVM physical volume and volume group.
# This device should be available tpo the container # This device should be available tpo the container
pvcreate /dev/cinder_storage_volume #pvcreate /dev/cinder_storage_volume
vgcreate cinder-volumes /dev/cinder_storage_volume #vgcreate cinder-volumes /dev/cinder_storage_volume

View File

@ -3,7 +3,9 @@
# Write the config files # Write the config files
/etc/write_conf.sh /etc/write_conf.sh
# start cinder processes. # start cinder processes.
tgtd cinder-volume -d &
sleep 5
cinder-volume -d & cinder-volume -d &

View File

@ -10,9 +10,9 @@ connection = mysql+pymysql://$CINDER_USER:$CINDER_PASSWORD@$MYSQL_HOST/cinder
[DEFAULT] [DEFAULT]
auth_strategy = keystone auth_strategy = keystone
transport_url = rabbit://$RABBIT_USER:$RABBIT_PASSWORD@$RABBIT_HOST transport_url = rabbit://$RABBIT_USER:$RABBIT_PASSWORD@$MY_IP
my_ip = $MY_IP my_ip = $MY_IP
enabled_backends = lvm enabled_backends = RBD-backend
glance_api_servers = http://$GLANCE_HOST:9292 glance_api_servers = http://$GLANCE_HOST:9292
[keystone_authtoken] [keystone_authtoken]
@ -29,11 +29,12 @@ password = $CINDER_PASSWORD
[oslo_concurrency] [oslo_concurrency]
lock_path = /var/lib/cinder/tmp lock_path = /var/lib/cinder/tmp
[lvm] [RBD-backend]
volume_driver = cinder.volume.drivers.lvm.LVMVolumeDriver volume_backend_name=RBD-backend
volume_group = cinder-volumes rbd_pool=volumes
iscsi_protocol = iscsi rbd_user=volumes
iscsi_helper = tgtadm rbd_secret_uuid=d0db6ba7-a0c9-4da6-b0bc-aa7846325333
volumes_dir = /var/lib/cinder/volumes volume_driver=cinder.volume.drivers.rbd.RBDDriver
rbd_ceph_conf=/etc/ceph/ceph.conf
EOF EOF

View File

@ -14,6 +14,8 @@ RUN set -x \
python-mysqldb \ python-mysqldb \
python-openstackclient \ python-openstackclient \
python-oslo.cache \ python-oslo.cache \
python-rbd \
python-ceph \
&& apt-get -y clean \ && apt-get -y clean \
&& rm -f /var/lib/glance/glance.sqlite && rm -f /var/lib/glance/glance.sqlite

View File

@ -32,13 +32,14 @@ flavor = keystone
[glance_store] [glance_store]
stores = file,http stores = glance.store.rbd.Store
default_store = file default_store = rbd
filesystem_store_datadir = /var/lib/glance/images/ rbd_store_pool = images
rbd_store_user = images
rbd_store_ceph_conf = /etc/ceph/ceph.conf
EOF EOF
cat << EOF > /etc/glance/glance-registry.conf cat << EOF > /etc/glance/glance-registry.conf
[DEFAULT] [DEFAULT]
@ -49,9 +50,11 @@ rpc_backend = rabbit
connection = mysql+pymysql://$GLANCE_USER:$GLANCE_PASSWORD@$MYSQL_HOST/glance connection = mysql+pymysql://$GLANCE_USER:$GLANCE_PASSWORD@$MYSQL_HOST/glance
[glance_store] [glance_store]
stores = file,http stores = glance.store.rbd.Store
default_store = file default_store = rbd
filesystem_store_datadir = /var/lib/glance/images/ rbd_store_pool = images
rbd_store_user = images
rbd_store_ceph_conf = /etc/ceph/ceph.conf
[keystone_authtoken] [keystone_authtoken]
auth_uri = http://$KEYSTONE_HOST:5000 auth_uri = http://$KEYSTONE_HOST:5000

View File

@ -30,7 +30,7 @@ neutron-metadata-agent \
-v -d & -v -d &
# If any process fails, kill the rest. # If any process fails, kill the rest.
# This insures the container stops and systemd will restart it. # This ensures the container stops and systemd will restart it.
wait -n wait -n
pkill -P $$ pkill -P $$

View File

@ -4,15 +4,16 @@
# These are to be passed to the docker container using -e # These are to be passed to the docker container using -e
cat << EOF > /etc/neutron/neutron.conf cat << EOF > /etc/neutron/neutron.conf
[DEFAULT] [DEFAULT]
core_plugin = ml2 core_plugin = ml2
service_plugins = service_plugins = router
allow_overlapping_ips = True
transport_url = rabbit://$RABBIT_USER:$RABBIT_PASSWORD@$MY_IP transport_url = rabbit://$RABBIT_USER:$RABBIT_PASSWORD@$MY_IP
auth_strategy = keystone auth_strategy = keystone
notify_nova_on_port_status_changes = true notify_nova_on_port_status_changes = true
notify_nova_on_port_data_changes = true notify_nova_on_port_data_changes = true
dhcp_agents_per_network = 2 dhcp_agents_per_network = 2
global_physnet_mtu = $GLOBAL_PHYSNET_MTU
[agent] [agent]
root_helper = sudo /usr/bin/neutron-rootwrap /etc/neutron/rootwrap.conf root_helper = sudo /usr/bin/neutron-rootwrap /etc/neutron/rootwrap.conf
@ -46,11 +47,10 @@ EOF
cat << EOF > /etc/neutron/plugins/ml2/ml2_conf.ini cat << EOF > /etc/neutron/plugins/ml2/ml2_conf.ini
[ml2] [ml2]
type_drivers = flat,vlan type_drivers = flat,vlan,vxlan
tenant_network_types = tenant_network_types = vxlan
mechanism_drivers = linuxbridge mechanism_drivers = linuxbridge,l2population
extension_drivers = port_security extension_drivers = port_security
path_mtu = $GLOBAL_PHYSNET_MTU
[ml2_type_vlan] [ml2_type_vlan]
network_vlan_ranges = provider network_vlan_ranges = provider
@ -58,25 +58,14 @@ network_vlan_ranges = provider
[ml2_type_flat] [ml2_type_flat]
flat_networks = provider flat_networks = provider
[ml2_type_vxlan]
vni_ranges = 1:1000
[securitygroup] [securitygroup]
enable_ipset = true enable_ipset = true
EOF EOF
cat << EOF > /etc/neutron/plugins/ml2/linuxbridge_agent.ini
[linux_bridge]
physical_interface_mappings = $PHYSICAL_INTERFACE_MAPPINGS
[vxlan]
enable_vxlan = false
[securitygroup]
enable_security_group = true
firewall_driver = neutron.agent.linux.iptables_firewall.IptablesFirewallDriver
EOF
cat << EOF > /etc/neutron/metadata_agent.ini cat << EOF > /etc/neutron/metadata_agent.ini
[DEFAULT] [DEFAULT]
@ -84,3 +73,35 @@ nova_metadata_ip = $MY_IP
metadata_proxy_shared_secret = $METADATA_SECRET metadata_proxy_shared_secret = $METADATA_SECRET
EOF EOF
cat << EOF > /etc/neutron/l3_agent.ini
[DEFAULT]
interface_driver = linuxbridge
external_network_bridge =
EOF
cat << EOF > /etc/neutron/plugins/ml2/linuxbridge_agent.ini
[linux_bridge]
physical_interface_mappings = $PHYSICAL_INTERFACE_MAPPINGS
[vxlan]
enable_vxlan = True
l2_population = True
local_ip = $OVERLAY_IP
[securitygroup]
enable_security_group = true
firewall_driver = iptables
EOF
cat << EOF > /etc/neutron/l3_agent.ini
[DEFAULT]
interface_driver = linuxbridge
external_network_bridge =
EOF

View File

@ -12,12 +12,15 @@ RUN set -x \
python-openstackclient \ python-openstackclient \
nova-compute \ nova-compute \
neutron-linuxbridge-agent \ neutron-linuxbridge-agent \
neutron-l3-agent \
neutron-dhcp-agent \ neutron-dhcp-agent \
neutron-metadata-agent \ neutron-metadata-agent \
python-ceph \
python-rbd \
&& apt-get -y clean && apt-get -y clean
COPY write_conf.sh /etc/write_conf.sh COPY write_conf.sh /etc/write_conf.sh
COPY run.sh /etc/run.sh COPY run.sh /etc/run.sh
RUN echo hoi
CMD ["/etc/run.sh"] CMD ["/etc/run.sh"]

View File

@ -27,6 +27,14 @@ neutron-metadata-agent \
--config-dir /etc/neutron/ \ --config-dir /etc/neutron/ \
-v -d & -v -d &
sleep 3
neutron-l3-agent \
--config-file /etc/neutron/l3_agent.ini \
--config-file /etc/neutron/neutron.conf \
--config-file /etc/neutron/metadata_agent.ini \
--config-dir /etc/neutron/ \
-v -d &
# If any process fails, kill the rest. # If any process fails, kill the rest.
# This ensures the container stops and systemd will restart it. # This ensures the container stops and systemd will restart it.

View File

@ -121,7 +121,12 @@ allow_migrate_to_same_host = True
allow_resize_to_same_host = True allow_resize_to_same_host = True
[libvirt] [libvirt]
virt_type=kvm virt_type = kvm
images_type = rbd
images_rbd_pool = vms
images_rbd_ceph_conf = /etc/ceph/ceph.conf
rbd_user = nova
rbd_secret_uuid = b5044271-1918-4070-822c-f19ed14d7494
[vnc] [vnc]
enabled = True enabled = True
@ -189,10 +194,11 @@ EOF
cat << EOF > /etc/neutron/neutron.conf cat << EOF > /etc/neutron/neutron.conf
[DEFAULT] [DEFAULT]
service_plugins = router
allow_overlapping_ips = True
transport_url = rabbit://$RABBIT_USER:$RABBIT_PASSWORD@$RABBIT_HOST transport_url = rabbit://$RABBIT_USER:$RABBIT_PASSWORD@$RABBIT_HOST
auth_strategy = keystone auth_strategy = keystone
core_plugin = ml2 core_plugin = ml2
global_physnet_mtu = $GLOBAL_PHYSNET_MTU
[keystone_authtoken] [keystone_authtoken]
auth_uri = http://$KEYSTONE_HOST:5000 auth_uri = http://$KEYSTONE_HOST:5000
@ -217,17 +223,12 @@ password = $NOVA_PASSWORD
EOF EOF
cat << EOF > /etc/neutron/plugins/ml2/linuxbridge_agent.ini
[linux_bridge] cat << EOF > /etc/neutron/l3_agent.ini
physical_interface_mappings = $PHYSICAL_INTERFACE_MAPPINGS
[vxlan] [DEFAULT]
enable_vxlan = false interface_driver = linuxbridge
external_network_bridge =
[securitygroup]
enable_security_group = true
firewall_driver = neutron.agent.linux.iptables_firewall.IptablesFirewallDriver
EOF EOF
@ -251,11 +252,10 @@ EOF
cat << EOF > /etc/neutron/plugins/ml2/ml2_conf.ini cat << EOF > /etc/neutron/plugins/ml2/ml2_conf.ini
[ml2] [ml2]
type_drivers = flat,vlan type_drivers = flat,vlan,vxlan
tenant_network_types = tenant_network_types = vxlan
mechanism_drivers = linuxbridge mechanism_drivers = linuxbridge,l2population
extension_drivers = port_security extension_drivers = port_security
path_mtu = $GLOBAL_PHYSNET_MTU
[ml2_type_vlan] [ml2_type_vlan]
network_vlan_ranges = provider network_vlan_ranges = provider
@ -263,7 +263,19 @@ network_vlan_ranges = provider
[ml2_type_flat] [ml2_type_flat]
flat_networks = provider flat_networks = provider
[ml2_type_vxlan]
vni_ranges = 1:100
[securitygroup] [securitygroup]
enable_ipset = true enable_ipset = true
EOF EOF
cat << EOF > /etc/neutron/plugins/ml2/linuxbridge_agent.ini
[vxlan]
enable_vxlan = True
l2_population = True
local_ip = $OVERLAY_IP
EOF