Skip to content

Commit

Permalink
Merge pull request kubernetes#4902 from a-robinson/label
Browse files Browse the repository at this point in the history
Modernize the node selection example to use the `kubectl label` command
  • Loading branch information
thockin committed Feb 27, 2015
2 parents 900d58e + 4e9a2be commit 5fee09d
Showing 1 changed file with 5 additions and 62 deletions.
67 changes: 5 additions & 62 deletions examples/node-selection/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,72 +8,15 @@ This example assumes that you have a basic understanding of kubernetes pods and

### Step One: Attach label to the node

Run `kubectl get nodes` to get the names of the nodes. Pick out the one that you want to add a label to. Note that label keys must be in the form of DNS labels (as described in the [identifiers doc](/docs/design/identifiers.md)), meaning that they are not allowed to contain any upper-case letters. Then run `kubectl get node <node-name> -o yaml > node.yaml`. The contents of the file should look something like this:
Run `kubectl get nodes` to get the names of your cluster's nodes. Pick out the one that you want to add a label to.

<pre>
apiVersion: v1beta1
creationTimestamp: 2015-02-03T01:16:46Z
hostIP: 104.154.60.112
id: <node-name>
kind: Node
resourceVersion: 12
resources:
capacity:
cpu: "1"
memory: 4.0265318e+09
selfLink: /api/v1beta1/minions/<node-name>
status:
conditions:
- kind: Ready
lastTransitionTime: null
status: Full
uid: 526a4156-ab42-11e4-9817-42010af0258d
</pre>

Add the labels that you want to the file like this:

<pre>
apiVersion: v1beta1
creationTimestamp: 2015-02-03T01:16:46Z
hostIP: 104.154.60.112
id: <node-name>
kind: Node
<b>labels:
disktype: ssd</b>
resourceVersion: 12
resources:
capacity:
cpu: "1"
memory: 4.0265318e+09
selfLink: /api/v1beta1/minions/<node-name>
status:
conditions:
- kind: Ready
lastTransitionTime: null
status: Full
uid: 526a4156-ab42-11e4-9817-42010af0258d
</pre>
Then, to add a label to the node you've chosen, run `kubectl label nodes <node-name> <label-key>=<label-value>`. For example, if my node name is 'kubernetes-foo-node-1.c.a-robinson.internal' and my desired label is 'disktype=ssd', then I can run `kubectl label nodes kubernetes-foo-node-1.c.a-robinson.internal disktype=ssd`.

Then update the node by running `kubectl update -f node.yaml`. Make sure that the resourceVersion you use in your update call is the same as the resourceVersion returned by the get call. If something about the node changes between your get and your update, the update will fail because the resourceVersion will have changed.
If this fails with an "invalid command" error, you're likely using an older version of kubectl that doesn't have the `label` command. In that case, see the [previous version](https://github.com/GoogleCloudPlatform/kubernetes/blob/a053dbc313572ed60d89dae9821ecab8bfd676dc/examples/node-selection/README.md) of this guide for instructions on how to manually set labels on a node.

Note that as of 2015-02-03 there are a couple open issues that prevent this from working without modification. Due to [issue #3005](https://github.com/GoogleCloudPlatform/kubernetes/issues/3005), you have to remove all status-related fields from the file, which is both everything under the `status` field as well as the `hostIP` field (removing hostIP isn't required in v1beta3). Due to [issue 4041](https://github.com/GoogleCloudPlatform/kubernetes/issues/4041), you may have to modify the representation of the resource capacity numbers to make them integers. These are both temporary, and fixes are being worked on. In the meantime, you would actually call `kubectl update -f node.yaml` with a file that looks like this:

<pre>
apiVersion: v1beta1
creationTimestamp: 2015-02-03T01:16:46Z
id: <node-name>
kind: Node
<b>labels:
disktype: ssd</b>
resourceVersion: 12
resources:
capacity:
cpu: "1"
memory: 4026531800
selfLink: /api/v1beta1/minions/<node-name>
uid: 526a4156-ab42-11e4-9817-42010af0258d
</pre>
Also, note that label keys must be in the form of DNS labels (as described in the [identifiers doc](/docs/design/identifiers.md)), meaning that they are not allowed to contain any upper-case letters.

You can verify that it worked by re-running `kubectl get nodes` and checking that the node now has a label.

### Step Two: Add a nodeSelector field to your pod configuration

Expand Down

0 comments on commit 5fee09d

Please sign in to comment.