kubernetesopenstackopenstack-heat

Not able to bring up Kubernetes cluster in OpenStack


I'm trying to bring up a Kubernetes cluster in OpenStack using the steps mentioned here -> http://kubernetes.io/docs/getting-started-guides/openstack-heat/

The command KUBERNETES_PROVIDER=openstack-heat ./cluster/kube-up.sh fails with the following messages:

... Starting cluster using provider: openstack-heat
... calling verify-prereqs
swift client installed
glance client installed
nova client installed
heat client installed
openstack client installed
... calling kube-up
kube-up for provider openstack-heat
[INFO] Execute commands to create Kubernetes cluster
[INFO] Uploading kubernetes-server-linux-amd64.tar.gz
kubernetes-server.tar.gz
[INFO] Uploading kubernetes-salt.tar.gz
kubernetes-salt.tar.gz
[INFO] Image CentOS7 already exists
[INFO] Key pair already exists
Stack not found: KubernetesStack
[INFO] Retrieve new image ID
[INFO] Image Id 44284b7f-4f83-4c5d-89a2-992fab6ddaa3
[INFO] Create stack KubernetesStack
b'#cloud-config\nmerge_how: dict(recurse_array)+list(append)\nbootcmd:\n  - mkdir -p /etc/salt/minion.d\n  - mkdir -p /srv/salt-overlay/pillar\nwrite_files:\n  - path: /etc/salt/minion.d/log-level-debug.conf\n    content: |\n      log_level: warning\n      log_level_logfile: warning\n  - path: /etc/salt/minion.d/grains.conf\n    content: |\n      grains:\n        node_ip: $MASTER_IP\n        publicAddressOverride: $MASTER_IP\n        network_mode: openvswitch\n        networkInterfaceName: eth0\n        api_servers: $MASTER_IP\n        cloud: openstack\n        cloud_config: /srv/kubernetes/openstack.conf\n        roles:\n          - $role\n        runtime_config: ""\n        docker_opts: ""\n        master_extra_sans: "DNS:kubernetes,DNS:kubernetes.default,DNS:kubernetes.default.svc,DNS:kubernetes.default.svc.cluster.local,DNS:kubernetes-master"\n        keep_host_etcd: true\n        kube_user: $KUBE_USER\n  - path: /srv/kubernetes/openstack.conf\n    content: |\n      [Global]\n      auth-url=$OS_AUTH_URL\n      username=$OS_USERNAME\n      password=$OS_PASSWORD\n      region=$OS_REGION_NAME\n      tenant-id=$OS_TENANT_ID\n      [LoadBalancer]\n      lb-version=$LBAAS_VERSION\n      subnet-id=$SUBNET_ID\n      floating-network-id=$FLOATING_NETWORK_ID\n  - path: /srv/salt-overlay/pillar/cluster-params.sls\n    content: |\n      service_cluster_ip_range: 10.246.0.0/16\n      cert_ip: 10.246.0.1\n      enable_cluster_monitoring: influxdb\n      enable_cluster_logging: "true"\n      enable_cluster_ui: "true"\n      enable_node_logging: "true"\n      logging_destination: elasticsearch\n      elasticsearch_replicas: "1"\n      enable_cluster_dns: "true"\n      dns_server: 10.246.0.10\n      dns_domain: cluster.local\n      enable_dns_horizontal_autoscaler: "false"\n      federations_domain_map: \'\'\n      instance_prefix: kubernetes\n      admission_control: NamespaceLifecycle,LimitRanger,SecurityContextDeny,ServiceAccount,DefaultStorageClass,ResourceQuota\n      enable_cpu_cfs_quota: "true"\n      network_provider: none\n      opencontrail_tag: R2.20\n      opencontrail_kubernetes_tag: master\n      opencontrail_public_subnet: 10.1.0.0/16\n      e2e_storage_test_environment: "false"\n' is not JSON serializable

The last line is different for different executions of the kube-up.sh command. I have noticed that this corresponds to the yaml and sh files present in /cluster/openstack-heat/kubernetes-heat/kubecluster.yaml. In this example this is ./cluster/openstack-heat/kubernetes-heat/fragments/configure-salt.yaml

For some reason, it is not able to merge the contents of these files into kubecluster.yaml.

Any ideas?


Solution

  • Managed to solve this. It was because of a bug in python-heatclient 1.1.0. https://bugs.launchpad.net/python-heatclient/+bug/1589519

    Upgrading to version 1.3.0 solved the issue.