mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-08-03 01:06:27 +00:00
coreos/azure: Move into a separate repo
This commit is contained in:
parent
9fab05fe59
commit
712c1e2123
@ -1 +0,0 @@
|
|||||||
node_modules/
|
|
@ -1,99 +0,0 @@
|
|||||||
apiVersion: v1
|
|
||||||
kind: ReplicationController
|
|
||||||
metadata:
|
|
||||||
name: kube-dns-v9
|
|
||||||
namespace: kube-system
|
|
||||||
labels:
|
|
||||||
k8s-app: kube-dns
|
|
||||||
version: v9
|
|
||||||
kubernetes.io/cluster-service: "true"
|
|
||||||
spec:
|
|
||||||
replicas: 3
|
|
||||||
selector:
|
|
||||||
k8s-app: kube-dns
|
|
||||||
version: v9
|
|
||||||
template:
|
|
||||||
metadata:
|
|
||||||
labels:
|
|
||||||
k8s-app: kube-dns
|
|
||||||
version: v9
|
|
||||||
kubernetes.io/cluster-service: "true"
|
|
||||||
spec:
|
|
||||||
containers:
|
|
||||||
- name: etcd
|
|
||||||
image: gcr.io/google_containers/etcd:2.0.9
|
|
||||||
resources:
|
|
||||||
limits:
|
|
||||||
cpu: 100m
|
|
||||||
memory: 50Mi
|
|
||||||
command:
|
|
||||||
- /usr/local/bin/etcd
|
|
||||||
- -data-dir
|
|
||||||
- /var/etcd/data
|
|
||||||
- -listen-client-urls
|
|
||||||
- http://127.0.0.1:2379,http://127.0.0.1:4001
|
|
||||||
- -advertise-client-urls
|
|
||||||
- http://127.0.0.1:2379,http://127.0.0.1:4001
|
|
||||||
- -initial-cluster-token
|
|
||||||
- skydns-etcd
|
|
||||||
volumeMounts:
|
|
||||||
- name: etcd-storage
|
|
||||||
mountPath: /var/etcd/data
|
|
||||||
- name: kube2sky
|
|
||||||
image: gcr.io/google_containers/kube2sky:1.11
|
|
||||||
resources:
|
|
||||||
limits:
|
|
||||||
cpu: 100m
|
|
||||||
memory: 50Mi
|
|
||||||
args:
|
|
||||||
# command = "/kube2sky"
|
|
||||||
- -domain=kube.local
|
|
||||||
- -kube_master_url=http://kube-00:8080
|
|
||||||
- name: skydns
|
|
||||||
image: gcr.io/google_containers/skydns:2015-03-11-001
|
|
||||||
resources:
|
|
||||||
limits:
|
|
||||||
cpu: 100m
|
|
||||||
memory: 50Mi
|
|
||||||
args:
|
|
||||||
# command = "/skydns"
|
|
||||||
- -machines=http://localhost:4001
|
|
||||||
- -addr=0.0.0.0:53
|
|
||||||
- -domain=kube.local
|
|
||||||
ports:
|
|
||||||
- containerPort: 53
|
|
||||||
name: dns
|
|
||||||
protocol: UDP
|
|
||||||
- containerPort: 53
|
|
||||||
name: dns-tcp
|
|
||||||
protocol: TCP
|
|
||||||
livenessProbe:
|
|
||||||
httpGet:
|
|
||||||
path: /healthz
|
|
||||||
port: 8080
|
|
||||||
scheme: HTTP
|
|
||||||
initialDelaySeconds: 30
|
|
||||||
timeoutSeconds: 5
|
|
||||||
readinessProbe:
|
|
||||||
httpGet:
|
|
||||||
path: /healthz
|
|
||||||
port: 8080
|
|
||||||
scheme: HTTP
|
|
||||||
initialDelaySeconds: 1
|
|
||||||
timeoutSeconds: 5
|
|
||||||
- name: healthz
|
|
||||||
image: gcr.io/google_containers/exechealthz:1.0
|
|
||||||
resources:
|
|
||||||
limits:
|
|
||||||
cpu: 10m
|
|
||||||
memory: 20Mi
|
|
||||||
args:
|
|
||||||
- -cmd=nslookup kubernetes.default.svc.kube.local localhost >/dev/null
|
|
||||||
- -port=8080
|
|
||||||
ports:
|
|
||||||
- containerPort: 8080
|
|
||||||
protocol: TCP
|
|
||||||
volumes:
|
|
||||||
- name: etcd-storage
|
|
||||||
emptyDir: {}
|
|
||||||
dnsPolicy: Default # Don't use cluster DNS.
|
|
@ -1,20 +0,0 @@
|
|||||||
apiVersion: v1
|
|
||||||
kind: Service
|
|
||||||
metadata:
|
|
||||||
name: kube-dns
|
|
||||||
namespace: kube-system
|
|
||||||
labels:
|
|
||||||
k8s-app: kube-dns
|
|
||||||
kubernetes.io/cluster-service: "true"
|
|
||||||
kubernetes.io/name: "KubeDNS"
|
|
||||||
spec:
|
|
||||||
selector:
|
|
||||||
k8s-app: kube-dns
|
|
||||||
clusterIP: 10.16.0.3
|
|
||||||
ports:
|
|
||||||
- name: dns
|
|
||||||
port: 53
|
|
||||||
protocol: UDP
|
|
||||||
- name: dns-tcp
|
|
||||||
port: 53
|
|
||||||
protocol: TCP
|
|
@ -1,3 +0,0 @@
|
|||||||
#!/usr/bin/env node
|
|
||||||
|
|
||||||
require('child_process').fork('node_modules/azure-cli/bin/azure', ['login'].concat(process.argv));
|
|
@ -1,19 +0,0 @@
|
|||||||
## This file is used as input to deployment script, which amends it as needed.
|
|
||||||
## More specifically, we need to add peer hosts for each but the elected peer.
|
|
||||||
|
|
||||||
coreos:
|
|
||||||
units:
|
|
||||||
- name: etcd2.service
|
|
||||||
enable: true
|
|
||||||
command: start
|
|
||||||
etcd2:
|
|
||||||
name: '%H'
|
|
||||||
initial-cluster-token: 'etcd-cluster'
|
|
||||||
initial-advertise-peer-urls: 'http://%H:2380'
|
|
||||||
listen-peer-urls: 'http://%H:2380'
|
|
||||||
listen-client-urls: 'http://0.0.0.0:2379,http://0.0.0.0:4001'
|
|
||||||
advertise-client-urls: 'http://%H:2379,http://%H:4001'
|
|
||||||
initial-cluster-state: 'new'
|
|
||||||
update:
|
|
||||||
group: stable
|
|
||||||
reboot-strategy: off
|
|
@ -1,335 +0,0 @@
|
|||||||
## This file is used as input to deployment script, which amends it as needed.
|
|
||||||
## More specifically, we need to add environment files for as many nodes as we
|
|
||||||
## are going to deploy.
|
|
||||||
|
|
||||||
write_files:
|
|
||||||
- path: /opt/bin/curl-retry.sh
|
|
||||||
permissions: '0755'
|
|
||||||
owner: root
|
|
||||||
content: |
|
|
||||||
#!/bin/sh -x
|
|
||||||
until curl $@
|
|
||||||
do sleep 1
|
|
||||||
done
|
|
||||||
|
|
||||||
coreos:
|
|
||||||
update:
|
|
||||||
group: stable
|
|
||||||
reboot-strategy: off
|
|
||||||
units:
|
|
||||||
- name: systemd-networkd-wait-online.service
|
|
||||||
drop-ins:
|
|
||||||
- name: 50-check-github-is-reachable.conf
|
|
||||||
content: |
|
|
||||||
[Service]
|
|
||||||
ExecStart=/bin/sh -x -c \
|
|
||||||
'until curl --silent --fail https://status.github.com/api/status.json | grep -q \"good\"; do sleep 2; done'
|
|
||||||
|
|
||||||
- name: weave-network.target
|
|
||||||
enable: true
|
|
||||||
content: |
|
|
||||||
[Unit]
|
|
||||||
Description=Weave Network Setup Complete
|
|
||||||
Documentation=man:systemd.special(7)
|
|
||||||
RefuseManualStart=no
|
|
||||||
After=network-online.target
|
|
||||||
[Install]
|
|
||||||
WantedBy=multi-user.target
|
|
||||||
WantedBy=kubernetes-master.target
|
|
||||||
WantedBy=kubernetes-node.target
|
|
||||||
|
|
||||||
- name: kubernetes-master.target
|
|
||||||
enable: true
|
|
||||||
command: start
|
|
||||||
content: |
|
|
||||||
[Unit]
|
|
||||||
Description=Kubernetes Cluster Master
|
|
||||||
Documentation=http://kubernetes.io/
|
|
||||||
RefuseManualStart=no
|
|
||||||
After=weave-network.target
|
|
||||||
Requires=weave-network.target
|
|
||||||
ConditionHost=kube-00
|
|
||||||
Wants=kube-apiserver.service
|
|
||||||
Wants=kube-scheduler.service
|
|
||||||
Wants=kube-controller-manager.service
|
|
||||||
Wants=kube-proxy.service
|
|
||||||
[Install]
|
|
||||||
WantedBy=multi-user.target
|
|
||||||
|
|
||||||
- name: kubernetes-node.target
|
|
||||||
enable: true
|
|
||||||
command: start
|
|
||||||
content: |
|
|
||||||
[Unit]
|
|
||||||
Description=Kubernetes Cluster Node
|
|
||||||
Documentation=http://kubernetes.io/
|
|
||||||
RefuseManualStart=no
|
|
||||||
After=weave-network.target
|
|
||||||
Requires=weave-network.target
|
|
||||||
ConditionHost=!kube-00
|
|
||||||
Wants=kube-proxy.service
|
|
||||||
Wants=kubelet.service
|
|
||||||
[Install]
|
|
||||||
WantedBy=multi-user.target
|
|
||||||
|
|
||||||
- name: 10-weave.network
|
|
||||||
runtime: false
|
|
||||||
content: |
|
|
||||||
[Match]
|
|
||||||
Type=bridge
|
|
||||||
Name=weave*
|
|
||||||
[Network]
|
|
||||||
|
|
||||||
- name: install-weave.service
|
|
||||||
enable: true
|
|
||||||
content: |
|
|
||||||
[Unit]
|
|
||||||
After=network-online.target
|
|
||||||
After=docker.service
|
|
||||||
Before=weave.service
|
|
||||||
Description=Install Weave
|
|
||||||
Documentation=http://docs.weave.works/
|
|
||||||
Requires=network-online.target
|
|
||||||
[Service]
|
|
||||||
EnvironmentFile=-/etc/weave.%H.env
|
|
||||||
EnvironmentFile=-/etc/weave.env
|
|
||||||
Type=oneshot
|
|
||||||
RemainAfterExit=yes
|
|
||||||
TimeoutStartSec=0
|
|
||||||
ExecStartPre=/bin/mkdir -p /opt/bin/
|
|
||||||
ExecStartPre=/opt/bin/curl-retry.sh \
|
|
||||||
--silent \
|
|
||||||
--location \
|
|
||||||
git.io/weave \
|
|
||||||
--output /opt/bin/weave
|
|
||||||
ExecStartPre=/usr/bin/chmod +x /opt/bin/weave
|
|
||||||
ExecStart=/opt/bin/weave setup
|
|
||||||
[Install]
|
|
||||||
WantedBy=weave-network.target
|
|
||||||
WantedBy=weave.service
|
|
||||||
|
|
||||||
- name: weaveproxy.service
|
|
||||||
enable: true
|
|
||||||
content: |
|
|
||||||
[Unit]
|
|
||||||
After=install-weave.service
|
|
||||||
After=docker.service
|
|
||||||
Description=Weave proxy for Docker API
|
|
||||||
Documentation=http://docs.weave.works/
|
|
||||||
Requires=docker.service
|
|
||||||
Requires=install-weave.service
|
|
||||||
[Service]
|
|
||||||
EnvironmentFile=-/etc/weave.%H.env
|
|
||||||
EnvironmentFile=-/etc/weave.env
|
|
||||||
ExecStartPre=/opt/bin/weave launch-proxy --rewrite-inspect --without-dns
|
|
||||||
ExecStart=/usr/bin/docker attach weaveproxy
|
|
||||||
Restart=on-failure
|
|
||||||
ExecStop=/opt/bin/weave stop-proxy
|
|
||||||
[Install]
|
|
||||||
WantedBy=weave-network.target
|
|
||||||
|
|
||||||
- name: weave.service
|
|
||||||
enable: true
|
|
||||||
content: |
|
|
||||||
[Unit]
|
|
||||||
After=install-weave.service
|
|
||||||
After=docker.service
|
|
||||||
Description=Weave Network Router
|
|
||||||
Documentation=http://docs.weave.works/
|
|
||||||
Requires=docker.service
|
|
||||||
Requires=install-weave.service
|
|
||||||
[Service]
|
|
||||||
TimeoutStartSec=0
|
|
||||||
EnvironmentFile=-/etc/weave.%H.env
|
|
||||||
EnvironmentFile=-/etc/weave.env
|
|
||||||
ExecStartPre=/opt/bin/weave launch-router $WEAVE_PEERS
|
|
||||||
ExecStart=/usr/bin/docker attach weave
|
|
||||||
Restart=on-failure
|
|
||||||
ExecStop=/opt/bin/weave stop-router
|
|
||||||
[Install]
|
|
||||||
WantedBy=weave-network.target
|
|
||||||
|
|
||||||
- name: weave-expose.service
|
|
||||||
enable: true
|
|
||||||
content: |
|
|
||||||
[Unit]
|
|
||||||
After=install-weave.service
|
|
||||||
After=weave.service
|
|
||||||
After=docker.service
|
|
||||||
Documentation=http://docs.weave.works/
|
|
||||||
Requires=docker.service
|
|
||||||
Requires=install-weave.service
|
|
||||||
Requires=weave.service
|
|
||||||
[Service]
|
|
||||||
Type=oneshot
|
|
||||||
RemainAfterExit=yes
|
|
||||||
TimeoutStartSec=0
|
|
||||||
EnvironmentFile=-/etc/weave.%H.env
|
|
||||||
EnvironmentFile=-/etc/weave.env
|
|
||||||
ExecStart=/opt/bin/weave expose
|
|
||||||
ExecStop=/opt/bin/weave hide
|
|
||||||
[Install]
|
|
||||||
WantedBy=weave-network.target
|
|
||||||
|
|
||||||
- name: install-kubernetes.service
|
|
||||||
enable: true
|
|
||||||
content: |
|
|
||||||
[Unit]
|
|
||||||
After=network-online.target
|
|
||||||
Before=kube-apiserver.service
|
|
||||||
Before=kube-controller-manager.service
|
|
||||||
Before=kubelet.service
|
|
||||||
Before=kube-proxy.service
|
|
||||||
Description=Download Kubernetes Binaries
|
|
||||||
Documentation=http://kubernetes.io/
|
|
||||||
Requires=network-online.target
|
|
||||||
[Service]
|
|
||||||
Environment=KUBE_RELEASE_TARBALL=https://github.com/kubernetes/kubernetes/releases/download/v1.1.2/kubernetes.tar.gz
|
|
||||||
ExecStartPre=/bin/mkdir -p /opt/
|
|
||||||
ExecStart=/opt/bin/curl-retry.sh --silent --location $KUBE_RELEASE_TARBALL --output /tmp/kubernetes.tgz
|
|
||||||
ExecStart=/bin/tar xzvf /tmp/kubernetes.tgz -C /tmp/
|
|
||||||
ExecStart=/bin/tar xzvf /tmp/kubernetes/server/kubernetes-server-linux-amd64.tar.gz -C /opt
|
|
||||||
ExecStartPost=/bin/chmod o+rx -R /opt/kubernetes
|
|
||||||
ExecStartPost=/bin/ln -s /opt/kubernetes/server/bin/kubectl /opt/bin/
|
|
||||||
ExecStartPost=/bin/mv /tmp/kubernetes/examples/guestbook /home/core/guestbook-example
|
|
||||||
ExecStartPost=/bin/chown core. -R /home/core/guestbook-example
|
|
||||||
ExecStartPost=/bin/rm -rf /tmp/kubernetes
|
|
||||||
ExecStartPost=/bin/sed 's/# type: LoadBalancer/type: NodePort/' -i /home/core/guestbook-example/frontend-service.yaml
|
|
||||||
RemainAfterExit=yes
|
|
||||||
Type=oneshot
|
|
||||||
[Install]
|
|
||||||
WantedBy=kubernetes-master.target
|
|
||||||
WantedBy=kubernetes-node.target
|
|
||||||
|
|
||||||
- name: kube-apiserver.service
|
|
||||||
enable: true
|
|
||||||
content: |
|
|
||||||
[Unit]
|
|
||||||
After=install-kubernetes.service
|
|
||||||
Before=kube-controller-manager.service
|
|
||||||
Before=kube-scheduler.service
|
|
||||||
ConditionFileIsExecutable=/opt/kubernetes/server/bin/kube-apiserver
|
|
||||||
Description=Kubernetes API Server
|
|
||||||
Documentation=http://kubernetes.io/
|
|
||||||
Wants=install-kubernetes.service
|
|
||||||
ConditionHost=kube-00
|
|
||||||
[Service]
|
|
||||||
ExecStart=/opt/kubernetes/server/bin/kube-apiserver \
|
|
||||||
--insecure-bind-address=0.0.0.0 \
|
|
||||||
--advertise-address=$public_ipv4 \
|
|
||||||
--port=8080 \
|
|
||||||
$ETCD_SERVERS \
|
|
||||||
--service-cluster-ip-range=10.16.0.0/12 \
|
|
||||||
--cloud-provider=vagrant \
|
|
||||||
--logtostderr=true
|
|
||||||
Restart=always
|
|
||||||
RestartSec=10
|
|
||||||
[Install]
|
|
||||||
WantedBy=kubernetes-master.target
|
|
||||||
|
|
||||||
- name: kube-scheduler.service
|
|
||||||
enable: true
|
|
||||||
content: |
|
|
||||||
[Unit]
|
|
||||||
After=kube-apiserver.service
|
|
||||||
After=install-kubernetes.service
|
|
||||||
ConditionFileIsExecutable=/opt/kubernetes/server/bin/kube-scheduler
|
|
||||||
Description=Kubernetes Scheduler
|
|
||||||
Documentation=http://kubernetes.io/
|
|
||||||
Wants=kube-apiserver.service
|
|
||||||
ConditionHost=kube-00
|
|
||||||
[Service]
|
|
||||||
ExecStart=/opt/kubernetes/server/bin/kube-scheduler \
|
|
||||||
--logtostderr=true \
|
|
||||||
--master=127.0.0.1:8080
|
|
||||||
Restart=always
|
|
||||||
RestartSec=10
|
|
||||||
[Install]
|
|
||||||
WantedBy=kubernetes-master.target
|
|
||||||
|
|
||||||
- name: kube-controller-manager.service
|
|
||||||
enable: true
|
|
||||||
content: |
|
|
||||||
[Unit]
|
|
||||||
After=install-kubernetes.service
|
|
||||||
After=kube-apiserver.service
|
|
||||||
ConditionFileIsExecutable=/opt/kubernetes/server/bin/kube-controller-manager
|
|
||||||
Description=Kubernetes Controller Manager
|
|
||||||
Documentation=http://kubernetes.io/
|
|
||||||
Wants=kube-apiserver.service
|
|
||||||
Wants=install-kubernetes.service
|
|
||||||
ConditionHost=kube-00
|
|
||||||
[Service]
|
|
||||||
ExecStart=/opt/kubernetes/server/bin/kube-controller-manager \
|
|
||||||
--master=127.0.0.1:8080 \
|
|
||||||
--logtostderr=true
|
|
||||||
Restart=always
|
|
||||||
RestartSec=10
|
|
||||||
[Install]
|
|
||||||
WantedBy=kubernetes-master.target
|
|
||||||
|
|
||||||
- name: kubelet.service
|
|
||||||
enable: true
|
|
||||||
content: |
|
|
||||||
[Unit]
|
|
||||||
After=install-kubernetes.service
|
|
||||||
ConditionFileIsExecutable=/opt/kubernetes/server/bin/kubelet
|
|
||||||
Description=Kubernetes Kubelet
|
|
||||||
Documentation=http://kubernetes.io/
|
|
||||||
Wants=install-kubernetes.service
|
|
||||||
ConditionHost=!kube-00
|
|
||||||
[Service]
|
|
||||||
ExecStartPre=/bin/mkdir -p /etc/kubernetes/manifests/
|
|
||||||
ExecStart=/opt/kubernetes/server/bin/kubelet \
|
|
||||||
--docker-endpoint=unix:/var/run/weave/weave.sock \
|
|
||||||
--address=0.0.0.0 \
|
|
||||||
--port=10250 \
|
|
||||||
--hostname-override=%H \
|
|
||||||
--api-servers=http://kube-00:8080 \
|
|
||||||
--logtostderr=true \
|
|
||||||
--cluster-dns=10.16.0.3 \
|
|
||||||
--cluster-domain=kube.local \
|
|
||||||
--config=/etc/kubernetes/manifests/
|
|
||||||
Restart=always
|
|
||||||
RestartSec=10
|
|
||||||
[Install]
|
|
||||||
WantedBy=kubernetes-node.target
|
|
||||||
|
|
||||||
- name: kube-proxy.service
|
|
||||||
enable: true
|
|
||||||
content: |
|
|
||||||
[Unit]
|
|
||||||
After=install-kubernetes.service
|
|
||||||
ConditionFileIsExecutable=/opt/kubernetes/server/bin/kube-proxy
|
|
||||||
Description=Kubernetes Proxy
|
|
||||||
Documentation=http://kubernetes.io/
|
|
||||||
Wants=install-kubernetes.service
|
|
||||||
[Service]
|
|
||||||
ExecStart=/opt/kubernetes/server/bin/kube-proxy \
|
|
||||||
--master=http://kube-00:8080 \
|
|
||||||
--logtostderr=true
|
|
||||||
Restart=always
|
|
||||||
RestartSec=10
|
|
||||||
[Install]
|
|
||||||
WantedBy=kubernetes-master.target
|
|
||||||
WantedBy=kubernetes-node.target
|
|
||||||
|
|
||||||
- name: kube-create-addons.service
|
|
||||||
enable: true
|
|
||||||
content: |
|
|
||||||
[Unit]
|
|
||||||
After=install-kubernetes.service
|
|
||||||
ConditionFileIsExecutable=/opt/kubernetes/server/bin/kubectl
|
|
||||||
ConditionPathIsDirectory=/etc/kubernetes/addons/
|
|
||||||
ConditionHost=kube-00
|
|
||||||
Description=Kubernetes Addons
|
|
||||||
Documentation=http://kubernetes.io/
|
|
||||||
Wants=install-kubernetes.service
|
|
||||||
Wants=kube-apiserver.service
|
|
||||||
[Service]
|
|
||||||
Type=oneshot
|
|
||||||
RemainAfterExit=no
|
|
||||||
ExecStart=/bin/bash -c 'until /opt/kubernetes/server/bin/kubectl create -f /etc/kubernetes/addons/; do sleep 2; done'
|
|
||||||
SuccessExitStatus=1
|
|
||||||
[Install]
|
|
||||||
WantedBy=kubernetes-master.target
|
|
@ -1,15 +0,0 @@
|
|||||||
#!/usr/bin/env node
|
|
||||||
|
|
||||||
var azure = require('./lib/azure_wrapper.js');
|
|
||||||
var kube = require('./lib/deployment_logic/kubernetes.js');
|
|
||||||
|
|
||||||
azure.create_config('kube', { 'etcd': 3, 'kube': 3 });
|
|
||||||
|
|
||||||
azure.run_task_queue([
|
|
||||||
azure.queue_default_network(),
|
|
||||||
azure.queue_storage_if_needed(),
|
|
||||||
azure.queue_machines('etcd', 'stable',
|
|
||||||
kube.create_etcd_cloud_config),
|
|
||||||
azure.queue_machines('kube', 'stable',
|
|
||||||
kube.create_node_cloud_config),
|
|
||||||
]);
|
|
@ -1,7 +0,0 @@
|
|||||||
#!/usr/bin/env node
|
|
||||||
|
|
||||||
var azure = require('./lib/azure_wrapper.js');
|
|
||||||
|
|
||||||
azure.destroy_cluster(process.argv[2]);
|
|
||||||
|
|
||||||
console.log('The cluster had been destroyed, you can delete the state file now.');
|
|
@ -1,29 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
# Copyright 2014 The Kubernetes Authors.
|
|
||||||
#
|
|
||||||
# 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
|
|
||||||
|
|
||||||
[ ! -z $1 ] || (echo Usage: $0 ssh_conf; exit 1)
|
|
||||||
|
|
||||||
fe_port=$(ssh -F $1 kube-00 \
|
|
||||||
"/opt/bin/kubectl get -o template --template='{{(index .spec.ports 0).nodePort}}' services frontend -L name=frontend" \
|
|
||||||
)
|
|
||||||
|
|
||||||
echo "Guestbook app is on port $fe_port, will map it to port 80 on kube-00"
|
|
||||||
|
|
||||||
./node_modules/.bin/azure vm endpoint create kube-00 80 $fe_port
|
|
||||||
|
|
||||||
./node_modules/.bin/azure vm endpoint show kube-00 tcp-80-${fe_port}
|
|
Binary file not shown.
Before Width: | Height: | Size: 286 KiB |
Binary file not shown.
Before Width: | Height: | Size: 169 KiB |
@ -1,286 +0,0 @@
|
|||||||
var _ = require('underscore');
|
|
||||||
|
|
||||||
var fs = require('fs');
|
|
||||||
var cp = require('child_process');
|
|
||||||
|
|
||||||
var yaml = require('js-yaml');
|
|
||||||
|
|
||||||
var openssl = require('openssl-wrapper');
|
|
||||||
|
|
||||||
var clr = require('colors');
|
|
||||||
var inspect = require('util').inspect;
|
|
||||||
|
|
||||||
var util = require('./util.js');
|
|
||||||
|
|
||||||
var coreos_image_ids = {
|
|
||||||
'stable': '2b171e93f07c4903bcad35bda10acf22__CoreOS-Stable-835.12.0', // untested
|
|
||||||
'beta': '2b171e93f07c4903bcad35bda10acf22__CoreOS-Beta-899.6.0',
|
|
||||||
'alpha': '2b171e93f07c4903bcad35bda10acf22__CoreOS-Alpha-942.0.0' // untested
|
|
||||||
};
|
|
||||||
|
|
||||||
var conf = {};
|
|
||||||
|
|
||||||
var hosts = {
|
|
||||||
collection: [],
|
|
||||||
ssh_port_counter: 2200,
|
|
||||||
};
|
|
||||||
|
|
||||||
var task_queue = [];
|
|
||||||
|
|
||||||
exports.run_task_queue = function (dummy) {
|
|
||||||
var tasks = {
|
|
||||||
todo: task_queue,
|
|
||||||
done: [],
|
|
||||||
};
|
|
||||||
|
|
||||||
var pop_task = function() {
|
|
||||||
console.log(clr.yellow('azure_wrapper/task:'), clr.grey(inspect(tasks)));
|
|
||||||
var ret = {};
|
|
||||||
ret.current = tasks.todo.shift();
|
|
||||||
ret.remaining = tasks.todo.length;
|
|
||||||
return ret;
|
|
||||||
};
|
|
||||||
|
|
||||||
(function iter (task) {
|
|
||||||
if (task.current === undefined) {
|
|
||||||
if (conf.destroying === undefined) {
|
|
||||||
create_ssh_conf();
|
|
||||||
save_state();
|
|
||||||
}
|
|
||||||
return;
|
|
||||||
} else {
|
|
||||||
if (task.current.length !== 0) {
|
|
||||||
console.log(clr.yellow('azure_wrapper/exec:'), clr.blue(inspect(task.current)));
|
|
||||||
cp.fork('node_modules/azure-cli/bin/azure', task.current)
|
|
||||||
.on('exit', function (code, signal) {
|
|
||||||
tasks.done.push({
|
|
||||||
code: code,
|
|
||||||
signal: signal,
|
|
||||||
what: task.current.join(' '),
|
|
||||||
remaining: task.remaining,
|
|
||||||
});
|
|
||||||
if (code !== 0 && conf.destroying === undefined) {
|
|
||||||
console.log(clr.red('azure_wrapper/fail: Exiting due to an error.'));
|
|
||||||
save_state();
|
|
||||||
console.log(clr.cyan('azure_wrapper/info: You probably want to destroy and re-run.'));
|
|
||||||
process.abort();
|
|
||||||
} else {
|
|
||||||
iter(pop_task());
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
iter(pop_task());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
})(pop_task());
|
|
||||||
};
|
|
||||||
|
|
||||||
var save_state = function () {
|
|
||||||
var file_name = util.join_output_file_path(conf.name, 'deployment.yml');
|
|
||||||
try {
|
|
||||||
conf.hosts = hosts.collection;
|
|
||||||
fs.writeFileSync(file_name, yaml.safeDump(conf));
|
|
||||||
console.log(clr.yellow('azure_wrapper/info: Saved state into `%s`'), file_name);
|
|
||||||
} catch (e) {
|
|
||||||
console.log(clr.red(e));
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
var load_state = function (file_name) {
|
|
||||||
try {
|
|
||||||
conf = yaml.safeLoad(fs.readFileSync(file_name, 'utf8'));
|
|
||||||
console.log(clr.yellow('azure_wrapper/info: Loaded state from `%s`'), file_name);
|
|
||||||
return conf;
|
|
||||||
} catch (e) {
|
|
||||||
console.log(clr.red(e));
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
var create_ssh_key = function (prefix) {
|
|
||||||
var opts = {
|
|
||||||
x509: true,
|
|
||||||
nodes: true,
|
|
||||||
newkey: 'rsa:2048',
|
|
||||||
subj: '/O=Weaveworks, Inc./L=London/C=GB/CN=weave.works',
|
|
||||||
keyout: util.join_output_file_path(prefix, 'ssh.key'),
|
|
||||||
out: util.join_output_file_path(prefix, 'ssh.pem'),
|
|
||||||
};
|
|
||||||
openssl.exec('req', opts, function (err, buffer) {
|
|
||||||
if (err) console.log(clr.red(err));
|
|
||||||
openssl.exec('rsa', { in: opts.keyout, out: opts.keyout }, function (err, buffer) {
|
|
||||||
if (err) console.log(clr.red(err));
|
|
||||||
fs.chmod(opts.keyout, '0600', function (err) {
|
|
||||||
if (err) console.log(clr.red(err));
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
return {
|
|
||||||
key: opts.keyout,
|
|
||||||
pem: opts.out,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var create_ssh_conf = function () {
|
|
||||||
var file_name = util.join_output_file_path(conf.name, 'ssh_conf');
|
|
||||||
var ssh_conf_head = [
|
|
||||||
"Host *",
|
|
||||||
"\tHostname " + conf.resources['service'] + ".cloudapp.net",
|
|
||||||
"\tUser core",
|
|
||||||
"\tCompression yes",
|
|
||||||
"\tLogLevel FATAL",
|
|
||||||
"\tStrictHostKeyChecking no",
|
|
||||||
"\tUserKnownHostsFile /dev/null",
|
|
||||||
"\tIdentitiesOnly yes",
|
|
||||||
"\tIdentityFile " + conf.resources['ssh_key']['key'],
|
|
||||||
"\n",
|
|
||||||
];
|
|
||||||
|
|
||||||
fs.writeFileSync(file_name, ssh_conf_head.concat(_.map(hosts.collection, function (host) {
|
|
||||||
return _.template("Host <%= name %>\n\tPort <%= port %>\n")(host);
|
|
||||||
})).join('\n'));
|
|
||||||
console.log(clr.yellow('azure_wrapper/info:'), clr.green('Saved SSH config, you can use it like so: `ssh -F ', file_name, '<hostname>`'));
|
|
||||||
console.log(clr.yellow('azure_wrapper/info:'), clr.green('The hosts in this deployment are:\n'), _.map(hosts.collection, function (host) { return host.name; }));
|
|
||||||
};
|
|
||||||
|
|
||||||
var get_location = function () {
|
|
||||||
if (process.env['AZ_AFFINITY']) {
|
|
||||||
return '--affinity-group=' + process.env['AZ_AFFINITY'];
|
|
||||||
} else if (process.env['AZ_LOCATION']) {
|
|
||||||
return '--location=' + process.env['AZ_LOCATION'];
|
|
||||||
} else {
|
|
||||||
return '--location=West Europe';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
var get_vm_size = function () {
|
|
||||||
if (process.env['AZ_VM_SIZE']) {
|
|
||||||
return '--vm-size=' + process.env['AZ_VM_SIZE'];
|
|
||||||
} else {
|
|
||||||
return '--vm-size=Small';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var get_subscription= function () {
|
|
||||||
if (process.env['AZ_SUBSCRIPTION']) {
|
|
||||||
return '--subscription=' + process.env['AZ_SUBSCRIPTION'];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
exports.queue_default_network = function () {
|
|
||||||
task_queue.push([
|
|
||||||
'network', 'vnet', 'create',
|
|
||||||
get_location(),
|
|
||||||
'--address-space=172.16.0.0',
|
|
||||||
get_subscription(),
|
|
||||||
conf.resources['vnet'],
|
|
||||||
]);
|
|
||||||
}
|
|
||||||
|
|
||||||
exports.queue_storage_if_needed = function() {
|
|
||||||
if (!process.env['AZURE_STORAGE_ACCOUNT']) {
|
|
||||||
conf.resources['storage_account'] = util.rand_suffix;
|
|
||||||
task_queue.push([
|
|
||||||
'storage', 'account', 'create',
|
|
||||||
'--type=LRS',
|
|
||||||
get_location(),
|
|
||||||
get_subscription(),
|
|
||||||
conf.resources['storage_account'],
|
|
||||||
]);
|
|
||||||
process.env['AZURE_STORAGE_ACCOUNT'] = conf.resources['storage_account'];
|
|
||||||
} else {
|
|
||||||
// Preserve it for resizing, so we don't create a new one by accident,
|
|
||||||
// when the environment variable is unset
|
|
||||||
conf.resources['storage_account'] = process.env['AZURE_STORAGE_ACCOUNT'];
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
exports.queue_machines = function (name_prefix, coreos_update_channel, cloud_config_creator) {
|
|
||||||
var x = conf.nodes[name_prefix];
|
|
||||||
var vm_create_base_args = [
|
|
||||||
'vm', 'create',
|
|
||||||
get_location(),
|
|
||||||
get_vm_size(),
|
|
||||||
'--connect=' + conf.resources['service'],
|
|
||||||
'--virtual-network-name=' + conf.resources['vnet'],
|
|
||||||
'--no-ssh-password',
|
|
||||||
'--ssh-cert=' + conf.resources['ssh_key']['pem'],
|
|
||||||
get_subscription(),
|
|
||||||
];
|
|
||||||
|
|
||||||
var cloud_config = cloud_config_creator(x, conf);
|
|
||||||
|
|
||||||
var next_host = function (n) {
|
|
||||||
hosts.ssh_port_counter += 1;
|
|
||||||
var host = { name: util.hostname(n, name_prefix), port: hosts.ssh_port_counter };
|
|
||||||
if (cloud_config instanceof Array) {
|
|
||||||
host.cloud_config_file = cloud_config[n];
|
|
||||||
} else {
|
|
||||||
host.cloud_config_file = cloud_config;
|
|
||||||
}
|
|
||||||
hosts.collection.push(host);
|
|
||||||
return _.map([
|
|
||||||
"--vm-name=<%= name %>",
|
|
||||||
"--ssh=<%= port %>",
|
|
||||||
"--custom-data=<%= cloud_config_file %>",
|
|
||||||
], function (arg) { return _.template(arg)(host); });
|
|
||||||
};
|
|
||||||
|
|
||||||
task_queue = task_queue.concat(_(x).times(function (n) {
|
|
||||||
if (conf.resizing && n < conf.old_size) {
|
|
||||||
return [];
|
|
||||||
} else {
|
|
||||||
if (process.env['AZ_VM_COREOS_CHANNEL']) {
|
|
||||||
coreos_update_channel = process.env['AZ_VM_COREOS_CHANNEL']
|
|
||||||
}
|
|
||||||
return vm_create_base_args.concat(next_host(n), [
|
|
||||||
coreos_image_ids[coreos_update_channel], 'core',
|
|
||||||
]);
|
|
||||||
}
|
|
||||||
}));
|
|
||||||
};
|
|
||||||
|
|
||||||
exports.create_config = function (name, nodes) {
|
|
||||||
conf = {
|
|
||||||
name: name,
|
|
||||||
nodes: nodes,
|
|
||||||
weave_salt: util.rand_string(),
|
|
||||||
resources: {
|
|
||||||
vnet: [name, 'internal-vnet', util.rand_suffix].join('-'),
|
|
||||||
service: [name, util.rand_suffix].join('-'),
|
|
||||||
ssh_key: create_ssh_key(name),
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
exports.destroy_cluster = function (state_file) {
|
|
||||||
load_state(state_file);
|
|
||||||
if (conf.hosts === undefined) {
|
|
||||||
console.log(clr.red('azure_wrapper/fail: Nothing to delete.'));
|
|
||||||
process.abort();
|
|
||||||
}
|
|
||||||
|
|
||||||
conf.destroying = true;
|
|
||||||
task_queue = _.map(conf.hosts, function (host) {
|
|
||||||
return ['vm', 'delete', '--quiet', '--blob-delete', host.name, get_subscription()];
|
|
||||||
});
|
|
||||||
|
|
||||||
task_queue.push(['network', 'vnet', 'delete', '--quiet', conf.resources['vnet'], get_subscription()]);
|
|
||||||
task_queue.push(['storage', 'account', 'delete', '--quiet', conf.resources['storage_account'], get_subscription()]);
|
|
||||||
|
|
||||||
exports.run_task_queue();
|
|
||||||
};
|
|
||||||
|
|
||||||
exports.load_state_for_resizing = function (state_file, node_type, new_nodes) {
|
|
||||||
load_state(state_file);
|
|
||||||
if (conf.hosts === undefined) {
|
|
||||||
console.log(clr.red('azure_wrapper/fail: Nothing to look at.'));
|
|
||||||
process.abort();
|
|
||||||
}
|
|
||||||
conf.resizing = true;
|
|
||||||
conf.old_size = conf.nodes[node_type];
|
|
||||||
conf.old_state_file = state_file;
|
|
||||||
conf.nodes[node_type] += new_nodes;
|
|
||||||
hosts.collection = conf.hosts;
|
|
||||||
hosts.ssh_port_counter += conf.hosts.length;
|
|
||||||
process.env['AZURE_STORAGE_ACCOUNT'] = conf.resources['storage_account'];
|
|
||||||
}
|
|
@ -1,58 +0,0 @@
|
|||||||
var _ = require('underscore');
|
|
||||||
var fs = require('fs');
|
|
||||||
var yaml = require('js-yaml');
|
|
||||||
var colors = require('colors/safe');
|
|
||||||
|
|
||||||
var write_cloud_config_from_object = function (data, output_file) {
|
|
||||||
try {
|
|
||||||
fs.writeFileSync(output_file, [
|
|
||||||
'#cloud-config',
|
|
||||||
yaml.safeDump(data),
|
|
||||||
].join("\n"));
|
|
||||||
return output_file;
|
|
||||||
} catch (e) {
|
|
||||||
console.log(colors.red(e));
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
exports.generate_environment_file_entry_from_object = function (hostname, environ) {
|
|
||||||
var data = {
|
|
||||||
hostname: hostname,
|
|
||||||
environ_array: _.map(environ, function (value, key) {
|
|
||||||
return [key.toUpperCase(), JSON.stringify(value.toString())].join('=');
|
|
||||||
}),
|
|
||||||
};
|
|
||||||
|
|
||||||
return {
|
|
||||||
permissions: '0600',
|
|
||||||
owner: 'root',
|
|
||||||
content: _.template("<%= environ_array.join('\\n') %>\n")(data),
|
|
||||||
path: _.template("/etc/weave.<%= hostname %>.env")(data),
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
exports.process_template = function (input_file, output_file, processor) {
|
|
||||||
var data = {};
|
|
||||||
try {
|
|
||||||
data = yaml.safeLoad(fs.readFileSync(input_file, 'utf8'));
|
|
||||||
} catch (e) {
|
|
||||||
console.log(colors.red(e));
|
|
||||||
}
|
|
||||||
return write_cloud_config_from_object(processor(_.clone(data)), output_file);
|
|
||||||
};
|
|
||||||
|
|
||||||
exports.write_files_from = function (local_dir, remote_dir) {
|
|
||||||
try {
|
|
||||||
return _.map(fs.readdirSync(local_dir), function (fn) {
|
|
||||||
return {
|
|
||||||
path: [remote_dir, fn].join('/'),
|
|
||||||
owner: 'root',
|
|
||||||
permissions: '0640',
|
|
||||||
encoding: 'base64',
|
|
||||||
content: fs.readFileSync([local_dir, fn].join('/')).toString('base64'),
|
|
||||||
};
|
|
||||||
});
|
|
||||||
} catch (e) {
|
|
||||||
console.log(colors.red(e));
|
|
||||||
}
|
|
||||||
};
|
|
@ -1,77 +0,0 @@
|
|||||||
var _ = require('underscore');
|
|
||||||
_.mixin(require('underscore.string').exports());
|
|
||||||
|
|
||||||
var util = require('../util.js');
|
|
||||||
var cloud_config = require('../cloud_config.js');
|
|
||||||
|
|
||||||
|
|
||||||
etcd_initial_cluster_conf_self = function (conf) {
|
|
||||||
var port = '2380';
|
|
||||||
|
|
||||||
var data = {
|
|
||||||
nodes: _(conf.nodes.etcd).times(function (n) {
|
|
||||||
var host = util.hostname(n, 'etcd');
|
|
||||||
return [host, [host, port].join(':')].join('=http://');
|
|
||||||
}),
|
|
||||||
};
|
|
||||||
|
|
||||||
return {
|
|
||||||
'name': 'etcd2.service',
|
|
||||||
'drop-ins': [{
|
|
||||||
'name': '50-etcd-initial-cluster.conf',
|
|
||||||
'content': _.template("[Service]\nEnvironment=ETCD_INITIAL_CLUSTER=<%= nodes.join(',') %>\n")(data),
|
|
||||||
}],
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
etcd_initial_cluster_conf_kube = function (conf) {
|
|
||||||
var port = '4001';
|
|
||||||
|
|
||||||
var data = {
|
|
||||||
nodes: _(conf.nodes.etcd).times(function (n) {
|
|
||||||
var host = util.hostname(n, 'etcd');
|
|
||||||
return 'http://' + [host, port].join(':');
|
|
||||||
}),
|
|
||||||
};
|
|
||||||
|
|
||||||
return {
|
|
||||||
'name': 'kube-apiserver.service',
|
|
||||||
'drop-ins': [{
|
|
||||||
'name': '50-etcd-initial-cluster.conf',
|
|
||||||
'content': _.template("[Service]\nEnvironment=ETCD_SERVERS=--etcd-servers=<%= nodes.join(',') %>\n")(data),
|
|
||||||
}],
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
exports.create_etcd_cloud_config = function (node_count, conf) {
|
|
||||||
var input_file = './cloud_config_templates/kubernetes-cluster-etcd-node-template.yml';
|
|
||||||
var output_file = util.join_output_file_path('kubernetes-cluster-etcd-nodes', 'generated.yml');
|
|
||||||
|
|
||||||
return cloud_config.process_template(input_file, output_file, function(data) {
|
|
||||||
data.coreos.units.push(etcd_initial_cluster_conf_self(conf));
|
|
||||||
return data;
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
exports.create_node_cloud_config = function (node_count, conf) {
|
|
||||||
var elected_node = 0;
|
|
||||||
|
|
||||||
var input_file = './cloud_config_templates/kubernetes-cluster-main-nodes-template.yml';
|
|
||||||
var output_file = util.join_output_file_path('kubernetes-cluster-main-nodes', 'generated.yml');
|
|
||||||
|
|
||||||
var make_node_config = function (n) {
|
|
||||||
return cloud_config.generate_environment_file_entry_from_object(util.hostname(n, 'kube'), {
|
|
||||||
weave_password: conf.weave_salt,
|
|
||||||
weave_peers: n === elected_node ? "" : util.hostname(elected_node, 'kube'),
|
|
||||||
breakout_route: util.ipv4([10, 2, 0, 0], 16),
|
|
||||||
bridge_address_cidr: util.ipv4([10, 2, n, 1], 24),
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
var write_files_extra = cloud_config.write_files_from('addons', '/etc/kubernetes/addons');
|
|
||||||
return cloud_config.process_template(input_file, output_file, function(data) {
|
|
||||||
data.write_files = data.write_files.concat(_(node_count).times(make_node_config), write_files_extra);
|
|
||||||
data.coreos.units.push(etcd_initial_cluster_conf_kube(conf));
|
|
||||||
return data;
|
|
||||||
});
|
|
||||||
};
|
|
@ -1,33 +0,0 @@
|
|||||||
var _ = require('underscore');
|
|
||||||
_.mixin(require('underscore.string').exports());
|
|
||||||
|
|
||||||
exports.ipv4 = function (ocets, prefix) {
|
|
||||||
return {
|
|
||||||
ocets: ocets,
|
|
||||||
prefix: prefix,
|
|
||||||
toString: function () {
|
|
||||||
return [ocets.join('.'), prefix].join('/');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
exports.hostname = function hostname (n, prefix) {
|
|
||||||
return _.template("<%= pre %>-<%= seq %>")({
|
|
||||||
pre: prefix || 'core',
|
|
||||||
seq: _.pad(n, 2, '0'),
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
exports.rand_string = function () {
|
|
||||||
var crypto = require('crypto');
|
|
||||||
var shasum = crypto.createHash('sha256');
|
|
||||||
shasum.update(crypto.randomBytes(256));
|
|
||||||
return shasum.digest('hex');
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
exports.rand_suffix = exports.rand_string().substring(50);
|
|
||||||
|
|
||||||
exports.join_output_file_path = function(prefix, suffix) {
|
|
||||||
return './output/' + [prefix, exports.rand_suffix, suffix].join('_');
|
|
||||||
};
|
|
@ -1 +0,0 @@
|
|||||||
*
|
|
@ -1,19 +0,0 @@
|
|||||||
{
|
|
||||||
"name": "coreos-azure-weave",
|
|
||||||
"version": "1.0.0",
|
|
||||||
"description": "Small utility to bring up a woven CoreOS cluster",
|
|
||||||
"main": "index.js",
|
|
||||||
"scripts": {
|
|
||||||
"test": "echo \"Error: no test specified\" && exit 1"
|
|
||||||
},
|
|
||||||
"author": "Ilya Dmitrichenko <errordeveloper@gmail.com>",
|
|
||||||
"license": "Apache 2.0",
|
|
||||||
"dependencies": {
|
|
||||||
"azure-cli": "^0.9.9",
|
|
||||||
"colors": "^1.0.3",
|
|
||||||
"js-yaml": "^3.2.5",
|
|
||||||
"openssl-wrapper": "^0.2.1",
|
|
||||||
"underscore": "^1.7.0",
|
|
||||||
"underscore.string": "^3.0.2"
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,10 +0,0 @@
|
|||||||
#!/usr/bin/env node
|
|
||||||
|
|
||||||
var azure = require('./lib/azure_wrapper.js');
|
|
||||||
var kube = require('./lib/deployment_logic/kubernetes.js');
|
|
||||||
|
|
||||||
azure.load_state_for_resizing(process.argv[2], 'kube', parseInt(process.argv[3] || 1));
|
|
||||||
|
|
||||||
azure.run_task_queue([
|
|
||||||
azure.queue_machines('kube', 'stable', kube.create_node_cloud_config),
|
|
||||||
]);
|
|
Loading…
Reference in New Issue
Block a user