Merge pull request #2494 from bgrant0607/config

Create tool for resizing a replication controller via kubectl.
pull/6/head
bgrant0607 2014-11-20 16:30:22 -08:00
commit 6b80abc78c
4 changed files with 94 additions and 2 deletions

17
contrib/rctools/README.md Normal file
View File

@ -0,0 +1,17 @@
# Replication controller tools
## resize.sh
Resizes a replication controller to the specified number of pods.
```
$ resize.sh
usage: resize.sh <replication controller name> <size>
$ resize.sh redisslave 4
```
## stop.sh
Resizes a replication controller to 0 pods and waits until the pods are deleted.
```
$ stop.sh
usage: stop.sh <replication controller name>
$ stop.sh redisslave
```

30
contrib/rctools/resize.sh Executable file
View File

@ -0,0 +1,30 @@
#!/bin/bash
# Copyright 2014 Google Inc. All rights reserved.
#
# 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.
# This command resizes a replication controller using kubectl.
KUBE_ROOT=$(dirname "${BASH_SOURCE}")/../..
KUBECTL="${KUBE_ROOT}/cluster/kubectl.sh"
if [[ $# != 2 ]] ; then
echo "usage: $0 <replication controller name> <size>" >&2
exit 1
fi
rc="$1"
size="$2"
"${KUBECTL}" get -o json rc "$rc" | sed 's/"replicas": [0-9][0-9]*/"replicas": '"$size"'/' | "${KUBECTL}" update -f - rc "$rc"

46
contrib/rctools/stop.sh Executable file
View File

@ -0,0 +1,46 @@
#!/bin/bash
# Copyright 2014 Google Inc. All rights reserved.
#
# 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.
# This command resizes a replication controller to 0.
KUBE_ROOT=$(dirname "${BASH_SOURCE}")/../..
KUBECTL="${KUBE_ROOT}/cluster/kubectl.sh"
RESIZE="${KUBE_ROOT}/contrib/rctools/resize.sh"
if [[ $# != 1 ]] ; then
echo "usage: $0 <replication controller name>" >&2
exit 1
fi
rc="$1"
"${RESIZE}" "$rc" 0
# kubectl describe output includes a line like:
# Replicas: 2 current / 2 desired
# Wait until it shows 0 pods
while true; do
pods=$(${KUBECTL} describe rc "$rc" | awk '/^Replicas:/{print $2}')
if [[ "$pods" -eq 0 ]] ; then
exit 0
else
echo "$pods remaining..."
fi
sleep 1
done
exit 1

View File

@ -402,8 +402,7 @@ func (p *TemplatePrinter) PrintObj(obj runtime.Object, w io.Writer) error {
func tabbedString(f func(io.Writer) error) (string, error) {
out := new(tabwriter.Writer)
b := make([]byte, 1024)
buf := bytes.NewBuffer(b)
buf := &bytes.Buffer{}
out.Init(buf, 0, 8, 1, '\t', 0)
err := f(out)