Merge "Use overcloud-full instead of atomic-image"
This commit is contained in:
commit
ffd4443a26
|
@ -1,76 +1,56 @@
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
set -eux
|
set -eux
|
||||||
|
|
||||||
/sbin/setenforce 0
|
# TODO remove this when built image includes docker
|
||||||
/sbin/modprobe ebtables
|
if [ ! -f "/usr/bin/docker" ]; then
|
||||||
|
yum -y install docker
|
||||||
# CentOS sets ptmx to 000. Withoutit being 666, we can't use Cinder volumes
|
fi
|
||||||
chmod 666 /dev/pts/ptmx
|
|
||||||
|
|
||||||
# We need hostname -f to return in a centos container for the puppet hook
|
|
||||||
HOSTNAME=$(hostname)
|
|
||||||
echo "127.0.0.1 $HOSTNAME.localdomain $HOSTNAME" >> /etc/hosts
|
|
||||||
|
|
||||||
# update docker for local insecure registry(optional)
|
|
||||||
# Note: This is different for different docker versions
|
|
||||||
# For older docker versions < 1.4.x use commented line
|
|
||||||
#echo "OPTIONS='--insecure-registry $docker_registry'" >> /etc/sysconfig/docker
|
|
||||||
#echo "ADD_REGISTRY='--registry-mirror $docker_registry'" >> /etc/sysconfig/docker
|
|
||||||
|
|
||||||
# Local docker registry 1.8
|
# Local docker registry 1.8
|
||||||
# NOTE(mandre) $docker_namespace_is_registry is not a bash variable but is
|
# NOTE(mandre) $docker_namespace_is_registry is not a bash variable but is
|
||||||
# a place holder for text replacement done via heat
|
# a place holder for text replacement done via heat
|
||||||
if [ "$docker_namespace_is_registry" = True ]; then
|
if [ "$docker_namespace_is_registry" = "True" ]; then
|
||||||
/usr/bin/systemctl stop docker.service
|
/usr/bin/systemctl stop docker.service
|
||||||
# if namespace is used with local registry, trim all namespacing
|
# if namespace is used with local registry, trim all namespacing
|
||||||
trim_var=$docker_registry
|
trim_var=$docker_registry
|
||||||
registry_host="${trim_var%%/*}"
|
registry_host="${trim_var%%/*}"
|
||||||
/bin/sed -i -r "s/^[# ]*INSECURE_REGISTRY *=.+$/INSECURE_REGISTRY='--insecure-registry $registry_host'/" /etc/sysconfig/docker
|
/bin/sed -i -r "s/^[# ]*INSECURE_REGISTRY *=.+$/INSECURE_REGISTRY='--insecure-registry $registry_host'/" /etc/sysconfig/docker
|
||||||
/usr/bin/systemctl start --no-block docker.service
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
/usr/bin/docker pull $agent_image &
|
|
||||||
DOCKER_PULL_PID=$!
|
|
||||||
|
|
||||||
mkdir -p /var/lib/etc-data/json-config #FIXME: this should be a docker data container
|
mkdir -p /var/lib/etc-data/json-config #FIXME: this should be a docker data container
|
||||||
|
|
||||||
# NOTE(flaper87): Heat Agent required mounts
|
# NOTE(flaper87): Heat Agent required mounts
|
||||||
AGENT_COMMAND_MOUNTS="-v /var/lib/etc-data:/var/lib/etc-data \
|
AGENT_COMMAND_MOUNTS="\
|
||||||
-v /run:/run \
|
-v /var/lib/etc-data:/var/lib/etc-data \
|
||||||
-v /etc:/host/etc \
|
-v /run:/run \
|
||||||
-v /usr/bin/atomic:/usr/bin/atomic \
|
-v /etc/hosts:/etc/hosts \
|
||||||
-v /var/lib/dhclient:/var/lib/dhclient \
|
-v /etc:/host/etc \
|
||||||
-v /var/lib/cloud:/var/lib/cloud \
|
-v /var/lib/dhclient:/var/lib/dhclient \
|
||||||
-v /var/lib/heat-cfntools:/var/lib/heat-cfntools \
|
-v /var/lib/cloud:/var/lib/cloud \
|
||||||
-v /etc/sysconfig/docker:/etc/sysconfig/docker \
|
-v /var/lib/heat-cfntools:/var/lib/heat-cfntools \
|
||||||
-v /etc/sysconfig/network-scripts:/etc/sysconfig/network-scripts \
|
-v /var/lib/os-collect-config:/var/lib/os-collect-config \
|
||||||
-v /var/lib/os-collect-config:/var/lib/os-collect-config \
|
-v /var/lib/os-apply-config-deployments:/var/lib/os-apply-config-deployments \
|
||||||
-v /var/lib/os-apply-config-deployments:/var/lib/os-apply-config-deployments \
|
-v /var/lib/heat-config:/var/lib/heat-config \
|
||||||
-v /var/lib/heat-config:/var/lib/heat-config \
|
-v /etc/sysconfig/docker:/etc/sysconfig/docker \
|
||||||
-v /usr/lib64/libseccomp.so.2:/usr/lib64/libseccomp.so.2"
|
-v /etc/sysconfig/network-scripts:/etc/sysconfig/network-scripts \
|
||||||
|
-v /usr/lib64/libseccomp.so.2:/usr/lib64/libseccomp.so.2 \
|
||||||
|
-v /usr/bin/docker:/usr/bin/docker \
|
||||||
# NOTE(flaper87): Some of these commands may not be present depending on the
|
-v /usr/bin/docker-current:/usr/bin/docker-current \
|
||||||
# atomic version.
|
-v /var/lib/os-collect-config:/var/lib/os-collect-config"
|
||||||
for docker_cmd in docker docker-current docker-latest; do
|
|
||||||
if [ -f "/usr/bin/$docker_cmd" ]; then
|
|
||||||
AGENT_COMMAND_MOUNTS+=" -v /usr/bin/$docker_cmd:/usr/bin/$docker_cmd"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
# heat-docker-agents service
|
# heat-docker-agents service
|
||||||
cat <<EOF > /etc/systemd/system/heat-docker-agents.service
|
cat <<EOF > /etc/systemd/system/heat-docker-agents.service
|
||||||
|
|
||||||
[Unit]
|
[Unit]
|
||||||
Description=Heat Docker Agent Container
|
Description=Heat Docker Agent Container
|
||||||
After=docker.service
|
After=docker.service
|
||||||
Requires=docker.service
|
Requires=docker.service
|
||||||
|
Before=os-collect-config.service
|
||||||
|
Conflicts=os-collect-config.service
|
||||||
|
|
||||||
[Service]
|
[Service]
|
||||||
User=root
|
User=root
|
||||||
Restart=on-failure
|
Restart=always
|
||||||
ExecStartPre=-/usr/bin/docker kill heat-agents
|
ExecStartPre=-/usr/bin/docker rm -f heat-agents
|
||||||
ExecStartPre=-/usr/bin/docker rm heat-agents
|
|
||||||
ExecStart=/usr/bin/docker run --name heat-agents --privileged --net=host \
|
ExecStart=/usr/bin/docker run --name heat-agents --privileged --net=host \
|
||||||
$AGENT_COMMAND_MOUNTS \
|
$AGENT_COMMAND_MOUNTS \
|
||||||
--entrypoint=/usr/bin/os-collect-config $agent_image
|
--entrypoint=/usr/bin/os-collect-config $agent_image
|
||||||
|
@ -78,35 +58,12 @@ ExecStop=/usr/bin/docker stop heat-agents
|
||||||
|
|
||||||
[Install]
|
[Install]
|
||||||
WantedBy=multi-user.target
|
WantedBy=multi-user.target
|
||||||
|
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
# enable and start heat-docker-agents
|
# enable and start heat-docker-agents
|
||||||
chmod 0640 /etc/systemd/system/heat-docker-agents.service
|
|
||||||
/usr/bin/systemctl enable heat-docker-agents.service
|
/usr/bin/systemctl enable heat-docker-agents.service
|
||||||
/usr/bin/systemctl start --no-block heat-docker-agents.service
|
/usr/bin/systemctl start --no-block heat-docker-agents.service
|
||||||
|
|
||||||
# Disable NetworkManager and let the ifup/down scripts work properly.
|
# Disable libvirtd
|
||||||
/usr/bin/systemctl disable NetworkManager
|
/usr/bin/systemctl disable libvirtd.service
|
||||||
/usr/bin/systemctl stop NetworkManager
|
/usr/bin/systemctl stop libvirtd.service
|
||||||
|
|
||||||
# Atomic's root partition & logical volume defaults to 3G. In order to launch
|
|
||||||
# larger VMs, we need to enlarge the root logical volume and scale down the
|
|
||||||
# docker_pool logical volume. We are allocating 80% of the disk space for
|
|
||||||
# vm data and the remaining 20% for docker images.
|
|
||||||
ATOMIC_ROOT='/dev/mapper/atomicos-root'
|
|
||||||
ROOT_DEVICE=`pvs -o vg_name,pv_name --no-headings | grep atomicos | awk '{ print $2}'`
|
|
||||||
|
|
||||||
growpart $( echo "${ROOT_DEVICE}" | sed -r 's/([^0-9]*)([0-9]+)/\1 \2/' )
|
|
||||||
pvresize "${ROOT_DEVICE}"
|
|
||||||
lvresize -l +80%FREE "${ATOMIC_ROOT}"
|
|
||||||
xfs_growfs "${ATOMIC_ROOT}"
|
|
||||||
|
|
||||||
cat <<EOF > /etc/sysconfig/docker-storage-setup
|
|
||||||
GROWPART=true
|
|
||||||
AUTO_EXTEND_POOL=yes
|
|
||||||
POOL_AUTOEXTEND_PERCENT=30
|
|
||||||
POOL_AUTOEXTEND_THRESHOLD=70
|
|
||||||
EOF
|
|
||||||
|
|
||||||
wait $DOCKER_PULL_PID
|
|
||||||
|
|
|
@ -25,16 +25,6 @@ parameters:
|
||||||
default: 'tripleoupstream'
|
default: 'tripleoupstream'
|
||||||
type: string
|
type: string
|
||||||
|
|
||||||
DockerOpenvswitchDBImage:
|
|
||||||
description: image
|
|
||||||
default: 'centos-binary-openvswitch-db-server'
|
|
||||||
type: string
|
|
||||||
|
|
||||||
DockerOvsVswitchdImage:
|
|
||||||
description: image
|
|
||||||
default: 'centos-binary-openvswitch-vswitchd'
|
|
||||||
type: string
|
|
||||||
|
|
||||||
LibvirtConfig:
|
LibvirtConfig:
|
||||||
type: string
|
type: string
|
||||||
default: "/etc/libvirt/libvirtd.conf"
|
default: "/etc/libvirt/libvirtd.conf"
|
||||||
|
@ -206,52 +196,6 @@ resources:
|
||||||
nova_config: {get_param: NovaConfig}
|
nova_config: {get_param: NovaConfig}
|
||||||
neutron_openvswitch_agent_config: {get_param: NeutronOpenvswitchAgentConfig}
|
neutron_openvswitch_agent_config: {get_param: NeutronOpenvswitchAgentConfig}
|
||||||
|
|
||||||
NovaComputeContainersDeploymentOVS:
|
|
||||||
type: OS::Heat::StructuredDeploymentGroup
|
|
||||||
depends_on: CopyJsonDeployment
|
|
||||||
properties:
|
|
||||||
name: NovaComputeContainersDeploymentOVS
|
|
||||||
config: {get_resource: NovaComputeContainersConfigOVS}
|
|
||||||
servers: {get_param: [servers, {{role.name}}]}
|
|
||||||
|
|
||||||
NovaComputeContainersConfigOVS:
|
|
||||||
type: OS::Heat::StructuredConfig
|
|
||||||
properties:
|
|
||||||
group: docker-cmd
|
|
||||||
config:
|
|
||||||
openvswitchdb:
|
|
||||||
image:
|
|
||||||
list_join:
|
|
||||||
- '/'
|
|
||||||
- [ {get_param: DockerNamespace}, {get_param: DockerOpenvswitchDBImage} ]
|
|
||||||
net: host
|
|
||||||
restart: always
|
|
||||||
volumes:
|
|
||||||
- /var/lib/etc-data/json-config/ovsdb-server.json:/var/lib/kolla/config_files/config.json
|
|
||||||
- /etc/localtime:/etc/localtime:ro
|
|
||||||
- /run:/run
|
|
||||||
- logs:/var/log/kolla/
|
|
||||||
- openvswitch_db:/var/lib/openvswitch/
|
|
||||||
environment:
|
|
||||||
- KOLLA_CONFIG_STRATEGY=COPY_ALWAYS
|
|
||||||
|
|
||||||
ovsvswitchd:
|
|
||||||
image:
|
|
||||||
list_join:
|
|
||||||
- '/'
|
|
||||||
- [ {get_param: DockerNamespace}, {get_param: DockerOvsVswitchdImage} ]
|
|
||||||
net: host
|
|
||||||
privileged: true
|
|
||||||
restart: always
|
|
||||||
volumes:
|
|
||||||
- /var/lib/etc-data/json-config/ovs-vswitchd.json:/var/lib/kolla/config_files/config.json
|
|
||||||
- /etc/localtime:/etc/localtime:ro
|
|
||||||
- /lib/modules:/lib/modules:ro
|
|
||||||
- /run:/run
|
|
||||||
- logs:/var/log/kolla/
|
|
||||||
environment:
|
|
||||||
- KOLLA_CONFIG_STRATEGY=COPY_ALWAYS
|
|
||||||
|
|
||||||
{{role.name}}ContainersConfig_Step1:
|
{{role.name}}ContainersConfig_Step1:
|
||||||
type: OS::Heat::StructuredConfig
|
type: OS::Heat::StructuredConfig
|
||||||
depends_on: CopyJsonDeployment
|
depends_on: CopyJsonDeployment
|
||||||
|
|
|
@ -13,7 +13,6 @@ resource_registry:
|
||||||
OS::TripleO::Services: ../docker/services/services.yaml
|
OS::TripleO::Services: ../docker/services/services.yaml
|
||||||
|
|
||||||
parameter_defaults:
|
parameter_defaults:
|
||||||
NovaImage: atomic-image
|
|
||||||
# Defaults to 'tripleoupstream'. Specify a local docker registry
|
# Defaults to 'tripleoupstream'. Specify a local docker registry
|
||||||
# Example: 192.0.2.1:8787/tripleoupstream
|
# Example: 192.0.2.1:8787/tripleoupstream
|
||||||
DockerNamespace: tripleoupstream
|
DockerNamespace: tripleoupstream
|
||||||
|
@ -24,8 +23,6 @@ parameter_defaults:
|
||||||
DockerNovaComputeImage: centos-binary-nova-compute:newton
|
DockerNovaComputeImage: centos-binary-nova-compute:newton
|
||||||
DockerLibvirtImage: centos-binary-nova-libvirt:newton
|
DockerLibvirtImage: centos-binary-nova-libvirt:newton
|
||||||
DockerOpenvswitchImage: centos-binary-neutron-openvswitch-agent:newton
|
DockerOpenvswitchImage: centos-binary-neutron-openvswitch-agent:newton
|
||||||
DockerOvsVswitchdImage: centos-binary-openvswitch-vswitchd:newton
|
|
||||||
DockerOpenvswitchDBImage: centos-binary-openvswitch-db-server:newton
|
|
||||||
|
|
||||||
ComputeServices:
|
ComputeServices:
|
||||||
- OS::TripleO::Services::NovaCompute
|
- OS::TripleO::Services::NovaCompute
|
||||||
|
|
Loading…
Reference in New Issue