本篇內(nèi)容主要講解“kubernetes/kubeadm工作流Runner怎么用”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“kubernetes/kubeadm工作流Runner怎么用”吧!
溫嶺網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)!從網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開(kāi)發(fā)、APP開(kāi)發(fā)、響應(yīng)式網(wǎng)站建設(shè)等網(wǎng)站項(xiàng)目制作,到程序開(kāi)發(fā),運(yùn)營(yíng)維護(hù)。創(chuàng)新互聯(lián)成立于2013年到現(xiàn)在10年的時(shí)間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來(lái)保證我們的工作的順利進(jìn)行。專(zhuān)注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)。
// phaseRunner provides a wrapper to a Phase with the addition of a set // of contextual information derived by the workflow managed by the Runner. // TODO: If we ever decide to get more sophisticated we can swap this type with a well defined dag or tree library. type phaseRunner struct { Phase parent *phaseRunner // 父phaseRunner level int // phase在工作流中的層級(jí) // selfPath contains all the elements of the path that identify the phase into // the workflow managed by the Runner. selfPath []string generatedName string // phase包含各級(jí)phase的全名 use string // 使用幫助信息,相當(dāng)于工作流中的相對(duì)路徑 }
type RunnerOptions struct { FilterPhases []string // 需要執(zhí)行的phase列表,如果列表為空,則全部執(zhí)行 SkipPhases []string // 需要屏蔽的phase,如果列表為空,則不屏蔽 }
// Runner implements management of composable kubeadm workflows. type Runner struct { Options RunnerOptions // Runner執(zhí)行選項(xiàng) Phases []Phase // Runner管理的工作流中所有的phase runDataInitializer func(*cobra.Command, []string) (RunData, error) // 構(gòu)造工作流中所有phase共享數(shù)據(jù)的回調(diào)函數(shù) runData RunData // 工作流中所有phase共享的數(shù)據(jù) runCmd *cobra.Command // 觸發(fā)Runner的命令 // cmdAdditionalFlags holds additional, shared flags that could be added to the subcommands generated // for phases. Flags could be inherited from the parent command too or added directly to each phase cmdAdditionalFlags *pflag.FlagSet phaseRunners []*phaseRunner // 工作流的上下文信息 }
工作流workflow
包對(duì)外提供一個(gè)創(chuàng)建空Runner的方法NewRunner()
,該空Runner實(shí)際上也是一個(gè)空的工作流,它不包括任何phase
,后續(xù)可以使用添加phase
的接口來(lái)增加phase
。
func NewRunner() *Runner { return &Runner{ Phases: []Phase{}, } }
當(dāng)工作流創(chuàng)建完成后,就可以使用func (e *Runner) AppendPhase(t Phase)
接口來(lái)添加phase
了。
func (e *Runner) AppendPhase(t Phase) { e.Phases = append(e.Phases, t) }
此時(shí)添加phase,只是簡(jiǎn)單的把phase追加到runner的切片列表中,phase的執(zhí)行順序與加入順序一致。
到此,相信大家對(duì)“kubernetes/kubeadm工作流Runner怎么用”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢(xún),關(guān)注我們,繼續(xù)學(xué)習(xí)!