原創(chuàng)文章躲胳,歡迎轉(zhuǎn)載。轉(zhuǎn)載請(qǐng)注明:轉(zhuǎn)載自IT人故事會(huì),謝謝!
原文鏈接地址:『中級(jí)篇』k8s的NodePort類(lèi)型Service以及Label的簡(jiǎn)單實(shí)用(68)
上次主要說(shuō)了service的一種類(lèi)型快压,clusterIp,這次說(shuō)下NodePort垃瞧。源碼:https://github.com/limingios/docker/tree/master/No.10
通過(guò)pod創(chuàng)建service
- 進(jìn)入labs目錄下的service
cd deployk8s-master
cd labs
cd services
- 查看nginx-pod
apiVersion: v1
kind: Pod
metadata:
name: nginx-pod
labels:
app: nginx
spec:
containers:
- name: nginx-container
image: nginx
ports:
- name: nginx-port
containerPort: 8
kubectl create -f pod_nginx.yml
kubectl get pods
- 創(chuàng)建service類(lèi)型是nodePort
默認(rèn)的type clusterIP的形式
kubectl expose pods nginx-pod -h
expose pods nginx-pod --type=NodePort
kubectl describe node
明白了啥了沒(méi)?其實(shí)nodePort就是直接暴露出來(lái)一個(gè)端口坪郭,直接就可以訪問(wèn)了个从,爽是爽但是不安全。
通過(guò)pod 根據(jù)yml文件的形式創(chuàng)建service
- 刪除service
pod還在歪沃,service已經(jīng)成功刪除了嗦锐,app必須對(duì)應(yīng)。
kubectl delete service nginx-pod
kubectl get pods
kubectl get svc
get pods --show-labels
more service_nginx.yml
- 創(chuàng)建service
kubectl create -f service_nginx.yml
vim service_nginx.yml
- label的理解
Label機(jī)制是K8S中一個(gè)重要設(shè)計(jì)沪曙,通過(guò)Label進(jìn)行對(duì)象弱關(guān)聯(lián)奕污,靈活地分類(lèi)和選擇不同服務(wù)或業(yè)務(wù),讓用戶根據(jù)自己特定的組織結(jié)構(gòu)以松耦合方式進(jìn)行服務(wù)部署液走。
Label是一對(duì)KV碳默,對(duì)用戶而言非常有意義的,但對(duì)K8S本身而言沒(méi)有直接意義的缘眶。Label可以在創(chuàng)建對(duì)象時(shí)指定嘱根,也可以在后期修改,每個(gè)對(duì)象可以擁有多個(gè)標(biāo)簽巷懈,但key值必須是唯一的该抒。
Label可隨意定義,但建議可讀性顶燕,比如設(shè)置Pod的應(yīng)用名稱(chēng)和版本號(hào)等凑保。另外Lable是不具有唯一性的冈爹,為了更準(zhǔn)確標(biāo)識(shí)資源對(duì)象,應(yīng)為資源對(duì)象設(shè)置多維度的label欧引。
nodePort是所有的pod都可以使用犯助,如果使用nodePort的話,占用了很多端口维咸,是不是很占用資源呢剂买!label就把看成別名就可以了,方便操作指定的pod癌蓖。
往期精彩
- docker導(dǎo)學(xué)(一)
- 容器的技術(shù)概述(二)
- docker的魅力初體驗(yàn)-5分鐘安裝wordpress不走彎路(三)
- docker官網(wǎng)介紹(四)
- 如何在mac上安裝docker(五)
- 如何在window上安裝docker(六)
- 如何在mac上通過(guò)vagrant安裝虛擬機(jī)(七)
- 如何在window上通過(guò)vagrant安裝虛擬機(jī)(八)
- docker-Machine的本地使用(九)
- docker-Machine的本地使用(十)
- 在linux/mac下通過(guò)Docker-Machine在阿里云上的使用(11)
- docker架構(gòu)和底層技術(shù)(12)
- docker Image概述(13)
- 手動(dòng)建立一個(gè)base Image(14)
- 什么是Container(15)
- 構(gòu)建自己的Docker鏡像(16)
- Dockerfile詳解(17)
- 鏡像的發(fā)布(18)
- Dockerfile實(shí)戰(zhàn)(19)
- 容器的操作(20)
- Dockerfile實(shí)戰(zhàn)CMD和ENTRTYPOINT的配合(21)
- 容器的資源限制(22)
- docker網(wǎng)絡(luò)(23)
- docker學(xué)習(xí)必會(huì)網(wǎng)絡(luò)基礎(chǔ)(24)
- Linux網(wǎng)絡(luò)命名空間(25)
- Docker Bridge詳解(26)
- 容器之間的Link(27)
- 容器的端口映射(28)
- 容器網(wǎng)絡(luò)之host和none(29)
- 多容器復(fù)雜應(yīng)用的部署(30)
- overlay網(wǎng)絡(luò)和etcd實(shí)現(xiàn)多機(jī)的容器通信(31)
- docker的數(shù)據(jù)持久化存儲(chǔ)和數(shù)據(jù)共享(32)
- windows下vagrant 通過(guò)SecureCRT連接centos7(33)
- 數(shù)據(jù)持久化之Data Volume(34)
- 數(shù)據(jù)持久化之bind Mounting(35)
- docker 使用bind Mounting實(shí)戰(zhàn)(36)
- docker容器安裝wordpress(37)
- docker Compose到底是什么(38)
- Docker Compose的安裝和基本使用(39)
- Docker 水平擴(kuò)展和負(fù)載均衡(40)
- Docker compose 部署一個(gè)復(fù)雜的應(yīng)用(41)
- 容器編排Docker Swarm介紹(42)
- docker-swarm創(chuàng)建一個(gè)多節(jié)點(diǎn)集群(43)
- play with docker 的使用(44)
- docker-swarm中的Service創(chuàng)建維護(hù)和水平擴(kuò)展(45)
- 在docker-swarm集群里通過(guò)serivce部署wordpress(46)
- 集群服務(wù)間通信之RoutingMesh(47)
- RoutingMesh之Ingress負(fù)載均衡(48)
- Docker-Stack部署wordpress(49)
- Docker-Stack部署投票應(yīng)用(50)
- Docker-Secret管理和使用(51)
- Docker service更新(52)
- Docker的收費(fèi)模式(53)
- Docker-cloud介紹(54)
- Docker Cloud自動(dòng)構(gòu)建 Docker image(55)
- Docker企業(yè)版的在線免費(fèi)體驗(yàn)(56)
- docker企業(yè)版本地安裝之UCP(57)
- docker體驗(yàn)阿里云的容器服務(wù)(58)
- 阿里云安裝Docker企業(yè)版UCP和DTR(59)
- Kubenetes簡(jiǎn)介(60)
- Minikube快速搭建K8S單節(jié)點(diǎn)環(huán)境(61)
- K8S最小調(diào)度單位Pod(62)
- K8S橫向擴(kuò)展功能ReplicaSet和ReplicationController(63)
- k8s重要的Deployment(64)
- Vagrant在本地搭建多節(jié)點(diǎn)K8S集群(65)
- k8s基礎(chǔ)網(wǎng)絡(luò)Cluster Network(66)
- k8s的Service簡(jiǎn)介和演示(67)