Kubernetes系統(tǒng)精講 Go語言實(shí)戰(zhàn)K8S集群可視化(附word文檔)
Kubernetes系統(tǒng)精講 Go語言實(shí)戰(zhàn)K8S集群可視化(附word文檔)
學(xué)習(xí)地址1:https://pan.baidu.com/s/1LEcLrcqlyP3v6xsyM6T1DQ 提取碼:7345?
學(xué)習(xí)地址2:https://pan.baidu.com/s/1bUEn3WJqWaCoVPO5psB74Q 提取碼:zfxr?
Kubernetes系統(tǒng)精講 Go語言實(shí)戰(zhàn)K8S集群可視化(附word文檔,也就是電子教程,獨(dú)家提供,其他地方都沒有的word文檔)
《Kubernetes系統(tǒng)精講 Go語言實(shí)戰(zhàn)K8S集群可視化》課程目前更新到第21章,即將完結(jié),大家關(guān)注學(xué)習(xí)地址,有更新會同步進(jìn)去??!
K8S 適用場景
學(xué)習(xí)一門技術(shù)我們需要了解學(xué)了該技術(shù)到底能干啥,因此了解K8S適用場景對我們學(xué)習(xí)課程非常重要。
微服務(wù)運(yùn)維
微服務(wù)極大的方便了業(yè)務(wù)的解耦,但是部署起來就相對比較麻煩了,一般微服務(wù)為了保證服務(wù)的可用性,都不會只用一臺主機(jī),而是主機(jī)集群。但是借助于k8s的集群容器編排能力,輕松完成微服務(wù)的部署,做到服務(wù)的拓展的高可用部署。
CI/CD
CI/CD就是咱們常說的持續(xù)集成與持續(xù)發(fā)布,傳統(tǒng)的持續(xù)集成,例如小伙伴們非常熟悉的Jenkins,可以做到流水線的配置,遠(yuǎn)程到目標(biāo)主機(jī)操作。
如果在K8S的加持下,我們遠(yuǎn)程到的目標(biāo)主機(jī)是Master節(jié)點(diǎn),或者是配置了ApiServer訪問,借助于K8S的統(tǒng)一編排,那么我們便可以做到集群場景的持續(xù)集成與發(fā)布。
虛擬機(jī)與Docker
了解了全虛擬化與半虛擬化的區(qū)別,現(xiàn)在我們來看看虛擬機(jī)和Docker的區(qū)別。

如圖所示我們可以看到,Docker就是一種半虛擬機(jī)技術(shù),Docker上運(yùn)行的容器,其實(shí)就是資源隔離的進(jìn)程,而這些資源隔離的進(jìn)程,就是我們常說的容器。
另外我們再來虛擬機(jī),在物理操作系統(tǒng)的基礎(chǔ)上,則是在物理操作系統(tǒng)上抽象出來一整套的操作系統(tǒng)。
Pod詳情查看
Pod詳情查看,這里的作用是將K8S查詢的數(shù)據(jù),轉(zhuǎn)為提交Pod創(chuàng)建的數(shù)據(jù)結(jié)構(gòu),用于查看并且更新。
func (this *K8s2ReqConvert) PodK8s2Req(podK8s corev1.Pod) pod_req.Pod {
return pod_req.Pod{
Base:? ? ? ? ? ?getReqBase(podK8s),
NetWorking:? ? ?getReqNetworking(podK8s),
Volumes:? ? ? ? this.getReqVolumes(podK8s.Spec.Volumes),
Containers:? ? ?this.getReqContainers(podK8s.Spec.Containers),
InitContainers: this.getReqContainers(podK8s.Spec.InitContainers),
}
}
func getReqContainerProbe(probeK8s *corev1.Probe) pod_req.ContainerProbe {
containerProbe := pod_req.ContainerProbe{
Enable: false,
}
//先判斷是否探針為空
if probeK8s != nil {
containerProbe.Enable = true
//再判斷 探針具體是什么類型
if probeK8s.Exec != nil {
containerProbe.Type = probe_exec
containerProbe.Exec.Command = probeK8s.Exec.Command
} else if probeK8s.HTTPGet != nil {
containerProbe.Type = probe_http
httpGet := probeK8s.HTTPGet
headersReq := make([]pod_req.ListMapItem, 0)
for _, headerK8s := range httpGet.HTTPHeaders {
headersReq = append(headersReq, pod_req.ListMapItem{
Key:? ?headerK8s.Name,
Value: headerK8s.Value,
})
}
containerProbe.HttpGet = pod_req.ProbeHttpGet{
Host:? ? ? ? httpGet.Host,
Port:? ? ? ? httpGet.Port.IntVal,
Scheme:? ? ? string(httpGet.Scheme),
Path:? ? ? ? httpGet.Path,
HttpHeaders: headersReq,
}
} else if probeK8s.TCPSocket != nil {
containerProbe.Type = probe_tcp
containerProbe.TcpSocket = pod_req.ProbeTcpSocket{
Host: probeK8s.TCPSocket.Host,
Port: probeK8s.TCPSocket.Port.IntVal,
}
} else {
containerProbe.Type = probe_http
return containerProbe
}
containerProbe.InitialDelaySeconds = probeK8s.InitialDelaySeconds
containerProbe.PeriodSeconds = probeK8s.PeriodSeconds
containerProbe.TimeoutSeconds = probeK8s.TimeoutSeconds
containerProbe.SuccessThreshold = probeK8s.SuccessThreshold
containerProbe.FailureThreshold = probeK8s.FailureThreshold
}
return containerProbe
}