网站首页 > 技术文章 正文
将一组pod公开为网络服务,通过service代理,可以实现负载均衡
一、ClusterIP
此方式只能在集群内访问
1.使用命令暴露已存在的pod
(1)继续使用前面章节的案例,查看名称为nginx的deploy下的pod
kubectl get pod -n dev -owide
进入每个pod容器,更改index.html内容
kubectl exec nginx-6799fc88d8-2rf2c -it /bin/bash -n dev
cd /usr/share/nginx/html/
rm -rf index.html
touche index.html
echo 1111 >> index.html
kubectl exec nginx-6799fc88d8-rnhmd -it /bin/bash -n dev
cd /usr/share/nginx/html/
rm -rf index.html
touche index.html
echo 2222 >> index.htm
(2)使用curl命令访问pod的ip,查看更改后的结果
(3)通过ClusterIP的方式暴露pod,默认就是ClusterIP
kubectl expose deploy nginx --name=svc-nginx --port=8000 --target-port=80 --type=ClusterIP -n dev
(4)查看暴露后的service
kubectl get svc -n dev
可以看到分配了一个ClusterIP
(5)访问ClusterIp,查看结果
service把请求负载均衡的分发给后面代理的pod进行处理,可以看到输出结果不一样
(6) 在容器内部通过域名的方式访问:服务名.命名空间.svc:port
进入某个pod容器
kubectl exec nginx-6799fc88d8-2rf2c -n dev -it /bin/bash
在容器内部执行curl命令访问服务的域名
2.删除服务
kubectl delete svc svc-nginx -n dev
3.通过yaml创建服务
编写svc-nginx.yaml文件
apiVersion: v1
kind: Service
metadata:
labels:
app: svc-nginx
name: svc-nginx
namespace: dev
spec:
selector:
#选择指定标签的Deployment
app: nginx
type: ClusterIP
ports:
- port: 8000
protocol: TCP
targetPort: 80
创建nginx服务
kubectl apply -f svc-nginx.yaml
二、NodePort
此方式不仅能在集群内访问,也可以在集群外部访问,NodePort范围在 30000-32767 之间
1.使用命令暴露已存在的pod
(1)继续使用前面章节的案例,查看名称为nginx的deploy下的pod
kubectl get pod -n dev -owide
进入每个pod容器,更改index.html内容
kubectl exec nginx-6799fc88d8-2rf2c -it /bin/bash -n dev
cd /usr/share/nginx/html/
rm -rf index.html
touche index.html
echo 1111 >> index.html
kubectl exec nginx-6799fc88d8-rnhmd -it /bin/bash -n dev
cd /usr/share/nginx/html/
rm -rf index.html
touche index.html
echo 2222 >> index.htm
(2)使用curl访问pod的ip查看更改后的结果
(3)通过NodePort的方式暴露pod,不指定--name参数,service的名称默认为deploy的名称
kubectl expose deploy nginx --port=8000 --target-port=80 --type=NodePort -n dev
(4)查看暴露后的service
kubectl get svc -n dev
(5)在集群内访问ClusterIp,查看结果
service把请求负载均衡的分发给后面代理的pod进行处理
(6)在集群外访问
2.删除服务
kubectl delete svc nginx -n dev
3.通过yaml创建服务
apiVersion: v1
kind: Service
metadata:
labels:
app: svc-nginx
name: svc-nginx
namespace: dev
spec:
selector:
#选择指定标签的Deployment
app: nginx
#注意指定type为NodePort
type: NodePort
ports:
- port: 8000
protocol: TCP
targetPort: 80
#指定暴露的端口号,不设置就默认随机一个
#nodePort: 31234
创建成功之后,可以使用上面介绍的方法来查看测试服务
猜你喜欢
- 2024-10-12 Kong 优雅实现微服务网关鉴权,登录场景落地实战篇
- 2024-10-12 k8s安装与使用入门(k8s安装步骤)
- 2024-10-12 应用无损上下线(应用无损上下线怎么关闭)
- 2024-10-12 另一个Kubernetes(k8s)指南(kubernetesk8s怎么使用)
- 2024-10-12 Kubernetes 安全专家(CKS)必过心得
- 2024-10-12 深入理解K8S网络原理上(k8s网络解决方案)
- 2024-10-12 一次客户需求引发的K8S网络探究(基于客户需求)
- 2024-10-12 今天讲讲k8s的pod控制器及无状态和有状态
- 2024-10-12 k8s如何滚动升级应用(k8s升级组件方法)
- 2024-10-12 k8s基础知识之service类型(k8s的service类型)
- 02-21走进git时代, 你该怎么玩?_gits
- 02-21GitHub是什么?它可不仅仅是云中的Git版本控制器
- 02-21Git常用操作总结_git基本用法
- 02-21为什么互联网巨头使用Git而放弃SVN?(含核心命令与原理)
- 02-21Git 高级用法,喜欢就拿去用_git基本用法
- 02-21Git常用命令和Git团队使用规范指南
- 02-21总结几个常用的Git命令的使用方法
- 02-21Git工作原理和常用指令_git原理详解
- 最近发表
- 标签列表
-
- cmd/c (57)
- c++中::是什么意思 (57)
- sqlset (59)
- ps可以打开pdf格式吗 (58)
- phprequire_once (61)
- localstorage.removeitem (74)
- routermode (59)
- vector线程安全吗 (70)
- & (66)
- java (73)
- org.redisson (64)
- log.warn (60)
- cannotinstantiatethetype (62)
- js数组插入 (83)
- resttemplateokhttp (59)
- gormwherein (64)
- linux删除一个文件夹 (65)
- mac安装java (72)
- reader.onload (61)
- outofmemoryerror是什么意思 (64)
- flask文件上传 (63)
- eacces (67)
- 查看mysql是否启动 (70)
- java是值传递还是引用传递 (58)
- 无效的列索引 (74)