(一) 核心概念
Kubernetes在新版中會新增了一個設置JOB執行計劃的功能,在1.3中已經可以初見端倪了,從進度上來看會在1.4版本中進行發佈,下面我們先睹爲快。
Kubernetes通過這個功能可以給JOB設置執行時間,這個功能類似一個開源項目quartz提供的功能。Quartz是一個完全由Java編寫的開源作業調度框架,爲在Java應用程序中進行作業調度提供了簡單卻強大的機制,Quartz允許開發人員根據時間間隔來調度作業。
下圖是這個新功能的核心概念模型:
(二) 數據結構介紹
1) 配置計劃任務的出發時間
結構體ScheduledJobSpec中變量Schedule是一個字符串變量,這個變量中存放了一個cron達式字符串,kubernetes1.3通過這個cron表達式配置計劃任務的觸發時間。
cron表達式由6或7個由空格分隔的時間字段組成:
位置 |
時間域名 |
允許值 |
允許的特殊字符 |
1 |
秒 |
0-59 |
, - * / |
2 |
分鐘 |
0-59 |
, - * / |
3 |
小時 |
0-23 |
, - * / |
4 |
日期 |
1-31 |
, - * ? / L W C |
5 |
月份 |
1-12 |
, - * / |
6 |
星期 |
1-7 |
, - * ? / L C # |
7 |
年(可選) |
空值1970-2099 |
, - * / |
cron表達式的時間字段除允許設置數值外,還可使用一些特殊的字符,提供列表、範圍、通配符等功能,細說如下:
• 星號(*):可用在所有字段中,表示對應時間域的每一個時刻,例如,*在分鐘字段時,表示“每分鐘”;
• 問號(?):該字符只在日期和星期字段中使用,它通常指定爲“無意義的值”,相當於點位符;
• 減號(-):表達一個範圍,如在小時字段中使用“10-12”,則表示從10到12點,即10,11,12;
• 逗號(,):表達一個列表值,如在星期字段中使用“MON,WED,FRI”,則表示星期一,星期三和星期五;
• 斜槓(/):x/y表達一個等步長序列,x爲起始值,y爲增量步長值。如在分鐘字段中使用0/15,則表示爲0,15,30和45秒,而5/15在分鐘字段中表示5,20,35,50,你也可以使用*/y,它等同於0/y;
• L:該字符只在日期和星期字段中使用,代表“Last”的意思,但它在兩個字段中意思不同。L在日期字段中,表示這個月份的最後一天,如一月的 31號,非閏年二月的28號;如果L用在星期中,則表示星期六,等同於7。但是,如果L出現在星期字段裏,而且在前面有一個數值X,則表示“這個月的最後 X天”,例如,6L表示該月的最後星期五;
• W:該字符只能出現在日期字段裏,是對前導日期的修飾,表示離該日期最近的工作日。例如15W表示離該月15號最近的工作日,如果該月15號是星 期六,則匹配14號星期五;如果15日是星期日,則匹配16號星期一;如果15號是星期二,那結果就是15號星期二。但必須注意關聯的匹配日期不能夠跨 月,如你指定1W,如果1號是星期六,結果匹配的是3號星期一,而非上個月最後的那天。W字符串只能指定單一日期,而不能指定日期範圍;
• LW組合:在日期字段可以組合使用LW,它的意思是當月的最後一個工作日;
• 井號(#):該字符只能在星期字段中使用,表示當月某個工作日。如6#3表示當月的第三個星期五(6表示星期五,#3表示當前的第三個),而4#5表示當月的第五個星期三,假設當月沒有第五個星期三,忽略不觸發;
• C:該字符只在日期和星期字段中使用,代表“Calendar”的意思。它的意思是計劃所關聯的日期,如果日期沒有被關聯,則相當於日曆中所有日期。例如5C在日期字段中就相當於日曆5日以後的第一天。1C在星期字段中相當於星期日後的第一天。
Cron表達式對特殊字符的大小寫不敏感,對代表星期的縮寫英文大小寫也不敏感。下面給出一些cron表達式的示例:
表示式 |
說明 |
“0 0 12 * * ? “ |
每天12點運行 |
“0 15 10 ? * *” |
每天10:15運行 |
“0 15 10 * * ?” |
每天10:15運行 |
“0 15 10 * * ? *” |
每天10:15運行 |
“0 15 10 * * ? 2008” |
在2008年的每天10:15運行 |
“0 * 14 * * ?” |
每天14點到15點之間每分鐘運行一次,開始於14:00,結束於14:59。 |
“0 0/5 14 * * ?” |
每天14點到15點每5分鐘運行一次,開始於14:00,結束於14:55。 |
“0 0/5 14,18 * * ?” |
每天14點到15點每5分鐘運行一次,此外每天18點到19點每5鍾也運行一次。 |
“0 0-5 14 * * ?” |
每天14:00點到14:05,每分鐘運行一次。 |
“0 10,44 14 ? 3 WED” |
3月每週三的14:10分到14:44,每分鐘運行一次。 |
“0 15 10 ? * MON-FRI” |
每週一,二,三,四,五的10:15分運行。 |
“0 15 10 15 * ?” |
每月15日10:15分運行。 |
“0 15 10 L * ?” |
每月最後一天10:15分運行。 |
“0 15 10 ? * 6L” |
每月最後一個星期五10:15分運行。 |
“0 15 10 ? * 6L 2007-2009” |
在2007,2008,2009年每個月的最後一個星期五的10:15分運行。 |
“0 15 10 ? * 6#3” |
每月第三個星期五的10:15分運行。 |
2) 配置計劃任務
結構體ScheduledJobSpec中變量Jobtemplate是一個JOB模板結構體變量,這個變量用來存放需要按照執行計劃執行的JOB,從下圖可以看到,通過這個變量,可以查找到需要執行的JOB,也就是ScheduledJobSpec結構體,通過ScheduledJobSpec結構體的Template可以查找到JOB對應的POD,也就是PodSpec結構體。所以說kubernetes是以POD爲中心的一個容器編排平臺,JOB最後的運行都是體現在POD的運行上。
3) 配置計劃任務併發處理策略
結構體ScheduledJobSpec中變量ConcurrencyPolicy是一個字符串變量,這個變量用來指定一個JOB在併發執行時的處理策略。
ConcurrencyPolicy的取值包括“Allow”、“Forbid”、“Replace”三種類型,含義如下:
1) Allow:允許一個JOB併發執行,當之前的JOB在沒有執行結束時,可以再次執行新的JOB。
2) Forbid:不允許一個JOB併發執行,當之前的JOB在沒有執行結束時,不能再次執行新的JOB。
3) Replace:不允許一個JOB併發執行,當之前的JOB在沒有執行結束時,可以在此執行新的JOB,但是之前沒有執行結束的JOB會被取消掉。
如果沒有設置ConcurrencyPolicy,那麼kubernetes1.3默認ConcurrencyPolicy是“Allow”。