在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

如何創(chuàng)建Kubernetes jobs和cronjobs?

馬哥Linux運(yùn)維 ? 來源:PHP開源社區(qū) ? 作者:PHP開源社區(qū) ? 2021-06-15 14:04 ? 次閱讀

Kubernetes jobs主要是針對短時和批量的工作負(fù)載。它是為了結(jié)束而運(yùn)行的,而不是像deployment、replicasets、replication controllers和DaemonSets等其他對象那樣持續(xù)運(yùn)行。

本文將介紹如何創(chuàng)建Kubernetes jobs和cronjobs,以及一些小技巧。

Kubernetes Jobs會一直運(yùn)行到Job中指定的任務(wù)完成。也就是說,如果pods給出退出代碼0,那么Job就會退出。而在正常的Kubernetes中,無論退出代碼是什么,deployment對象在終止或出現(xiàn)錯誤時都會創(chuàng)建新的pod,以保持deployment的理想狀態(tài)。

在job運(yùn)行過程中,如果托管pod的節(jié)點(diǎn)發(fā)生故障,Job pod將被自動重新安排到另一個節(jié)點(diǎn)。

Kubernetes Jobs用例????

對于Kubernetes Jobs最好的用例實(shí)踐是:

1.批處理任務(wù):比如說你想每天運(yùn)行一次批處理任務(wù),或者在指定日程中運(yùn)行。它可能是像從存儲庫或數(shù)據(jù)庫中讀取文件那樣,將它們分配給一個服務(wù)來處理文件。

2.運(yùn)維/ad-hoc任務(wù):比如你想要運(yùn)行一個腳本/代碼,該腳本/代碼會運(yùn)行一個數(shù)據(jù)庫清理活動,甚至備份一個Kubernetes集群。

如何創(chuàng)建Kubernetes Job

在本例中,我們將使用Ubuntu 容器來運(yùn)行一個帶有for循環(huán)的shell腳本,并根據(jù)你傳遞給容器的參數(shù)來呼應(yīng)消息。這個參數(shù)是一個數(shù)字,決定shell腳本循環(huán)應(yīng)該運(yùn)行多少次。

例如,如果你傳遞了參數(shù)100,那么shell腳本將呼應(yīng)消息100次然后容器將會退出。

你可以訪問以下鏈接查看Dockerfile和shell腳本:

https://github.com/devopscube/Kubernetes-jobs-example/tree/master/Docker

我們先從一個簡單設(shè)置的job開始。

Step1:使用自定義的Docker鏡像創(chuàng)建一個job.yaml文件,命令參數(shù)為100。100將會作為參數(shù)傳遞給docker ENTRYPOINT腳本。

apiVersion:batch/v1

Step2 :使用kubectl創(chuàng)建一個job.yaml文件的job

kubectlapply-fjob.yam

Step3:使用kubectl檢查job的狀態(tài)

kubectlgetjobs

Step4:使用kubectl獲取pod列表

kubectlgetpo

Step5:使用kubectl獲取job pod 日志。使用你在輸出中看到的Pod名稱替換原本的Pod名稱。

kubectllogskubernetes-job-example-bc7s9-f

你應(yīng)該看到如下輸出:

并行運(yùn)行多Job pods

當(dāng)一個job被部署后,你可以讓它在多個Pod上并行運(yùn)行。例如,在一個job中如果你想要運(yùn)行6個 pods,同時并行運(yùn)行2個pods,你需要添加以下2個參數(shù)到你的job manifets中:

completions:6

以下是帶有那些參數(shù)的manifest:

apiVersion:batch/v1為Kubernetes Job生成隨機(jī)名稱

你不能從一個job manifest文件中創(chuàng)建多個job,因?yàn)镵ubernetes會報錯,說存在一個同名的job。為了規(guī)避這個問題,你可以在元數(shù)據(jù)中添加 generateName 名稱參數(shù)。

例如:

apiVersion:batch/v1

在上方示例中,每次你運(yùn)行該manifest,job將以kube-job-作為前綴,后面跟著一個隨機(jī)字符串來創(chuàng)建。

如何創(chuàng)建Kubernetes CronJob

如果你想按照特定的時間表運(yùn)行批處理job,例如,每2個小時運(yùn)行一次。你可以用cron表達(dá)式創(chuàng)建一個Kubernetes cronjob。Job會按照你在job中提到的時間表自動啟動。

