job资源对象的使用方法
admin
2023-02-02 01:01:59
0

这篇文章给大家分享的是job资源对象的使用方法。小编觉得挺实用的,因此分享给大家学习。如下资料是关于job资源对象的内容。

Job资源对象
服务类的Pod容器:RC、RS、DS、Deployment.
工作类的Pod容器:Job--->执行一次,或者批量执行处理程序,完成之后推出容器。
[root@master ~]# cat job.yaml
kind: Job
apiVersion: batch/v1
metadata:
name: test-job
spec:
template:
metadata:
name: test-job
spec:
containers:

  • name: hello
    image: busybox
    command: ["echo","hello k8s job!"]
    restartPolicy: Never
    [root@master ~]# kubectl get pod
    NAME             READY   STATUS      RESTARTS   AGE
    test-job-qgc6p   0/1     Completed   0          55s
    [root@master ~]# kubectl logs test-job-qgc6p
    hello k8s job!
    PS:注意,如果容器内执行任务有误,会根据容器的重启策略操作容器,不过这里的容器重启策略只能是:Never、OnFailure
    提高Job的执行效率
    我们可以在Job.spec字段下加上parallelism选项。表示同时运行多少个Pod执行任务
    我们可以在Job.spec字段下加上completions选项。表示总共需要完成Pod的数量。
    [root@master ~]# cat job.yaml
    kind: Job
    apiVersion: batch/v1
    metadata:
    name: test-job
    spec:
    completions: 8     //总共需要完成多少个Pod
    parallelism: 2     //同时运行几个pod
    template:
    metadata:
    name: test-job
    spec:
    containers:
  • name: hello
    image: busybox
    command: ["echo","hello k8s job!"]
    restartPolicy: OnFailure
    如何定时执行Job
    kind: CronJob
    apiVersion: batch/v1beta1
    metadata:
    name: hello
    spec:
    schedule: "/1 *"
    jobTemplate:
    spec:
    template:
    spec:
    containers:
    • name: hello
      image: busybox
      command: ["echo","hello cronjob!"]
      restartPolicy: OnFailure
      [root@master ~]# kubectl apply -f cronjob.yaml
      [root@master ~]# kubectl get cronjobs.batch
      NAME    SCHEDULE      SUSPEND   ACTIVE   LAST SCHEDULE   AGE
      hello   /1 *   False     0        47s             51s
      [root@master ~]# kubectl logs hello-1579053480-vpm6t
      hello cronjob!
      此时查看Pod的状态,会发现,每分钟都会运行一个新的Pod来执行命令规定的任务。
      练习:
      规定2020年1月15号上午十点五分运行上面的crontab任务。
      [root@master ~]# cat cronjob.yaml
      kind: CronJob
      apiVersion: batch/v1beta1
      metadata:
      name: hello
      spec:
      schedule: "5 10 15 1 3"
      jobTemplate:
      spec:
      template:
      spec:
      containers:
    • name: hello
      image: busybox
      command: ["echo","hello cronjob!"]
      restartPolicy: OnFailure
      这时会发现,如果规定具体时间,可能并不会执行任务。
      [root@master ~]# kubectl api-versions    //查看api版本
      添加apiVersion库。
      [root@master ~]# vim /etc/kubernetes/manifests/kube-apiserver.yaml

//在yaml文件中添加

  • --runtime-config=batch/v2alpha1=true

然后重启kubelet服务,重新识别api yaml文件内容即可。
//查看api版本库
[root@master ~]# kubectl api-versions
PS:注意,此时任然不能正常运行指定时间的job,这时因为k8s官方在cronjob这个资源对象的支持中还没有完善此功能。还待开发。
跟job资源一样在cronjob.spec.jobTemplate.spec下同样支持并发Job参数:parallelism,也支持完成Pod的总数参数:completions。

关于job资源对象的使用方法就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

相关内容

热门资讯

终于懂了“乐山游戏中心有没有挂... 网上科普关于“乐山游戏中心有没有挂”话题很是火热,小编也是针对乐山游戏中心作*弊开挂的方法以及开挂对...
终于了解“同城乐吧有没有挂?”... 家人们!今天小编来为大家解答同城乐吧透视挂怎么安装这个问题咨询软件客服徽4282891的挂在哪里买很...
终于懂了“夜猫麻将怎么开挂?”... 终于懂了“夜猫麻将怎么开挂?”(原来真的有挂)您好,夜猫麻将这个游戏其实有挂的,确实是有挂的,需要了...
重磅消息“欢聚水鱼虎步龙行到底... 有 亲,根据资深记者爆料欢聚水鱼虎步龙行是可以开挂的,确实有挂(咨询软件...
玩家最新攻略“新蛮王牛牛开挂器... 玩家最新攻略“新蛮王牛牛开挂器?”(必胜开挂神器)您好,新蛮王牛牛这个游戏其实有挂的,确实是有挂的,...
重磅消息“发财麻将有没有挂?”... 有 亲,根据资深记者爆料发财麻将是可以开挂的,确实有挂(咨询软件无需打开...
玩家分享攻略“来趣广西麻将开挂... 玩家分享攻略“来趣广西麻将开挂神器?”(太坑了原来有挂)您好,来趣广西麻将这个游戏其实有挂的,确实是...
玩家分享攻略“相约福建麻将怎么... 网上科普关于“相约福建麻将有没有挂”话题很是火热,小编也是针对相约福建麻将作*弊开挂的方法以及开挂对...
终于懂了“约约麻将真的有挂吗?... 网上科普关于“约约麻将有没有挂”话题很是火热,小编也是针对约约麻将作*弊开挂的方法以及开挂对应的知识...
重磅消息“开心泉州麻将真的有挂... 网上科普关于“开心泉州麻将有没有挂”话题很是火热,小编也是针对开心泉州麻将作*弊开挂的方法以及开挂对...