2017-05-22 10:38:46 +00:00
|
|
|
#!/bin/bash
|
|
|
|
#
|
|
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
# you may not use this file except in compliance with the License.
|
|
|
|
# You may obtain a copy of the License at
|
|
|
|
#
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
#
|
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
|
|
# License for the specific language governing permissions and limitations
|
|
|
|
# under the License.
|
|
|
|
|
|
|
|
set -e
|
|
|
|
|
|
|
|
DIR=$( cd "$( dirname "$0" )" && pwd )
|
|
|
|
source "$DIR/../devstack/lib/kuryr_kubernetes"
|
|
|
|
|
|
|
|
OUTPUT_DIR=${1:-.}
|
2019-06-18 12:36:27 +00:00
|
|
|
CONF_PATH=${2:-""}
|
2018-04-25 17:41:33 +00:00
|
|
|
CA_CERTIFICATE_PATH=${CA_CERTIFICATE_PATH:-""}
|
2019-06-18 12:36:27 +00:00
|
|
|
CA_CERTIFICATE_PATH=${3:-$CA_CERTIFICATE_PATH}
|
2017-05-22 10:38:46 +00:00
|
|
|
|
2019-06-18 12:36:27 +00:00
|
|
|
if [ -z $CONF_PATH ]; then
|
2017-05-22 10:38:46 +00:00
|
|
|
api_root=${KURYR_K8S_API_ROOT:-https://127.0.0.1:6443}
|
|
|
|
auth_url=${KURYR_K8S_AUTH_URL:-http://127.0.0.1/identity}
|
|
|
|
username=${KURYR_K8S_USERNAME:-admin}
|
|
|
|
password=${KURYR_K8S_PASSWORD:-password}
|
|
|
|
user_domain_name=${KURYR_K8S_USER_DOMAIN_NAME:-Default}
|
|
|
|
kuryr_project_id=${KURYR_K8S_KURYR_PROJECT_ID}
|
|
|
|
project_domain_name=${KURYR_K8S_PROJECT_DOMAIN_NAME:-Default}
|
|
|
|
k8s_project_id=${KURYR_K8S_PROJECT_ID}
|
|
|
|
pod_subnet_id=${KURYR_K8S_POD_SUBNET_ID}
|
|
|
|
pod_sg=${KURYR_K8S_POD_SG}
|
|
|
|
service_subnet_id=${KURYR_K8S_SERVICE_SUBNET_ID}
|
2024-02-28 09:24:16 +00:00
|
|
|
worker_nodes_subnets=${KURYR_K8S_WORKER_NODES_SUBNET}
|
2017-05-22 10:38:46 +00:00
|
|
|
binding_driver=${KURYR_K8S_BINDING_DRIVER:-kuryr.lib.binding.drivers.vlan}
|
|
|
|
binding_iface=${KURYR_K8S_BINDING_IFACE:-eth0}
|
2018-04-18 11:03:27 +00:00
|
|
|
pod_subnet_pool=${KURYR_NEUTRON_DEFAULT_SUBNETPOOL_ID}
|
2017-05-22 10:38:46 +00:00
|
|
|
|
2019-06-18 12:36:27 +00:00
|
|
|
CONF_PATH="${OUTPUT_DIR}/kuryr.conf"
|
|
|
|
rm -f $CONF_PATH
|
|
|
|
cat >> $CONF_PATH << EOF
|
2017-05-22 10:38:46 +00:00
|
|
|
[DEFAULT]
|
|
|
|
debug = true
|
|
|
|
[kubernetes]
|
|
|
|
api_root = $api_root
|
|
|
|
token_file = /var/run/secrets/kubernetes.io/serviceaccount/token
|
|
|
|
ssl_ca_crt_file = /var/run/secrets/kubernetes.io/serviceaccount/ca.crt
|
|
|
|
[neutron]
|
|
|
|
signing_dir = /var/cache/kuryr
|
|
|
|
project_domain_name = $project_domain_name
|
|
|
|
project_id = $kuryr_project_id
|
|
|
|
user_domain_name = $user_domain_name
|
|
|
|
username = $username
|
|
|
|
password = $password
|
|
|
|
auth_url = $auth_url
|
|
|
|
auth_type = password
|
2020-04-21 02:19:14 +00:00
|
|
|
EOF
|
|
|
|
|
|
|
|
if [ ! -z $CA_CERTIFICATE_PATH ]; then
|
|
|
|
cat >> $CONF_PATH << EOF
|
|
|
|
cafile = /etc/ssl/certs/kuryr-ca-bundle.crt
|
|
|
|
EOF
|
|
|
|
fi
|
|
|
|
|
|
|
|
cat >> $CONF_PATH << EOF
|
2017-05-22 10:38:46 +00:00
|
|
|
[neutron_defaults]
|
|
|
|
ovs_bridge = br-int
|
|
|
|
service_subnet = $service_subnet_id
|
|
|
|
pod_security_groups = $pod_sg
|
|
|
|
pod_subnet = $pod_subnet_id
|
|
|
|
project = $k8s_project_id
|
2018-04-18 11:03:27 +00:00
|
|
|
[namespace_subnet]
|
|
|
|
pod_subnet_pool = $pod_subnet_pool
|
2019-06-18 12:36:27 +00:00
|
|
|
[cni_daemon]
|
|
|
|
docker_mode = true
|
|
|
|
netns_proc_dir = /host_proc
|
2018-02-02 12:22:31 +00:00
|
|
|
[vif_plug_ovs_privileged]
|
|
|
|
helper_command=privsep-helper
|
|
|
|
[vif_plug_linux_bridge_privileged]
|
|
|
|
helper_command=privsep-helper
|
2017-05-22 10:38:46 +00:00
|
|
|
EOF
|
|
|
|
|
|
|
|
if [ ! -z $binding_driver ]; then
|
2019-06-18 12:36:27 +00:00
|
|
|
cat >> $CONF_PATH << EOF
|
2017-05-22 10:38:46 +00:00
|
|
|
[pod_vif_nested]
|
2020-12-14 09:01:51 +00:00
|
|
|
worker_nodes_subnets = $worker_nodes_subnets
|
2017-05-22 10:38:46 +00:00
|
|
|
[binding]
|
|
|
|
driver = $binding_driver
|
|
|
|
link_iface = $binding_iface
|
|
|
|
EOF
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2018-03-22 17:28:28 +00:00
|
|
|
generate_kuryr_certificates_secret $OUTPUT_DIR $CA_CERTIFICATE_PATH
|
2019-06-18 12:36:27 +00:00
|
|
|
generate_kuryr_configmap $OUTPUT_DIR $CONF_PATH
|
2017-05-22 10:38:46 +00:00
|
|
|
generate_kuryr_service_account $OUTPUT_DIR
|
2017-12-20 14:15:53 +00:00
|
|
|
health_server_port=${KURYR_HEALTH_SERVER_PORT:-8082}
|
|
|
|
generate_controller_deployment $OUTPUT_DIR $health_server_port
|
2018-01-25 02:05:44 +00:00
|
|
|
cni_health_server_port=${KURYR_CNI_HEALTH_SERVER_PORT:-8090}
|
|
|
|
generate_cni_daemon_set $OUTPUT_DIR $cni_health_server_port
|