2017-03-16 18:31:57 +00:00
|
|
|
---
|
|
|
|
title: Parallel Processing using Expansions
|
2020-05-30 19:10:23 +00:00
|
|
|
content_type: task
|
2020-01-10 20:52:40 +00:00
|
|
|
min-kubernetes-server-version: v1.8
|
2018-05-18 19:51:50 +00:00
|
|
|
weight: 20
|
2017-03-16 18:31:57 +00:00
|
|
|
---
|
|
|
|
|
2020-05-30 19:10:23 +00:00
|
|
|
<!-- overview -->
|
2017-03-16 18:31:57 +00:00
|
|
|
|
2019-12-10 01:35:17 +00:00
|
|
|
This task demonstrates running multiple {{< glossary_tooltip text="Jobs" term_id="job" >}}
|
|
|
|
based on a common template. You can use this approach to process batches of work in
|
|
|
|
parallel.
|
2017-03-16 18:31:57 +00:00
|
|
|
|
2019-12-10 01:35:17 +00:00
|
|
|
For this example there are only three items: _apple_, _banana_, and _cherry_.
|
|
|
|
The sample Jobs process each item simply by printing a string then pausing.
|
|
|
|
|
|
|
|
See [using Jobs in real workloads](#using-jobs-in-real-workloads) to learn about how
|
|
|
|
this pattern fits more realistic use cases.
|
2018-06-22 18:20:04 +00:00
|
|
|
|
2020-05-30 19:10:23 +00:00
|
|
|
## {{% heading "prerequisites" %}}
|
|
|
|
|
2019-12-10 01:35:17 +00:00
|
|
|
You should be familiar with the basic,
|
2020-08-07 12:40:55 +00:00
|
|
|
non-parallel, use of [Job](/docs/concepts/workloads/controllers/job/).
|
2018-06-22 18:20:04 +00:00
|
|
|
|
2019-12-10 01:35:17 +00:00
|
|
|
{{< include "task-tutorial-prereqs.md" >}}
|
2017-03-16 18:31:57 +00:00
|
|
|
|
2019-12-10 01:35:17 +00:00
|
|
|
For basic templating you need the command-line utility `sed`.
|
2017-03-16 18:31:57 +00:00
|
|
|
|
2019-12-10 01:35:17 +00:00
|
|
|
To follow the advanced templating example, you need a working installation of
|
|
|
|
[Python](https://www.python.org/), and the Jinja2 template
|
|
|
|
library for Python.
|
|
|
|
|
|
|
|
Once you have Python set up, you can install Jinja2 by running:
|
2020-08-07 12:40:55 +00:00
|
|
|
|
2019-12-10 01:35:17 +00:00
|
|
|
```shell
|
|
|
|
pip install --user jinja2
|
|
|
|
```
|
2017-03-16 18:31:57 +00:00
|
|
|
|
2020-05-30 19:10:23 +00:00
|
|
|
<!-- steps -->
|
2017-03-16 18:31:57 +00:00
|
|
|
|
2019-12-10 01:35:17 +00:00
|
|
|
## Create Jobs based on a template
|
2017-03-16 18:31:57 +00:00
|
|
|
|
2019-12-10 01:35:17 +00:00
|
|
|
First, download the following template of a Job to a file called `job-tmpl.yaml`.
|
|
|
|
Here's what you'll download:
|
|
|
|
|
|
|
|
{{< codenew file="application/job/job-tmpl.yaml" >}}
|
2017-03-16 18:31:57 +00:00
|
|
|
|
|
|
|
```shell
|
2019-12-10 01:35:17 +00:00
|
|
|
# Use curl to download job-tmpl.yaml
|
2019-04-10 05:38:14 +00:00
|
|
|
curl -L -s -O https://k8s.io/examples/application/job/job-tmpl.yaml
|
2019-12-10 01:35:17 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
The file you downloaded is not yet a valid Kubernetes
|
|
|
|
{{< glossary_tooltip text="manifest" term_id="manifest" >}}.
|
|
|
|
Instead that template is a YAML representation of a Job object with some placeholders
|
|
|
|
that need to be filled in before it can be used. The `$ITEM` syntax is not meaningful to Kubernetes.
|
|
|
|
|
2019-04-10 05:38:14 +00:00
|
|
|
|
2019-12-10 01:35:17 +00:00
|
|
|
### Create manifests from the template
|
|
|
|
|
|
|
|
The following shell snippet uses `sed` to replace the string `$ITEM` with the loop
|
|
|
|
variable, writing into a temporary directory named `jobs`. Run this now:
|
|
|
|
|
|
|
|
```shell
|
|
|
|
# Expand the template into multiple files, one for each item to be processed.
|
2019-02-28 05:07:48 +00:00
|
|
|
mkdir ./jobs
|
|
|
|
for i in apple banana cherry
|
2017-03-16 18:31:57 +00:00
|
|
|
do
|
2018-07-02 20:54:18 +00:00
|
|
|
cat job-tmpl.yaml | sed "s/\$ITEM/$i/" > ./jobs/job-$i.yaml
|
2017-03-16 18:31:57 +00:00
|
|
|
done
|
|
|
|
```
|
|
|
|
|
|
|
|
Check if it worked:
|
|
|
|
|
|
|
|
```shell
|
2019-02-28 05:07:48 +00:00
|
|
|
ls jobs/
|
2019-04-10 05:38:14 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
The output is similar to this:
|
|
|
|
|
|
|
|
```
|
2017-03-16 18:31:57 +00:00
|
|
|
job-apple.yaml
|
|
|
|
job-banana.yaml
|
|
|
|
job-cherry.yaml
|
|
|
|
```
|
|
|
|
|
2019-12-10 01:35:17 +00:00
|
|
|
You could use any type of template language (for example: Jinja2; ERB), or
|
|
|
|
write a program to generate the Job manifests.
|
2017-03-16 18:31:57 +00:00
|
|
|
|
2019-12-10 01:35:17 +00:00
|
|
|
### Create Jobs from the manifests
|
|
|
|
|
|
|
|
Next, create all the Jobs with one kubectl command:
|
2017-03-16 18:31:57 +00:00
|
|
|
|
|
|
|
```shell
|
2019-02-28 05:07:48 +00:00
|
|
|
kubectl create -f ./jobs
|
2019-04-10 05:38:14 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
The output is similar to this:
|
|
|
|
|
|
|
|
```
|
|
|
|
job.batch/process-item-apple created
|
|
|
|
job.batch/process-item-banana created
|
|
|
|
job.batch/process-item-cherry created
|
2017-03-16 18:31:57 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
Now, check on the jobs:
|
|
|
|
|
|
|
|
```shell
|
2019-02-28 05:07:48 +00:00
|
|
|
kubectl get jobs -l jobgroup=jobexample
|
2019-04-10 05:38:14 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
The output is similar to this:
|
|
|
|
|
|
|
|
```
|
|
|
|
NAME COMPLETIONS DURATION AGE
|
2019-12-10 01:35:17 +00:00
|
|
|
process-item-apple 1/1 14s 22s
|
|
|
|
process-item-banana 1/1 12s 21s
|
2019-04-10 05:38:14 +00:00
|
|
|
process-item-cherry 1/1 12s 20s
|
2017-03-16 18:31:57 +00:00
|
|
|
```
|
|
|
|
|
2019-12-10 01:35:17 +00:00
|
|
|
Using the `-l` option to kubectl selects only the Jobs that are part
|
|
|
|
of this group of jobs (there might be other unrelated jobs in the system).
|
|
|
|
|
|
|
|
You can check on the Pods as well using the same
|
|
|
|
{{< glossary_tooltip text="label selector" term_id="selector" >}}:
|
2017-03-16 18:31:57 +00:00
|
|
|
|
|
|
|
|
|
|
|
```shell
|
2019-02-28 05:07:48 +00:00
|
|
|
kubectl get pods -l jobgroup=jobexample
|
2019-04-10 05:38:14 +00:00
|
|
|
```
|
|
|
|
|
2019-12-10 01:35:17 +00:00
|
|
|
The output is similar to:
|
2019-04-10 05:38:14 +00:00
|
|
|
|
|
|
|
```
|
2017-03-16 18:31:57 +00:00
|
|
|
NAME READY STATUS RESTARTS AGE
|
2017-07-28 15:23:11 +00:00
|
|
|
process-item-apple-kixwv 0/1 Completed 0 4m
|
|
|
|
process-item-banana-wrsf7 0/1 Completed 0 4m
|
|
|
|
process-item-cherry-dnfu9 0/1 Completed 0 4m
|
2017-03-16 18:31:57 +00:00
|
|
|
```
|
|
|
|
|
2020-01-15 12:35:32 +00:00
|
|
|
We can use this single command to check on the output of all jobs at once:
|
2017-03-16 18:31:57 +00:00
|
|
|
|
|
|
|
```shell
|
2020-01-15 12:35:32 +00:00
|
|
|
kubectl logs -f -l jobgroup=jobexample
|
2019-04-10 05:38:14 +00:00
|
|
|
```
|
|
|
|
|
2019-12-10 01:35:17 +00:00
|
|
|
The output should be:
|
2019-04-10 05:38:14 +00:00
|
|
|
|
|
|
|
```
|
2017-03-16 18:31:57 +00:00
|
|
|
Processing item apple
|
|
|
|
Processing item banana
|
|
|
|
Processing item cherry
|
|
|
|
```
|
|
|
|
|
2019-12-10 01:35:17 +00:00
|
|
|
### Clean up {#cleanup-1}
|
|
|
|
|
|
|
|
```shell
|
|
|
|
# Remove the Jobs you created
|
|
|
|
# Your cluster automatically cleans up their Pods
|
|
|
|
kubectl delete job -l jobgroup=jobexample
|
|
|
|
```
|
|
|
|
|
|
|
|
## Use advanced template parameters
|
|
|
|
|
|
|
|
In the [first example](#create-jobs-based-on-a-template), each instance of the template had one
|
|
|
|
parameter, and that parameter was also used in the Job's name. However,
|
|
|
|
[names](/docs/concepts/overview/working-with-objects/names/#names) are restricted
|
|
|
|
to contain only certain characters.
|
2017-03-16 18:31:57 +00:00
|
|
|
|
2019-12-10 01:35:17 +00:00
|
|
|
This slightly more complex example uses the
|
|
|
|
[Jinja template language](https://palletsprojects.com/p/jinja/) to generate manifests
|
|
|
|
and then objects from those manifests, with a multiple parameters for each Job.
|
2017-03-16 18:31:57 +00:00
|
|
|
|
2019-12-10 01:35:17 +00:00
|
|
|
For this part of the task, you are going to use a one-line Python script to
|
|
|
|
convert the template to a set of manifests.
|
2017-03-16 18:31:57 +00:00
|
|
|
|
|
|
|
First, copy and paste the following template of a Job object, into a file called `job.yaml.jinja2`:
|
|
|
|
|
|
|
|
|
2018-05-05 16:00:51 +00:00
|
|
|
```liquid
|
2019-12-10 01:35:17 +00:00
|
|
|
{%- set params = [{ "name": "apple", "url": "http://dbpedia.org/resource/Apple", },
|
|
|
|
{ "name": "banana", "url": "http://dbpedia.org/resource/Banana", },
|
|
|
|
{ "name": "cherry", "url": "http://dbpedia.org/resource/Cherry" }]
|
2017-07-28 15:23:11 +00:00
|
|
|
%}
|
2017-03-16 18:31:57 +00:00
|
|
|
{%- for p in params %}
|
|
|
|
{%- set name = p["name"] %}
|
|
|
|
{%- set url = p["url"] %}
|
2019-12-10 01:35:17 +00:00
|
|
|
---
|
2017-03-16 18:31:57 +00:00
|
|
|
apiVersion: batch/v1
|
|
|
|
kind: Job
|
|
|
|
metadata:
|
|
|
|
name: jobexample-{{ name }}
|
|
|
|
labels:
|
|
|
|
jobgroup: jobexample
|
|
|
|
spec:
|
|
|
|
template:
|
2017-08-25 20:06:27 +00:00
|
|
|
metadata:
|
2017-03-16 18:31:57 +00:00
|
|
|
name: jobexample
|
|
|
|
labels:
|
|
|
|
jobgroup: jobexample
|
|
|
|
spec:
|
|
|
|
containers:
|
|
|
|
- name: c
|
|
|
|
image: busybox
|
|
|
|
command: ["sh", "-c", "echo Processing URL {{ url }} && sleep 5"]
|
|
|
|
restartPolicy: Never
|
|
|
|
{%- endfor %}
|
|
|
|
```
|
|
|
|
|
2019-12-10 01:35:17 +00:00
|
|
|
The above template defines two parameters for each Job object using a list of
|
|
|
|
python dicts (lines 1-4). A `for` loop emits one Job manifest for each
|
|
|
|
set of parameters (remaining lines).
|
2017-03-16 18:31:57 +00:00
|
|
|
|
2019-12-10 01:35:17 +00:00
|
|
|
This example relies on a feature of YAML. One YAML file can contain multiple
|
|
|
|
documents (Kubernetes manifests, in this case), separated by `---` on a line
|
|
|
|
by itself.
|
|
|
|
You can pipe the output directly to `kubectl` to create the Jobs.
|
|
|
|
|
|
|
|
Next, use this one-line Python program to expand the template:
|
2017-03-16 18:31:57 +00:00
|
|
|
|
|
|
|
```shell
|
|
|
|
alias render_template='python -c "from jinja2 import Template; import sys; print(Template(sys.stdin.read()).render());"'
|
|
|
|
```
|
|
|
|
|
2019-12-10 01:35:17 +00:00
|
|
|
Use `render_template` to convert the parameters and template into a single
|
|
|
|
YAML file containing Kubernetes manifests:
|
2017-03-16 18:31:57 +00:00
|
|
|
|
|
|
|
```shell
|
2019-12-10 01:35:17 +00:00
|
|
|
# This requires the alias you defined earlier
|
2017-03-16 18:31:57 +00:00
|
|
|
cat job.yaml.jinja2 | render_template > jobs.yaml
|
|
|
|
```
|
|
|
|
|
2019-12-10 01:35:17 +00:00
|
|
|
You can view `jobs.yaml` to verify that the `render_template` script worked
|
|
|
|
correctly.
|
|
|
|
|
|
|
|
Once you are happy that `render_template` is working how you intend,
|
|
|
|
you can pipe its output into `kubectl`:
|
2017-03-16 18:31:57 +00:00
|
|
|
|
|
|
|
```shell
|
Official 1.14 Release Docs (#13174)
* Official documentation on Poseidon/Firmament, a new multi-scheduler support for K8S. (#11752)
* Added documentation about Poseidon-Firmament scheduler
* Fixed some style issues.
* Udpated the document as per the review comments.
* Fixed some typos and updated the document
* Updated the document as per the review comments.
* Document timeout attribute for kms-plugin. (#12158)
See 72540.
* Official documentation on Poseidon/Firmament, a new multi-scheduler (#12343)
* Removed the old version of the Poseidon documentation. Incorrect location.
* Official documentation on Poseidon/Firmament, a new multi-scheduler support for K8S (#12069)
* Official documentation on Poseidon/Firmament, a new multi-scheduler support for K8S. (#11752)
* Added documentation about Poseidon-Firmament scheduler
* Fixed some style issues.
* Udpated the document as per the review comments.
* Fixed some typos and updated the document
* Updated the document as per the review comments.
* Updated the document as per review comments. Added config details.
* Updated the document as per the latest review comments. Fixed nits
* Made changes as per latest suggestions.
* Some more changes added.
* Updated as per suggestions.
* Changed the release process section.
* SIG Docs edits
Small edits to match style guidelines.
* add plus to feature state
* capitalization
* revert feature state shortcode
since this is a Kubernetes extension, not a direct feature, it shouldn't use the regular feature state tagging.
(cherry picked from commit 7730c1540b637be74b9b21d4128a145994eb19cc)
* Remove initializers from doc. It will be removed in 1.14 (#12331)
* kubeadm: Document CRI auto detection functionality (#12462)
Signed-off-by: Rostislav M. Georgiev <rostislavg@vmware.com>
* Minor doc change for GAing Pod DNS Config (#12514)
* Graduate ExpandInUsePersistentVolumes feature to beta (#10574)
* Rename 2018-11-07-grpc-load-balancing-with-linkerd.md.md file (#12594)
* Add dynamic percentage of node scoring to user docs (#12235)
* Add dynamic percentage of node scoring to user docs
* addressed review comments
* delete special symbol (#12445)
* Update documentation for VolumeSubpathEnvExpansion (#11843)
* Update documentation for VolumeSubpathEnvExpansion
* Address comments - improve descriptions
* Graduate Pod Priority and Preemption to GA (#12428)
* Added Instana links to the documentation (#12977)
* Added link to the Instana Kubernetes integration
* Added Instana link for services section
Added Instana and a link to the Kubernetes integration to the analytics services section and broadened the scope to APM, monitoring and analytics.
* Oxford comma /flex
* More Oxford commas, because they matter
* Update kubectl plugins to stable (#12847)
* documentation for CSI topology beta (#12889)
* Document changes to default RBAC discovery ClusterRole(Binding)s (#12888)
* Document changes to default RBAC discovery ClusterRole(Binding)s
Documentation for https://github.com/kubernetes/enhancements/issues/789 and https://github.com/kubernetes/kubernetes/pull/73807
* documentation review feedback
* CSI raw block to beta (#12931)
* Change incorrect string raw to block (#12926)
Fixes #12925
* Update documentation on node OS/arch labels (#12976)
These labels have been promoted to GA:
https://github.com/kubernetes/enhancements/issues/793
* local pv GA doc updates (#12915)
* Publish CRD OpenAPI Documentation (#12910)
* add documentation for CustomResourcePublishOpenAPI
* address comments
fix links, ordered lists, style and typo
* kubeadm: add document for upgrading from 1.13 to 1.14 (single CP and HA) (#13189)
* kubeadm: add document for upgrading from 1.13 to 1.14
- remove doc for upgrading 1.10 -> 1.11
* kubeadm: apply amends to upgrade-1.14 doc
* kubeadm: apply amends to upgrade-1.14 doc (part2)
* kubeadm: apply amends to upgrade-1.14 doc (part3)
* kubeadm: add note about "upgrade node experimental-control-plane"
+ add comment about `upgrade plan`
* kubeadm: add missing "You should see output similar to this"
* fix bullet indentation (#13214)
* mark PodReadinessGate GA (#12800)
* Update RuntimeClass documentation for beta (#13043)
* Update RuntimeClass documentation for beta
* Update feature gate & add upgrade section
* formatting fixes
* Highlight upgrade action required
* Address feedback
* CSI ephemeral volume alpha documentation (#10934)
* update kubectl documentation (#12867)
* update kubectl documentation
* add document for Secret/ConfigMap generators
* replace `kubectl create -f` by `kubectl apply -f`
* Add page for kustomization support in kubectl
* fix spelling errors and address comments
* Documentation for Windows GMSA feature (#12936)
* Documentation for Windows GMSA feature
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Enhancements to GMSA docs
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Fix links
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Fix GMSA link
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Add GMSA feature flag in feature flag list
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Relocate GMSA to container configuration
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Add example for container spec
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Remove changes in Windows index
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Update configure-gmsa.md
* Update configure-gmsa.md
* Update configure-gmsa.md
* Update configure-gmsa.md
* Rearrange the steps into two sections and other edits
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Fix links
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Add reference to script to generate GMSA YAMLs
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Some more clarifications for GMSA
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* HugePages graduated to GA (#13004)
* HugePages graduated to GA
* fixing nit for build
* Docs for node PID limiting (https://github.com/kubernetes/kubernetes/pull/73651) (#12932)
* kubeadm: update the reference documentation for 1.14 (#12911)
* kubeadm: update list of generated files for 1.14
NOTE: PLACEHOLDERS! these files are generated by SIG Docs each
release, but we need them to pass the k/website PR CI.
- add join_phase* (new sub phases of join)
- add init_phase_upload-certs.md (new upload certs phase for init)
- remove alpha-preflight (now both init and join have this)
* kubeadm: update reference docs includes for 1.14
- remove includes from alpha.md
- add upload-certs to init-phase.md
- add join-phase.md and it's phases
* kubeadm: update the editorial content of join and init
- cleanup master->control-plane node
- add some notes about phases and join
- remove table about pre-pulling images
- remove outdated info about self-hosting
* kubeadm: update target release for v1alpha3 removal
1.14 -> 1.15
* kubeadm: copy edits for 1.14 reference docs (part1)
* kubeadm: use "shell" for code blocks
* kubeadm: update the 1.14 HA guide (#13191)
* kubeadm: update the 1.14 HA guide
* kubeadm: try to fix note/caution indent in HA page
* kubeadm: fix missing sudo and minor amends in HA doc
* kubeadm: apply latest amends to the HA doc for 1.14
* fixed a few missed merge conflicts
* Admission Webhook new features doc (#12938)
- kubernetes/kubernetes#74998
- kubernetes/kubernetes#74477
- kubernetes/kubernetes#74562
* Clarifications and fixes in GMSA doc (#13226)
* Clarifications and fixes in GMSA doc
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Update configure-gmsa.md
* Reformat to align headings and pre-reqs better
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Reformat to align headings and pre-reqs better
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Reformat to fix bullets
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Reword application of sample gmsa
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Update configure-gmsa.md
* Address feedback to use active voice
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Address feedback to use active voice
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* RunAsGroup documentation for Progressing this to Beta (#12297)
* start serverside-apply documentation (#13077)
* start serverside-apply documentation
* add more concept info on server side apply
* Update api concepts
* Update api-concepts.md
* fix style issues
* Document CSI update (#12928)
* Document CSI update
* Finish CSI documentation
Also fix mistake with ExpandInUsePersistentVolumes documented as beta
* Overall docs for CSI Migration feature (#12935)
* Placeholder docs for CSI Migration feature
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Address CR comments and update feature gates
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Add mappings for CSI plugins
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Add sections for AWS and GCE PD migration
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Add docs for Cinder and CSI Migration info
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Clarify scope to volumes with file system
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Change the format of EBS and Cinder CSI Migration sections to follow the GCE template
Signed-off-by: Deep Debroy <ddebroy@docker.com>
* Windows documentation updates for 1.14 (#12929)
* Updated the note to indicate doc work for 1.14
* first attempt at md export from gdoc
* simplifyig
* big attempt
* moving DRAFT windows content to PR for review
* moving content to PR in markdown for review
* updated note tags
* Delete windows-contributing.md
deleting this file as it is already ported to the github contributor guide
* fixed formatting in intro and cluster setup guide
* updating formatting for running containers guide
* rejiggered end of troubleshooting
* fixed minor typos
* Clarified the windows binary download step
* Update _index.md
making updates based on feedback
* Update _index.md
updating ovn-kubernetes docs
* Update _index.md
* Update _index.md
* updating relative docs links
updating all the links to be relative links to /docs
* Update _index.md
* Update _index.md
updates for windows services and ovn-kubernetes
* formatted for correct step numbering
* fix typos
* Update _index.md
updates for flannel PR in troubleshooting
* Update _index.md
* Update _index.md
updating a few sections like roadmap, services, troubleshooting/filing tickets
* Update _index.md
* Update _index.md
* Update _index.md
* Fixed a few whitespace issues
* Update _index.md
* Update _index.md
* Update _index.md
* add section on upgrading CoreDNS (#12909)
* documentation for kubelet resource metrics endpoint (#12934)
* windows docs updates for 1.14 (#13279)
* Delete sample-l2bridge-wincni-config.json
this file is not used anywhere
* Update _index.md
* Update _index.md
* Update _index.md
* Update _index.md
* Update _index.md
* Rename content/en/docs/getting-started-guides/windows/_index.md to content/en/docs/setup/windows/_index.md
moving to new location
* Delete flannel-master-kubectl-get-ds.png
* Delete flannel-master-kubeclt-get-pods.png
* Delete windows-docker-error.png
* Add files via upload
* Rename _index.md to add-windows-nodes.md
* Create _index.md
* Update _index.md
* Update add-windows-nodes.md
* Update add-windows-nodes.md
* Create user-guide-windows-nodes.md
* Create user-guide-windows-containers.md
* Update and rename add-windows-nodes.md to intro-windows-nodes.md
* Update user-guide-windows-containers.md
* Rename intro-windows-nodes.md to intro-windows-in-kubernetes.md
* Update user-guide-windows-nodes.md
* Update user-guide-windows-containers.md
* Update user-guide-windows-containers.md
* Update user-guide-windows-nodes.md
* Update user-guide-windows-containers.md
* Update _index.md
* Update intro-windows-in-kubernetes.md
* Update intro-windows-in-kubernetes.md
fixing the pause image
* Update intro-windows-in-kubernetes.md
changing tables from html to MD
* Update user-guide-windows-nodes.md
converting tables from HTML to MD
* Update intro-windows-in-kubernetes.md
* Update user-guide-windows-nodes.md
* Update user-guide-windows-nodes.md
* Update user-guide-windows-nodes.md
updating the numbering , even though it messes up the notes a little bit. Jim will file a ticket to follow up
* Update user-guide-windows-nodes.md
* update to windows docs for 1.14 (#13322)
* Update intro-windows-in-kubernetes.md
* Update intro-windows-in-kubernetes.md
* Update intro-windows-in-kubernetes.md
* Update intro-windows-in-kubernetes.md
* Update intro-windows-in-kubernetes.md
* Update user-guide-windows-containers.md
* Update user-guide-windows-nodes.md
* Update intro-windows-in-kubernetes.md (#13344)
* server side apply followup (#13321)
* change some parts of serverside apply docs in response to comments
* fix typos and wording
* Update config.toml (#13365)
2019-03-25 22:06:16 +00:00
|
|
|
cat job.yaml.jinja2 | render_template | kubectl apply -f -
|
2017-03-16 18:31:57 +00:00
|
|
|
```
|
|
|
|
|
2019-12-10 01:35:17 +00:00
|
|
|
Kubernetes accepts and runs the Jobs you created.
|
|
|
|
|
|
|
|
### Clean up {#cleanup-2}
|
|
|
|
|
|
|
|
```shell
|
|
|
|
# Remove the Jobs you created
|
|
|
|
# Your cluster automatically cleans up their Pods
|
|
|
|
kubectl delete job -l jobgroup=jobexample
|
|
|
|
```
|
|
|
|
|
2020-05-30 19:10:23 +00:00
|
|
|
|
|
|
|
<!-- discussion -->
|
2019-12-10 01:35:17 +00:00
|
|
|
|
|
|
|
## Using Jobs in real workloads
|
|
|
|
|
|
|
|
In a real use case, each Job performs some substantial computation, such as rendering a frame
|
|
|
|
of a movie, or processing a range of rows in a database. If you were rendering a movie
|
|
|
|
you would set `$ITEM` to the frame number. If you were processing rows from a database
|
|
|
|
table, you would set `$ITEM` to represent the range of database rows to process.
|
|
|
|
|
|
|
|
In the task, you ran a command to collect the output from Pods by fetching
|
|
|
|
their logs. In a real use case, each Pod for a Job writes its output to
|
|
|
|
durable storage before completing. You can use a PersistentVolume for each Job,
|
|
|
|
or an external storage service. For example, if you are rendering frames for a movie,
|
|
|
|
use HTTP to `PUT` the rendered frame data to a URL, using a different URL for each
|
|
|
|
frame.
|
|
|
|
|
|
|
|
## Labels on Jobs and Pods
|
|
|
|
|
|
|
|
After you create a Job, Kubernetes automatically adds additional
|
|
|
|
{{< glossary_tooltip text="labels" term_id="label" >}} that
|
|
|
|
distinguish one Job's pods from another Job's pods.
|
|
|
|
|
|
|
|
In this example, each Job and its Pod template have a label:
|
|
|
|
`jobgroup=jobexample`.
|
|
|
|
|
|
|
|
Kubernetes itself pays no attention to labels named `jobgroup`. Setting a label
|
|
|
|
for all the Jobs you create from a template makes it convenient to operate on all
|
|
|
|
those Jobs at once.
|
|
|
|
In the [first example](#create-jobs-based-on-a-template) you used a template to
|
|
|
|
create several Jobs. The template ensures that each Pod also gets the same label, so
|
|
|
|
you can check on all Pods for these templated Jobs with a single command.
|
|
|
|
|
|
|
|
{{< note >}}
|
|
|
|
The label key `jobgroup` is not special or reserved.
|
|
|
|
You can pick your own labelling scheme.
|
|
|
|
There are [recommended labels](/docs/concepts/overview/working-with-objects/common-labels/#labels)
|
|
|
|
that you can use if you wish.
|
|
|
|
{{< /note >}}
|
|
|
|
|
2017-03-16 18:31:57 +00:00
|
|
|
## Alternatives
|
|
|
|
|
2019-12-10 01:35:17 +00:00
|
|
|
If you plan to create a large number of Job objects, you may find that:
|
2017-03-16 18:31:57 +00:00
|
|
|
|
2019-12-10 01:35:17 +00:00
|
|
|
- Even using labels, managing so many Jobs is cumbersome.
|
|
|
|
- If you create many Jobs in a batch, you might place high load
|
|
|
|
on the Kubernetes control plane. Alternatively, the Kubernetes API
|
|
|
|
server could rate limit you, temporarily rejecting your requests with a 429 status.
|
|
|
|
- You are limited by a {{< glossary_tooltip text="resource quota" term_id="resource-quota" >}}
|
|
|
|
on Jobs: the API server permanently rejects some of your requests
|
|
|
|
when you create a great deal of work in one batch.
|
2017-03-16 18:31:57 +00:00
|
|
|
|
2020-08-07 12:40:55 +00:00
|
|
|
There are other [job patterns](/docs/concepts/workloads/controllers/job/#job-patterns)
|
2019-12-10 01:35:17 +00:00
|
|
|
that you can use to process large amounts of work without creating very many Job
|
|
|
|
objects.
|
2018-06-22 18:20:04 +00:00
|
|
|
|
2019-12-10 01:35:17 +00:00
|
|
|
You could also consider writing your own [controller](/docs/concepts/architecture/controller/)
|
|
|
|
to manage Job objects automatically.
|
2020-05-30 19:10:23 +00:00
|
|
|
|