[英]Run a Kubernetes Cron Job from OpenShift to call a REST endpoint Periodically
我正在研究如何在 RedHat OpenShift 上将 Spring Batch 作业作为 Kubernetes 计划作业运行。 步骤已经完成,
1) 创建了一个示例 Spring Batch 应用程序,该应用程序读取一个 .csv 文件,该文件进行简单处理并将一些数据放入内存中的 h2 DB。 作业启动器作为 REST 端点 ( /load ) 被调用。 源代码可以在这里找到。 有关端点信息,请参阅 README 文件。
2) 创建 Docker Image 并推送到DockerHub
3) 使用该映像作为应用程序部署到我的 OpenShift Online 集群
我想做的是,
从 OpenShift 运行 Kubernetes Cron 作业以调用/load REST 端点,该端点定期启动 SpringBatch 作业
有人可以在这里指导我如何实现这一目标吗?
谢谢
萨姆
最简单的方法是卷曲您的/load
REST 端点。 这是一种方法:
我用来替代您的应用程序的 Pod 定义(用于测试目的):
apiVersion: v1
kind: Pod
metadata:
name: myapp-pod
labels:
app: myapp
spec:
containers:
- name: myapp-container
image: mendhak/http-https-echo
我使用这个图像是因为它将各种 HTTP 请求属性发送回客户端。
为 pod 创建一个服务:
apiVersion: v1
kind: Service
metadata:
name: myapp-service
spec:
selector:
app: myapp the selector
ports:
- protocol: TCP
port: 80 #Port that service is available on
targetPort: 80 #Port that app listens on
创建一个 CronJob:
apiVersion: batch/v1beta1
kind: CronJob
metadata:
name: curljob
spec:
jobTemplate:
metadata:
name: curljob
spec:
template:
metadata:
spec:
containers:
- command:
- curl
- http://myapp-service:80/load
image: curlimages/curl
imagePullPolicy: Always
name: curljobt
restartPolicy: OnFailure
schedule: '*/1 * * * *'
或者,您可以使用命令来启动它:
kubectl create cronjob --image curlimages/curl curljob -oyaml --schedule "*/1 * * * *" -- curl http://myapp-service:80/load
当"*/1 * * * *"
将指定此CronJob
运行的频率时。 我已经设置为每分钟运行一次。 您可以在此处和此处查看有关如何设置 cron 作业的更多信息
这是来自作业的 pod 之一的 kubectl 日志的结果:
{
"path": "/load",
"headers": {
"host": "myapp-service",
"user-agent": "curl/7.68.0-DEV",
"accept": "*/*"
},
"method": "GET",
"body": "",
"fresh": false,
"hostname": "myapp-service",
"ip": "::ffff:192.168.197.19",
"ips": [],
"protocol": "http",
"query": {},
"subdomains": [],
"xhr": false,
"os": {
"hostname": "myapp-pod"
正如您所看到的,应用程序通过路径接收GET
请求: /load
。
如果这有帮助,请告诉我。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.