2017-03-16 19:46:09 +00:00
|
|
|
---
|
|
|
|
title: Fine Parallel Processing Using a Work Queue
|
2018-06-22 18:20:04 +00:00
|
|
|
content_template: templates/task
|
2018-05-18 19:51:50 +00:00
|
|
|
weight: 40
|
2017-03-16 19:46:09 +00:00
|
|
|
---
|
|
|
|
|
2018-06-22 18:20:04 +00:00
|
|
|
{{% capture overview %}}
|
2017-03-16 19:46:09 +00:00
|
|
|
|
|
|
|
In this example, we will run a Kubernetes Job with multiple parallel
|
2018-06-22 18:20:04 +00:00
|
|
|
worker processes in a given pod.
|
2017-03-16 19:46:09 +00:00
|
|
|
|
|
|
|
In this example, as each pod is created, it picks up one unit of work
|
2017-10-11 00:31:51 +00:00
|
|
|
from a task queue, processes it, and repeats until the end of the queue is reached.
|
2017-03-16 19:46:09 +00:00
|
|
|
|
|
|
|
Here is an overview of the steps in this example:
|
|
|
|
|
|
|
|
1. **Start a storage service to hold the work queue.** In this example, we use Redis to store
|
|
|
|
our work items. In the previous example, we used RabbitMQ. In this example, we use Redis and
|
|
|
|
a custom work-queue client library because AMQP does not provide a good way for clients to
|
|
|
|
detect when a finite-length work queue is empty. In practice you would set up a store such
|
|
|
|
as Redis once and reuse it for the work queues of many jobs, and other things.
|
|
|
|
1. **Create a queue, and fill it with messages.** Each message represents one task to be done. In
|
|
|
|
this example, a message is just an integer that we will do a lengthy computation on.
|
|
|
|
1. **Start a Job that works on tasks from the queue**. The Job starts several pods. Each pod takes
|
|
|
|
one task from the message queue, processes it, and repeats until the end of the queue is reached.
|
|
|
|
|
2018-06-22 18:20:04 +00:00
|
|
|
{{% /capture %}}
|
|
|
|
|
|
|
|
|
|
|
|
{{% capture prerequisites %}}
|
|
|
|
|
|
|
|
{{< include "task-tutorial-prereqs.md" >}} {{< version-check >}}
|
|
|
|
|
|
|
|
{{% /capture %}}
|
|
|
|
|
|
|
|
{{% capture steps %}}
|
|
|
|
|
|
|
|
Be familiar with the basic,
|
|
|
|
non-parallel, use of [Job](/docs/concepts/jobs/run-to-completion-finite-workloads/).
|
|
|
|
|
|
|
|
{{% /capture %}}
|
|
|
|
|
|
|
|
{{% capture steps %}}
|
2017-03-16 19:46:09 +00:00
|
|
|
|
|
|
|
## Starting Redis
|
|
|
|
|
2017-08-08 04:05:33 +00:00
|
|
|
For this example, for simplicity, we will start a single instance of Redis.
|
2017-08-29 13:10:08 +00:00
|
|
|
See the [Redis Example](https://github.com/kubernetes/examples/tree/master/guestbook) for an example
|
2017-03-16 19:46:09 +00:00
|
|
|
of deploying Redis scalably and redundantly.
|
|
|
|
|
2019-02-28 05:14:58 +00:00
|
|
|
You could also download the following files directly:
|
2018-07-02 20:54:18 +00:00
|
|
|
|
|
|
|
- [`redis-pod.yaml`](/examples/application/job/redis/redis-pod.yaml)
|
|
|
|
- [`redis-service.yaml`](/examples/application/job/redis/redis-service.yaml)
|
|
|
|
- [`Dockerfile`](/examples/application/job/redis/Dockerfile)
|
|
|
|
- [`job.yaml`](/examples/application/job/redis/job.yaml)
|
|
|
|
- [`rediswq.py`](/examples/application/job/redis/rediswq.py)
|
|
|
|
- [`worker.py`](/examples/application/job/redis/worker.py)
|
|
|
|
|
2017-03-16 19:46:09 +00:00
|
|
|
|
|
|
|
## Filling the Queue with tasks
|
|
|
|
|
|
|
|
Now let's fill the queue with some "tasks". In our example, our tasks are just strings to be
|
|
|
|
printed.
|
|
|
|
|
2017-08-15 06:50:47 +00:00
|
|
|
Start a temporary interactive pod for running the Redis CLI.
|
2017-03-16 19:46:09 +00:00
|
|
|
|
|
|
|
```shell
|
2019-02-28 05:14:58 +00:00
|
|
|
kubectl run -i --tty temp --image redis --command "/bin/sh"
|
2017-03-16 19:46:09 +00:00
|
|
|
Waiting for pod default/redis2-c7h78 to be running, status is Pending, pod ready: false
|
|
|
|
Hit enter for command prompt
|
|
|
|
```
|
|
|
|
|
|
|
|
Now hit enter, start the redis CLI, and create a list with some work items in it.
|
|
|
|
|
|
|
|
```
|
|
|
|
# redis-cli -h redis
|
|
|
|
redis:6379> rpush job2 "apple"
|
|
|
|
(integer) 1
|
|
|
|
redis:6379> rpush job2 "banana"
|
|
|
|
(integer) 2
|
|
|
|
redis:6379> rpush job2 "cherry"
|
|
|
|
(integer) 3
|
|
|
|
redis:6379> rpush job2 "date"
|
|
|
|
(integer) 4
|
|
|
|
redis:6379> rpush job2 "fig"
|
|
|
|
(integer) 5
|
|
|
|
redis:6379> rpush job2 "grape"
|
|
|
|
(integer) 6
|
|
|
|
redis:6379> rpush job2 "lemon"
|
|
|
|
(integer) 7
|
|
|
|
redis:6379> rpush job2 "melon"
|
|
|
|
(integer) 8
|
|
|
|
redis:6379> rpush job2 "orange"
|
|
|
|
(integer) 9
|
|
|
|
redis:6379> lrange job2 0 -1
|
|
|
|
1) "apple"
|
|
|
|
2) "banana"
|
|
|
|
3) "cherry"
|
|
|
|
4) "date"
|
|
|
|
5) "fig"
|
|
|
|
6) "grape"
|
|
|
|
7) "lemon"
|
|
|
|
8) "melon"
|
|
|
|
9) "orange"
|
|
|
|
```
|
|
|
|
|
|
|
|
So, the list with key `job2` will be our work queue.
|
|
|
|
|
|
|
|
Note: if you do not have Kube DNS setup correctly, you may need to change
|
|
|
|
the first step of the above block to `redis-cli -h $REDIS_SERVICE_HOST`.
|
|
|
|
|
|
|
|
|
|
|
|
## Create an Image
|
|
|
|
|
|
|
|
Now we are ready to create an image that we will run.
|
|
|
|
|
|
|
|
We will use a python worker program with a redis client to read
|
|
|
|
the messages from the message queue.
|
|
|
|
|
|
|
|
A simple Redis work queue client library is provided,
|
2018-07-02 20:54:18 +00:00
|
|
|
called rediswq.py ([Download](/examples/application/job/redis/rediswq.py)).
|
2017-03-16 19:46:09 +00:00
|
|
|
|
|
|
|
The "worker" program in each Pod of the Job uses the work queue
|
|
|
|
client library to get work. Here it is:
|
|
|
|
|
2018-07-02 20:54:18 +00:00
|
|
|
{{< codenew language="python" file="application/job/redis/worker.py" >}}
|
2017-03-16 19:46:09 +00:00
|
|
|
|
2019-02-28 05:14:58 +00:00
|
|
|
You could also download [`worker.py`](/examples/application/job/redis/worker.py),
|
2018-07-02 20:54:18 +00:00
|
|
|
[`rediswq.py`](/examples/application/job/redis/rediswq.py), and
|
|
|
|
[`Dockerfile`](/examples/application/job/redis/Dockerfile) files, then build
|
|
|
|
the image:
|
2017-03-16 19:46:09 +00:00
|
|
|
|
|
|
|
```shell
|
|
|
|
docker build -t job-wq-2 .
|
|
|
|
```
|
|
|
|
|
|
|
|
### Push the image
|
|
|
|
|
|
|
|
For the [Docker Hub](https://hub.docker.com/), tag your app image with
|
|
|
|
your username and push to the Hub with the below commands. Replace
|
|
|
|
`<username>` with your Hub username.
|
|
|
|
|
|
|
|
```shell
|
|
|
|
docker tag job-wq-2 <username>/job-wq-2
|
|
|
|
docker push <username>/job-wq-2
|
|
|
|
```
|
|
|
|
|
|
|
|
You need to push to a public repository or [configure your cluster to be able to access
|
2017-03-20 22:35:51 +00:00
|
|
|
your private repository](/docs/concepts/containers/images/).
|
2017-03-16 19:46:09 +00:00
|
|
|
|
|
|
|
If you are using [Google Container
|
|
|
|
Registry](https://cloud.google.com/tools/container-registry/), tag
|
|
|
|
your app image with your project ID, and push to GCR. Replace
|
|
|
|
`<project>` with your project ID.
|
|
|
|
|
|
|
|
```shell
|
|
|
|
docker tag job-wq-2 gcr.io/<project>/job-wq-2
|
2017-07-14 18:44:43 +00:00
|
|
|
gcloud docker -- push gcr.io/<project>/job-wq-2
|
2017-03-16 19:46:09 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
## Defining a Job
|
|
|
|
|
|
|
|
Here is the job definition:
|
|
|
|
|
2018-07-02 20:54:18 +00:00
|
|
|
{{< codenew file="application/job/redis/job.yaml" >}}
|
2017-03-16 19:46:09 +00:00
|
|
|
|
|
|
|
Be sure to edit the job template to
|
|
|
|
change `gcr.io/myproject` to your own path.
|
|
|
|
|
|
|
|
In this example, each pod works on several items from the queue and then exits when there are no more items.
|
|
|
|
Since the workers themselves detect when the workqueue is empty, and the Job controller does not
|
|
|
|
know about the workqueue, it relies on the workers to signal when they are done working.
|
|
|
|
The workers signal that the queue is empty by exiting with success. So, as soon as any worker
|
|
|
|
exits with success, the controller knows the work is done, and the Pods will exit soon.
|
|
|
|
So, we set the completion count of the Job to 1. The job controller will wait for the other pods to complete
|
|
|
|
too.
|
|
|
|
|
|
|
|
|
|
|
|
## Running the Job
|
|
|
|
|
|
|
|
So, now run the Job:
|
|
|
|
|
|
|
|
```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
|
|
|
kubectl apply -f ./job.yaml
|
2017-03-16 19:46:09 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
Now wait a bit, then check on the job.
|
|
|
|
|
|
|
|
```shell
|
2019-02-28 05:14:58 +00:00
|
|
|
kubectl describe jobs/job-wq-2
|
2017-03-23 07:10:00 +00:00
|
|
|
Name: job-wq-2
|
|
|
|
Namespace: default
|
2017-09-09 00:48:15 +00:00
|
|
|
Selector: controller-uid=b1c7e4e3-92e1-11e7-b85e-fa163ee3c11f
|
|
|
|
Labels: controller-uid=b1c7e4e3-92e1-11e7-b85e-fa163ee3c11f
|
|
|
|
job-name=job-wq-2
|
|
|
|
Annotations: <none>
|
2017-03-23 07:10:00 +00:00
|
|
|
Parallelism: 2
|
2017-09-09 00:48:15 +00:00
|
|
|
Completions: <unset>
|
2017-03-23 07:10:00 +00:00
|
|
|
Start Time: Mon, 11 Jan 2016 17:07:59 -0800
|
|
|
|
Pods Statuses: 1 Running / 0 Succeeded / 0 Failed
|
2017-09-09 00:48:15 +00:00
|
|
|
Pod Template:
|
|
|
|
Labels: controller-uid=b1c7e4e3-92e1-11e7-b85e-fa163ee3c11f
|
|
|
|
job-name=job-wq-2
|
|
|
|
Containers:
|
|
|
|
c:
|
|
|
|
Image: gcr.io/exampleproject/job-wq-2
|
|
|
|
Port:
|
|
|
|
Environment: <none>
|
|
|
|
Mounts: <none>
|
|
|
|
Volumes: <none>
|
2017-03-16 19:46:09 +00:00
|
|
|
Events:
|
2017-03-23 07:10:00 +00:00
|
|
|
FirstSeen LastSeen Count From SubobjectPath Type Reason Message
|
|
|
|
--------- -------- ----- ---- ------------- -------- ------ -------
|
|
|
|
33s 33s 1 {job-controller } Normal SuccessfulCreate Created pod: job-wq-2-lglf8
|
2017-03-16 19:46:09 +00:00
|
|
|
|
|
|
|
|
2019-02-28 05:14:58 +00:00
|
|
|
kubectl logs pods/job-wq-2-7r7b2
|
2017-03-16 19:46:09 +00:00
|
|
|
Worker with sessionID: bbd72d0a-9e5c-4dd6-abf6-416cc267991f
|
|
|
|
Initial queue state: empty=False
|
|
|
|
Working on banana
|
|
|
|
Working on date
|
|
|
|
Working on lemon
|
|
|
|
```
|
|
|
|
|
|
|
|
As you can see, one of our pods worked on several work units.
|
|
|
|
|
2018-06-22 18:20:04 +00:00
|
|
|
{{% /capture %}}
|
|
|
|
|
|
|
|
{{% capture discussion %}}
|
|
|
|
|
2017-03-16 19:46:09 +00:00
|
|
|
## Alternatives
|
|
|
|
|
|
|
|
If running a queue service or modifying your containers to use a work queue is inconvenient, you may
|
|
|
|
want to consider one of the other [job patterns](/docs/concepts/jobs/run-to-completion-finite-workloads/#job-patterns).
|
|
|
|
|
|
|
|
If you have a continuous stream of background processing work to run, then
|
2019-02-04 23:25:03 +00:00
|
|
|
consider running your background workers with a `ReplicaSet` instead,
|
2017-03-16 19:46:09 +00:00
|
|
|
and consider running a background processing library such as
|
2017-08-22 23:49:55 +00:00
|
|
|
[https://github.com/resque/resque](https://github.com/resque/resque).
|
2018-06-22 18:20:04 +00:00
|
|
|
|
|
|
|
{{% /capture %}}
|