下面我們將介紹如何指定一個cron計劃,你可以使用crontab生成器(https://crontab-generator.org/)來生成自己的時間計劃。

schedule:"0,15,30,45****"

下圖顯示了Kubernetes cronjob schedule語法。

pYYBAGDIRC-AYzB5AAB8dMpIrKo604.jpg

來源:kubernetes.io

如果我們以cronjob的形式每15分鐘運(yùn)行一次我們之前的job,manifest應(yīng)該如下所示。創(chuàng)建一個名為cron-job.yaml的文件,并復(fù)制以下manifest:

apiVersion:batch/v1beta1

讓我們使用kubectl部署cronjob。

kubectlcreate-fcron-job.yaml

列出cronjobs:

kubectlgetcronjobs

你可以列出cronjob pod并從處于運(yùn)行狀態(tài)或完成狀態(tài)的pods中獲取日志來檢查Cronjob日志。

手動運(yùn)行Kubernetes CronJob

在某些情況下,你可能希望以臨時的方式執(zhí)行cronjob。你可以通過從現(xiàn)有的cronjob創(chuàng)建一個job來實(shí)現(xiàn)。

例如,如果你想手動觸發(fā)一個cronjob,我們應(yīng)該這樣做:

kubectlcreatejob--from=cronjob/kubernetes-cron-jobmanual-cron-job

--from=cronjob/kubernetes-cron-job將復(fù)制cronjob模板并創(chuàng)建一個名為manual-cron-job的job。

Kubernetes Job的關(guān)鍵參數(shù)

根據(jù)你的需求,你還可以使用kubernetes jobs/cronjobs的幾個關(guān)鍵參數(shù):

1.failedJobHistoryLimit & successfulJobsHistoryLimit:根據(jù)你提供的保留數(shù)量刪除失敗和成功的job歷史記錄。當(dāng)你嘗試列出job時,這對于減少所有失敗的條目非常有用。例如:

2.backoffLimit:如果你的Pod失敗,重試的總次數(shù)。

3.activeDeadlineSeconds:如果你想對cronjob的運(yùn)行時間進(jìn)行硬性限制,可以使用此參數(shù)。例如,如果你想只運(yùn)行1分鐘的cronjob,你可以將其設(shè)置為60。

通過本文我們了解了創(chuàng)建Job以及Cron Job的步驟并且一些詳細(xì)的配置過程和關(guān)鍵參數(shù),希望藉由本文可以幫助你開始上手了解K8S Job和Cron Job,輕松搞定批處理任務(wù)!

圖片來源:kubernetes.io

文章來源:PHP開源社區(qū)

責(zé)任編輯:lq6

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • kubernetes
    +關(guān)注

    關(guān)注

    0

    文章

    225

    瀏覽量

    8723

原文標(biāo)題:帶你5分鐘快速了解 K8S Job

文章出處:【微信號:magedu-Linux,微信公眾號:馬哥Linux運(yùn)維】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    Kubernetes的CNI網(wǎng)絡(luò)插件之flannel

    Kubernetes設(shè)計了網(wǎng)絡(luò)模型,但卻將它的實(shí)現(xiàn)講給了網(wǎng)絡(luò)插件,CNI網(wǎng)絡(luò)插件最重要的功能就是實(shí)現(xiàn)Pod資源能夠跨主機(jī)通信。
    的頭像 發(fā)表于 01-02 09:43 ?115次閱讀

    艾體寶與Kubernetes原生數(shù)據(jù)平臺AppsCode達(dá)成合作

    虹科姐妹公司艾體寶宣布與Kubernetes 原生數(shù)據(jù)平臺 AppsCode達(dá)成正式合作,致力于將其核心產(chǎn)品KubeDB引入中國市場,為企業(yè)提供專業(yè)、高效的云原生數(shù)據(jù)庫管理解決方案。
    的頭像 發(fā)表于 12-16 15:07 ?249次閱讀

    Kubernetes集群搭建容器云需要幾臺服務(wù)器?

    Kubernetes集群搭建容器云需要幾臺服務(wù)器?至少需要4臺服務(wù)器。搭建容器云所需的服務(wù)器數(shù)量以及具體的搭建步驟,會根據(jù)所選用的技術(shù)棧、業(yè)務(wù)規(guī)模、架構(gòu)設(shè)計以及安全需求等因素而有所不同。以下是一個基于Kubernetes集群的容器云搭建的概述:
    的頭像 發(fā)表于 10-21 10:06 ?164次閱讀

    從TPS54260創(chuàng)建GSM電源

    電子發(fā)燒友網(wǎng)站提供《從TPS54260創(chuàng)建GSM電源.pdf》資料免費(fèi)下載
    發(fā)表于 10-11 10:48 ?0次下載
    從TPS54260<b class='flag-5'>創(chuàng)建</b>GSM電源

    基于DPU與SmartNIC的K8s Service解決方案

    1.? 方案背景 1.1. Kubernetes Service介紹 Kubernetes Service是Kubernetes中的一個核心概念,它定義了一種抽象,用于表示一組提供相同功能的Pods
    的頭像 發(fā)表于 09-02 17:01 ?944次閱讀
    基于DPU與SmartNIC的K8s Service解決方案

    使用Velero備份Kubernetes集群

    Velero 是 heptio 團(tuán)隊(被 VMWare 收購)開源的 Kubernetes 集群備份、遷移工具。
    的頭像 發(fā)表于 08-05 15:43 ?372次閱讀
    使用Velero備份<b class='flag-5'>Kubernetes</b>集群

    如何使用Kubeadm命令在PetaExpress Ubuntu系統(tǒng)上安裝Kubernetes集群

    Kubernetes,通常縮寫為K8s,是一個開源的容器編排平臺,旨在自動化容器化應(yīng)用的部署、擴(kuò)展和管理。有了Kubernetes,您可以輕松地部署、更新和擴(kuò)展應(yīng)用,而無需擔(dān)心底層基礎(chǔ)設(shè)施。
    的頭像 發(fā)表于 07-15 13:31 ?878次閱讀
    如何使用Kubeadm命令在PetaExpress Ubuntu系統(tǒng)上安裝<b class='flag-5'>Kubernetes</b>集群

     K8S學(xué)習(xí)教程一:使用PetaExpress云服務(wù)器安裝Minikube 集群

    使得開發(fā)人員能夠在本地機(jī)器上輕松創(chuàng)建一個單節(jié)點(diǎn)的 Kubernetes 集群,從而方便開發(fā)、測試和學(xué)習(xí) Kubernetes。 我們看下如何使用PetaExpress云服務(wù)器安裝Minikube 集群
    的頭像 發(fā)表于 07-01 15:41 ?383次閱讀
     K8S學(xué)習(xí)教程一:使用PetaExpress云服務(wù)器安裝Minikube 集群

    鴻蒙開發(fā):創(chuàng)建PageAbility

    通過DevEco Studio開發(fā)平臺創(chuàng)建PageAbility時,DevEco Studio會在app.js/app.ets中默認(rèn)生成onCreate()和onDestroy()方法,其他方法需要開發(fā)者自行實(shí)現(xiàn)。
    的頭像 發(fā)表于 06-18 09:36 ?263次閱讀
    鴻蒙開發(fā):<b class='flag-5'>創(chuàng)建</b>PageAbility

    Linux添加磁盤創(chuàng)建分區(qū)、掛載

    Linux添加磁盤創(chuàng)建分區(qū)、掛載
    發(fā)表于 04-20 17:49 ?528次閱讀
    Linux添加磁盤<b class='flag-5'>創(chuàng)建</b>分區(qū)、掛載

    HIGHTEC創(chuàng)建工程導(dǎo)入iLLD遇到的疑問求解

    ] Error 1make: *** Waiting for unfinished jobs....出現(xiàn)這個問題,主要是因?yàn)檫@個代碼:#ifndef
    發(fā)表于 02-05 08:00

    e2 studio創(chuàng)建lib文件及使用

    e2 studio創(chuàng)建lib文件及使用
    的頭像 發(fā)表于 01-18 08:06 ?497次閱讀
    e2 studio<b class='flag-5'>創(chuàng)建</b>lib文件及使用

    Kubernetes Gateway API攻略教程

    Kubernetes Gateway API 剛剛 GA,旨在改進(jìn)將集群服務(wù)暴露給外部的過程。這其中包括一套更標(biāo)準(zhǔn)、更強(qiáng)大的 API資源,用于管理已暴露的服務(wù)。在這篇文章中,我將介紹 Gateway
    的頭像 發(fā)表于 01-12 11:32 ?902次閱讀
    <b class='flag-5'>Kubernetes</b> Gateway API攻略教程

    vb運(yùn)行時錯誤429不能創(chuàng)建對象

    VB運(yùn)行時錯誤429代表不能創(chuàng)建對象的錯誤。這個錯誤可能會發(fā)生在使用CreateObject函數(shù)或New關(guān)鍵字創(chuàng)建對象時。 這種錯誤通常發(fā)生在以下情況下: 缺少所需的組件或庫:創(chuàng)建對象時,需要確保在
    的頭像 發(fā)表于 01-09 11:07 ?2377次閱讀

    如何創(chuàng)建重疊的封裝文件

    創(chuàng)建重疊的封裝文件是一種常用的軟件設(shè)計模式,它允許程序員使用多層次的連接和封裝來保護(hù)數(shù)據(jù)和功能。下面介紹如何創(chuàng)建重疊的封裝文件。 重疊的封裝是一種軟件設(shè)計模式,可用于創(chuàng)建安全、高效且易于維護(hù)的代碼
    的頭像 發(fā)表于 01-07 16:51 ?593次閱讀
    主站蜘蛛池模板: 国模论坛| 女人爽到喷水的视频大全在线观看| 免费看美女禁处爆涌视频| 毛片特黄| 四虎最新在线| 国产―笫一页―浮力影院xyz| 国产精品视频永久免费播放| 色国产精品| 欧美极品在线| 精品视频一区在线观看| 闲人综合| www亚洲一区| 精品一区二区三区免费爱| 欧美一级别| 色五月激情小说| 亚洲国产色图| 中文字幕人成不卡一区| 亚洲天堂bt| 18videosex欧美69| 欧美性黄色| 一区二区三区在线免费| 免费高清在线视频色yeye| jlzzjlzz亚洲日本| 国产呦精品系列在线| 91破处视频| 九九热精品在线视频| 双性强迫开宫灌满h| 中国一级生活片| 很黄很黄叫声床戏免费视频| 毛片2016免费视频| 五月激情六月婷婷| 特黄色一级毛片| 免费在线观看一级毛片| 免费国产成高清人在线视频| 国产高清一区二区| 奇米影视欧美| 精品福利| 日本欧美一区二区三区免费不卡 | 人人干97| 欧美三级大片在线观看| 国产三区视频|