diff --git a/srcpkgs/kubernetes/files/environ/apiserver b/srcpkgs/kubernetes/files/environ/apiserver new file mode 100644 index 00000000000..223b99203c7 --- /dev/null +++ b/srcpkgs/kubernetes/files/environ/apiserver @@ -0,0 +1,26 @@ +### +# kubernetes system config +# +# The following values are used to configure the kube-apiserver +# + +# The address on the local server to listen to. +KUBE_API_ADDRESS="--insecure-bind-address=127.0.0.1" + +# The port on the local server to listen on. +# KUBE_API_PORT="--port=8080" + +# Port minions listen on +# KUBELET_PORT="--kubelet-port=10250" + +# Comma separated list of nodes in the etcd cluster +KUBE_ETCD_SERVERS="--etcd-servers=http://127.0.0.1:4001" + +# Address range to use for services +KUBE_SERVICE_ADDRESSES="--service-cluster-ip-range=10.254.0.0/16" + +# default admission control policies +KUBE_ADMISSION_CONTROL="--admission-control=NamespaceLifecycle,NamespaceExists,LimitRanger,SecurityContextDeny,ServiceAccount,ResourceQuota" + +# Add your own! +KUBE_API_ARGS="" diff --git a/srcpkgs/kubernetes/files/environ/config b/srcpkgs/kubernetes/files/environ/config new file mode 100644 index 00000000000..8c0a28493fd --- /dev/null +++ b/srcpkgs/kubernetes/files/environ/config @@ -0,0 +1,22 @@ +### +# kubernetes system config +# +# The following values are used to configure various aspects of all +# kubernetes services, including +# +# kube-apiserver.service +# kube-controller-manager.service +# kube-scheduler.service +# kubelet.service +# kube-proxy.service +# logging to stderr means we get it in the systemd journal +KUBE_LOGTOSTDERR="--logtostderr=true" + +# journal message level, 0 is debug +KUBE_LOG_LEVEL="--v=0" + +# Should this cluster be allowed to run privileged docker containers +KUBE_ALLOW_PRIV="--allow-privileged=false" + +# How the controller-manager, scheduler, and proxy find the apiserver +KUBE_MASTER="--master=http://127.0.0.1:8080" diff --git a/srcpkgs/kubernetes/files/environ/controller-manager b/srcpkgs/kubernetes/files/environ/controller-manager new file mode 100644 index 00000000000..1a9e3f204c9 --- /dev/null +++ b/srcpkgs/kubernetes/files/environ/controller-manager @@ -0,0 +1,7 @@ +### +# The following values are used to configure the kubernetes controller-manager + +# defaults from config and apiserver should be adequate + +# Add your own! +KUBE_CONTROLLER_MANAGER_ARGS="" diff --git a/srcpkgs/kubernetes/files/environ/kubelet b/srcpkgs/kubernetes/files/environ/kubelet new file mode 100644 index 00000000000..db93a5eeb42 --- /dev/null +++ b/srcpkgs/kubernetes/files/environ/kubelet @@ -0,0 +1,17 @@ +### +# kubernetes kubelet (minion) config + +# The address for the info server to serve on (set to 0.0.0.0 or "" for all interfaces) +KUBELET_ADDRESS="--address=127.0.0.1" + +# The port for the info server to serve on +# KUBELET_PORT="--port=10250" + +# You may leave this blank to use the actual hostname +KUBELET_HOSTNAME="--hostname-override=127.0.0.1" + +# location of the api-server +KUBELET_API_SERVER="--api-servers=http://127.0.0.1:8080" + +# Add your own! +KUBELET_ARGS="" diff --git a/srcpkgs/kubernetes/files/environ/proxy b/srcpkgs/kubernetes/files/environ/proxy new file mode 100644 index 00000000000..034276831ba --- /dev/null +++ b/srcpkgs/kubernetes/files/environ/proxy @@ -0,0 +1,7 @@ +### +# kubernetes proxy config + +# default config should be adequate + +# Add your own! +KUBE_PROXY_ARGS="" diff --git a/srcpkgs/kubernetes/files/environ/scheduler b/srcpkgs/kubernetes/files/environ/scheduler new file mode 100644 index 00000000000..f6fc507b72c --- /dev/null +++ b/srcpkgs/kubernetes/files/environ/scheduler @@ -0,0 +1,7 @@ +### +# kubernetes scheduler config + +# default config should be adequate + +# Add your own! +KUBE_SCHEDULER_ARGS="" diff --git a/srcpkgs/kubernetes/files/kube-apiserver/run b/srcpkgs/kubernetes/files/kube-apiserver/run new file mode 100644 index 00000000000..159804b95a5 --- /dev/null +++ b/srcpkgs/kubernetes/files/kube-apiserver/run @@ -0,0 +1,14 @@ +#!/bin/sh +[ -r /etc/kubernetes/config ] && . /etc/kubernetes/config +[ -r /etc/kubernetes/apiserver ] && . /etc/kubernetes/apiserver +exec chpst -u kube:kube kube-apiserver \ + $KUBE_LOGTOSTDERR \ + $KUBE_LOG_LEVEL \ + $KUBE_ETCD_SERVERS \ + $KUBE_API_ADDRESS \ + $KUBE_API_PORT \ + $KUBELET_PORT \ + $KUBE_ALLOW_PRIV \ + $KUBE_SERVICE_ADDRESSES \ + $KUBE_ADMISSION_CONTROL \ + $KUBE_API_ARGS 2>/dev/null diff --git a/srcpkgs/kubernetes/files/kube-controller-manager/run b/srcpkgs/kubernetes/files/kube-controller-manager/run new file mode 100644 index 00000000000..5d298168109 --- /dev/null +++ b/srcpkgs/kubernetes/files/kube-controller-manager/run @@ -0,0 +1,8 @@ +#!/bin/sh +[ -r /etc/kubernetes/config ] && . /etc/kubernetes/config +[ -r /etc/kubernetes/controller-manager ] && . /etc/kubernetes/controller-manager +exec chpst -u kube:kube kube-controller-manager \ + $KUBE_LOGTOSTDERR \ + $KUBE_LOG_LEVEL \ + $KUBE_MASTER \ + $KUBE_CONTROLLER_MANAGER_ARGS 2>/dev/null diff --git a/srcpkgs/kubernetes/files/kube-proxy/run b/srcpkgs/kubernetes/files/kube-proxy/run new file mode 100644 index 00000000000..58f4865ccbe --- /dev/null +++ b/srcpkgs/kubernetes/files/kube-proxy/run @@ -0,0 +1,8 @@ +#!/bin/sh +[ -r /etc/kubernetes/config ] && . /etc/kubernetes/config +[ -r /etc/kubernetes/proxy ] && . /etc/kubernetes/proxy +exec kube-proxy \ + $KUBE_LOGTOSTDERR \ + $KUBE_LOG_LEVEL \ + $KUBE_MASTER \ + $KUBE_PROXY_ARGS 2>/dev/null diff --git a/srcpkgs/kubernetes/files/kube-scheduler/run b/srcpkgs/kubernetes/files/kube-scheduler/run new file mode 100644 index 00000000000..8e0a83a7613 --- /dev/null +++ b/srcpkgs/kubernetes/files/kube-scheduler/run @@ -0,0 +1,8 @@ +#!/bin/sh +[ -r /etc/kubernetes/config ] && . /etc/kubernetes/config +[ -r /etc/kubernetes/scheduler ] && . /etc/kubernetes/scheduler +exec chpst -u kube:kube kube-scheduler \ + $KUBE_LOGTOSTDERR \ + $KUBE_LOG_LEVEL \ + $KUBE_MASTER \ + $KUBE_SCHEDULER_ARGS 2>/dev/null diff --git a/srcpkgs/kubernetes/files/kubelet/run b/srcpkgs/kubernetes/files/kubelet/run new file mode 100644 index 00000000000..4b623e966e5 --- /dev/null +++ b/srcpkgs/kubernetes/files/kubelet/run @@ -0,0 +1,4 @@ +#!/bin/sh +[ -r /etc/kubernetes/config ] && . /etc/kubernetes/config +[ -r /etc/kubernetes/kubelet ] && . /etc/kubernetes/kubelet +exec kubelet $OPTS 2>/dev/null diff --git a/srcpkgs/kubernetes/template b/srcpkgs/kubernetes/template new file mode 100644 index 00000000000..10e8a3c8a5a --- /dev/null +++ b/srcpkgs/kubernetes/template @@ -0,0 +1,46 @@ +# Template file for 'kubernetes' +pkgname=kubernetes +version=1.1.8 +revision=1 +build_style=go +nocross=yes +only_for_archs="x86_64 x86_64-musl" +hostmakedepends="rsync git git-perl" +short_desc="Container Cluster Manager for Docker" +maintainer="Andrea Brancaleoni " +license="Apache-2.0" +go_import_path="github.com/kubernetes/kubernetes" +homepage="http://kubernetes.io" +distfiles="https://$go_import_path/archive/v$version.tar.gz" +checksum=fbc1a01edc6683dc3c59830a63622730c5baece1e02dfa1cd32a852bf4415581 +system_accounts="kube" +make_dirs="/var/lib/kubelet 0755 kube kube" +conf_files="/etc/kubernetes/*" + +do_build() { + ./hack/build-go.sh +} + +do_install() { + find "_output/local/bin/linux/" -type f -executable | grep "kube" | egrep -v "gen|test" | while read line + do + vbin "${line}" + done + + for MAN in docs/man/man1/*.1; do + vman ${MAN} + done + + vinstall contrib/completions/bash/kubectl 644 usr/share/bash-completion/completions + + vmkdir etc/kubernetes + vcopy ${FILESDIR}/environ/* etc/kubernetes + + vsv kube-apiserver + vsv kube-controller-manager + vsv kubelet + vsv kube-scheduler + vsv kube-proxy + + vlicense LICENSE +}