From cc11d7367ac7ef115b9704d919974eb4bd94640a Mon Sep 17 00:00:00 2001 From: Jordan Liggitt Date: Sat, 11 Feb 2017 16:12:53 -0500 Subject: [PATCH] Switch kube-scheduler to secure API access --- .../gce/container-linux/configure-helper.sh | 33 ++++++++++++++++++- cluster/gce/gci/configure-helper.sh | 33 ++++++++++++++++++- cluster/gce/trusty/configure-helper.sh | 4 ++- .../kube-scheduler/kube-scheduler.manifest | 20 ++++++++--- hack/local-up-cluster.sh | 3 +- .../resources/start-kubemark-master.sh | 33 +++++++++++++++++-- 6 files changed, 114 insertions(+), 12 deletions(-) diff --git a/cluster/gce/container-linux/configure-helper.sh b/cluster/gce/container-linux/configure-helper.sh index de7f9aab69f..f558b3de2e0 100755 --- a/cluster/gce/container-linux/configure-helper.sh +++ b/cluster/gce/container-linux/configure-helper.sh @@ -163,6 +163,9 @@ function create-master-auth { if [[ -n "${KUBE_CONTROLLER_MANAGER_TOKEN:-}" ]]; then replace_prefixed_line "${known_tokens_csv}" "${KUBE_CONTROLLER_MANAGER_TOKEN}," "system:kube-controller-manager,uid:system:kube-controller-manager" fi + if [[ -n "${KUBE_SCHEDULER_TOKEN:-}" ]]; then + replace_prefixed_line "${known_tokens_csv}" "${KUBE_SCHEDULER_TOKEN}," "system:kube-scheduler,uid:system:kube-scheduler" + fi if [[ -n "${KUBELET_TOKEN:-}" ]]; then replace_prefixed_line "${known_tokens_csv}" "${KUBELET_TOKEN}," "system:node:node-name,uid:kubelet,system:nodes" fi @@ -360,6 +363,30 @@ current-context: service-account-context EOF } +function create-kubescheduler-kubeconfig { + echo "Creating kube-scheduler kubeconfig file" + mkdir -p /etc/srv/kubernetes/kube-scheduler + cat </etc/srv/kubernetes/kube-scheduler/kubeconfig +apiVersion: v1 +kind: Config +users: +- name: kube-scheduler + user: + token: ${KUBE_SCHEDULER_TOKEN} +clusters: +- name: local + cluster: + insecure-skip-tls-verify: true + server: https://localhost:443 +contexts: +- context: + cluster: local + user: kube-scheduler + name: kube-scheduler +current-context: kube-scheduler +EOF +} + function create-master-etcd-auth { if [[ -n "${ETCD_CA_CERT:-}" && -n "${ETCD_PEER_KEY:-}" && -n "${ETCD_PEER_CERT:-}" ]]; then local -r auth_dir="/etc/srv/kubernetes" @@ -952,10 +979,12 @@ function start-kube-controller-manager { # DOCKER_REGISTRY function start-kube-scheduler { echo "Start kubernetes scheduler" + create-kubescheduler-kubeconfig prepare-log-file /var/log/kube-scheduler.log # Calculate variables and set them in the manifest. params="${SCHEDULER_TEST_LOG_LEVEL:-"--v=2"} ${SCHEDULER_TEST_ARGS:-}" + params+=" --kubeconfig=/etc/srv/kubernetes/kube-scheduler/kubeconfig" if [[ -n "${FEATURE_GATES:-}" ]]; then params+=" --feature-gates=${FEATURE_GATES}" fi @@ -968,6 +997,7 @@ function start-kube-scheduler { local -r src_file="${KUBE_HOME}/kube-manifests/kubernetes/gci-trusty/kube-scheduler.manifest" remove-salt-config-comments "${src_file}" + sed -i -e "s@{{srv_kube_path}}@/etc/srv/kubernetes@g" "${src_file}" sed -i -e "s@{{params}}@${params}@g" "${src_file}" sed -i -e "s@{{pillar\['kube_docker_registry'\]}}@${DOCKER_REGISTRY}@g" "${src_file}" sed -i -e "s@{{pillar\['kube-scheduler_docker_tag'\]}}@${kube_scheduler_docker_tag}@g" "${src_file}" @@ -1270,8 +1300,9 @@ if [[ -n "${KUBE_USER:-}" ]]; then fi fi -# generate the controller manager token here since its only used on the master. +# generate the controller manager and scheduler tokens here since they are only used on the master. KUBE_CONTROLLER_MANAGER_TOKEN=$(dd if=/dev/urandom bs=128 count=1 2>/dev/null | base64 | tr -d "=+/" | dd bs=32 count=1 2>/dev/null) +KUBE_SCHEDULER_TOKEN=$(dd if=/dev/urandom bs=128 count=1 2>/dev/null | base64 | tr -d "=+/" | dd bs=32 count=1 2>/dev/null) # KUBERNETES_CONTAINER_RUNTIME is set by the `kube-env` file, but it's a bit of a mouthful if [[ "${CONTAINER_RUNTIME:-}" == "" ]]; then diff --git a/cluster/gce/gci/configure-helper.sh b/cluster/gce/gci/configure-helper.sh index 4ca94669a5e..bdf9ae0ed51 100644 --- a/cluster/gce/gci/configure-helper.sh +++ b/cluster/gce/gci/configure-helper.sh @@ -233,6 +233,9 @@ function create-master-auth { if [[ -n "${KUBE_CONTROLLER_MANAGER_TOKEN:-}" ]]; then replace_prefixed_line "${known_tokens_csv}" "${KUBE_CONTROLLER_MANAGER_TOKEN}," "system:kube-controller-manager,uid:system:kube-controller-manager" fi + if [[ -n "${KUBE_SCHEDULER_TOKEN:-}" ]]; then + replace_prefixed_line "${known_tokens_csv}" "${KUBE_SCHEDULER_TOKEN}," "system:kube-scheduler,uid:system:kube-scheduler" + fi if [[ -n "${KUBELET_TOKEN:-}" ]]; then replace_prefixed_line "${known_tokens_csv}" "${KUBELET_TOKEN}," "system:node:node-name,uid:kubelet,system:nodes" fi @@ -431,6 +434,30 @@ current-context: service-account-context EOF } +function create-kubescheduler-kubeconfig { + echo "Creating kube-scheduler kubeconfig file" + mkdir -p /etc/srv/kubernetes/kube-scheduler + cat </etc/srv/kubernetes/kube-scheduler/kubeconfig +apiVersion: v1 +kind: Config +users: +- name: kube-scheduler + user: + token: ${KUBE_SCHEDULER_TOKEN} +clusters: +- name: local + cluster: + insecure-skip-tls-verify: true + server: https://localhost:443 +contexts: +- context: + cluster: local + user: kube-scheduler + name: kube-scheduler +current-context: kube-scheduler +EOF +} + function create-master-etcd-auth { if [[ -n "${ETCD_CA_CERT:-}" && -n "${ETCD_PEER_KEY:-}" && -n "${ETCD_PEER_CERT:-}" ]]; then local -r auth_dir="/etc/srv/kubernetes" @@ -1021,10 +1048,12 @@ function start-kube-controller-manager { # DOCKER_REGISTRY function start-kube-scheduler { echo "Start kubernetes scheduler" + create-kubescheduler-kubeconfig prepare-log-file /var/log/kube-scheduler.log # Calculate variables and set them in the manifest. params="${SCHEDULER_TEST_LOG_LEVEL:-"--v=2"} ${SCHEDULER_TEST_ARGS:-}" + params+=" --kubeconfig=/etc/srv/kubernetes/kube-scheduler/kubeconfig" if [[ -n "${FEATURE_GATES:-}" ]]; then params+=" --feature-gates=${FEATURE_GATES}" fi @@ -1037,6 +1066,7 @@ function start-kube-scheduler { local -r src_file="${KUBE_HOME}/kube-manifests/kubernetes/gci-trusty/kube-scheduler.manifest" remove-salt-config-comments "${src_file}" + sed -i -e "s@{{srv_kube_path}}@/etc/srv/kubernetes@g" "${src_file}" sed -i -e "s@{{params}}@${params}@g" "${src_file}" sed -i -e "s@{{pillar\['kube_docker_registry'\]}}@${DOCKER_REGISTRY}@g" "${src_file}" sed -i -e "s@{{pillar\['kube-scheduler_docker_tag'\]}}@${kube_scheduler_docker_tag}@g" "${src_file}" @@ -1335,8 +1365,9 @@ if [[ -n "${KUBE_USER:-}" ]]; then fi fi -# generate the controller manager token here since its only used on the master. +# generate the controller manager and scheduler tokens here since they are only used on the master. KUBE_CONTROLLER_MANAGER_TOKEN=$(dd if=/dev/urandom bs=128 count=1 2>/dev/null | base64 | tr -d "=+/" | dd bs=32 count=1 2>/dev/null) +KUBE_SCHEDULER_TOKEN=$(dd if=/dev/urandom bs=128 count=1 2>/dev/null | base64 | tr -d "=+/" | dd bs=32 count=1 2>/dev/null) setup-os-params config-ip-firewall diff --git a/cluster/gce/trusty/configure-helper.sh b/cluster/gce/trusty/configure-helper.sh index ce48a7a704a..b180f574dc3 100644 --- a/cluster/gce/trusty/configure-helper.sh +++ b/cluster/gce/trusty/configure-helper.sh @@ -769,7 +769,7 @@ start_kube_scheduler() { if [ -n "${SCHEDULER_TEST_LOG_LEVEL:-}" ]; then log_level="${SCHEDULER_TEST_LOG_LEVEL}" fi - params="${log_level} ${SCHEDULER_TEST_ARGS:-}" + params="--master=127.0.0.1:8080 ${log_level} ${SCHEDULER_TEST_ARGS:-}" if [ -n "${SCHEDULING_ALGORITHM_PROVIDER:-}" ]; then params="${params} --algorithm-provider=${SCHEDULING_ALGORITHM_PROVIDER}" fi @@ -779,6 +779,8 @@ start_kube_scheduler() { # Remove salt comments and replace variables with values src_file="${kube_home}/kube-manifests/kubernetes/gci-trusty/kube-scheduler.manifest" remove_salt_config_comments "${src_file}" + + sed -i -e "s@{{srv_kube_path}}@/etc/srv/kubernetes@g" "${src_file}" sed -i -e "s@{{params}}@${params}@g" "${src_file}" sed -i -e "s@{{pillar\['kube_docker_registry'\]}}@${DOCKER_REGISTRY}@g" "${src_file}" sed -i -e "s@{{pillar\['kube-scheduler_docker_tag'\]}}@${kube_scheduler_docker_tag}@g" "${src_file}" diff --git a/cluster/saltbase/salt/kube-scheduler/kube-scheduler.manifest b/cluster/saltbase/salt/kube-scheduler/kube-scheduler.manifest index bb64d3e72c3..4176f8f79f0 100644 --- a/cluster/saltbase/salt/kube-scheduler/kube-scheduler.manifest +++ b/cluster/saltbase/salt/kube-scheduler/kube-scheduler.manifest @@ -1,4 +1,5 @@ -{% set params = "" -%} +{% set params = "--master=127.0.0.1:8080" -%} +{% set srv_kube_path = "/srv/kubernetes" -%} {% set log_level = pillar['log_level'] -%} {% if pillar['scheduler_test_log_level'] is defined -%} @@ -47,7 +48,7 @@ "command": [ "/bin/sh", "-c", - "/usr/local/bin/kube-scheduler --master=127.0.0.1:8080 {{params}} 1>>/var/log/kube-scheduler.log 2>&1" + "/usr/local/bin/kube-scheduler {{params}} 1>>/var/log/kube-scheduler.log 2>&1" ], "livenessProbe": { "httpGet": { @@ -63,14 +64,23 @@ "name": "logfile", "mountPath": "/var/log/kube-scheduler.log", "readOnly": false + }, + { + "name": "srvkube", + "mountPath": "{{srv_kube_path}}", + "readOnly": true } ] } ], "volumes":[ - { "name": "logfile", - "hostPath": { - "path": "/var/log/kube-scheduler.log"} + { + "name": "srvkube", + "hostPath": {"path": "{{srv_kube_path}}"} + }, + { + "name": "logfile", + "hostPath": {"path": "/var/log/kube-scheduler.log"} } ] }} diff --git a/hack/local-up-cluster.sh b/hack/local-up-cluster.sh index e963e98ff42..d39997bf418 100755 --- a/hack/local-up-cluster.sh +++ b/hack/local-up-cluster.sh @@ -402,11 +402,10 @@ function start_apiserver { kube::util::create_signing_certkey "${CONTROLPLANE_SUDO}" "${CERT_DIR}" client '"client auth"' # Create client certs signed with client-ca, given id, given CN and a number of groups - # NOTE: system:masters will be removed in the future kube::util::create_client_certkey "${CONTROLPLANE_SUDO}" "${CERT_DIR}" 'client-ca' kubelet system:node:${HOSTNAME_OVERRIDE} system:nodes kube::util::create_client_certkey "${CONTROLPLANE_SUDO}" "${CERT_DIR}" 'client-ca' kube-proxy system:kube-proxy system:nodes kube::util::create_client_certkey "${CONTROLPLANE_SUDO}" "${CERT_DIR}" 'client-ca' controller system:kube-controller-manager - kube::util::create_client_certkey "${CONTROLPLANE_SUDO}" "${CERT_DIR}" 'client-ca' scheduler system:scheduler system:masters + kube::util::create_client_certkey "${CONTROLPLANE_SUDO}" "${CERT_DIR}" 'client-ca' scheduler system:kube-scheduler kube::util::create_client_certkey "${CONTROLPLANE_SUDO}" "${CERT_DIR}" 'client-ca' admin system:admin system:masters # Create auth proxy client ca diff --git a/test/kubemark/resources/start-kubemark-master.sh b/test/kubemark/resources/start-kubemark-master.sh index 219974d450a..84914964069 100644 --- a/test/kubemark/resources/start-kubemark-master.sh +++ b/test/kubemark/resources/start-kubemark-master.sh @@ -160,6 +160,30 @@ current-context: service-account-context EOF } +function create-kubescheduler-kubeconfig { + echo "Creating kube-scheduler kubeconfig file" + mkdir -p /etc/srv/kubernetes/kube-scheduler + cat </etc/srv/kubernetes/kube-scheduler/kubeconfig +apiVersion: v1 +kind: Config +users: +- name: kube-scheduler + user: + token: ${KUBE_SCHEDULER_TOKEN} +clusters: +- name: local + cluster: + insecure-skip-tls-verify: true + server: https://localhost:443 +contexts: +- context: + cluster: local + user: kube-scheduler + name: kube-scheduler +current-context: kube-scheduler +EOF +} + function assemble-docker-flags { echo "Assemble docker command line flags" local docker_opts="-p /var/run/docker.pid --iptables=false --ip-masq=false" @@ -346,7 +370,7 @@ function compute-kube-controller-manager-params { # Computes command line arguments to be passed to scheduler. function compute-kube-scheduler-params { local params="${SCHEDULER_TEST_ARGS:-}" - params+=" --master=127.0.0.1:8080" + params+=" --kubeconfig=/etc/srv/kubernetes/kube-scheduler/kubeconfig" echo "${params}" } @@ -405,11 +429,16 @@ setup-kubelet-dir delete-default-etcd-configs compute-etcd-variables -# Setup authentication token and kubeconfig for controller-manager. +# Setup authentication token and kubeconfig for kube-controller-manager. KUBE_CONTROLLER_MANAGER_TOKEN=$(dd if=/dev/urandom bs=128 count=1 2>/dev/null | base64 | tr -d "=+/" | dd bs=32 count=1 2>/dev/null) echo "${KUBE_CONTROLLER_MANAGER_TOKEN},system:kube-controller-manager,uid:system:kube-controller-manager" >> /etc/srv/kubernetes/known_tokens.csv create-kubecontrollermanager-kubeconfig +# Setup authentication token and kubeconfig for kube-scheduler. +KUBE_SCHEDULER_TOKEN=$(dd if=/dev/urandom bs=128 count=1 2>/dev/null | base64 | tr -d "=+/" | dd bs=32 count=1 2>/dev/null) +echo "${KUBE_SCHEDULER_TOKEN},system:kube-scheduler,uid:system:kube-scheduler" >> /etc/srv/kubernetes/known_tokens.csv +create-kubescheduler-kubeconfig + # Mount master PD for etcd and create symbolic links to it. { main_etcd_mount_point="/mnt/disks/master-pd"