linux运维、架构之路-K8s通过Service访问Pod
一、通过Service访问Pod
每个Pod都有自己的IP地址,当Controller用新的Pod替换发生故障的Pod时,新Pod会分配到新的IP地址,例如:有一组Pod对外提供HTTP服务,它们的IP很可能发生变化,那么客户端如何找到并访问这个服务呢,Service由此而生。Service从逻辑上代表了一组Pod,具体是哪些则由label来挑选,Service有自己的IP,并且这个IP是不变的,客户端只需要访问Service IP,无论后端Pod如何变化,对客户端访问不会有任何影响,k8s负责建立和维护Service与Pod映射关系。
1、创建Service
①创建示例文件
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
name: httpd
spec:
replicas:
template:
metadata:
labels:
app: httpd #Service将会用这个label来挑选Pod
spec:
containers:
- name: httpd
image: httpd
ports:
- containerPort:
②创建一个Httpd的Deployment应用
[root@k8s-node1 ~]# kubectl apply -f httpd.yaml
deployment.extensions "httpd" created [root@k8s-node1 ~]# kubectl get pod -o wide
NAME READY STATUS RESTARTS AGE IP NODE
httpd-fcdb8b4d8-bzsq8 / Running 2m 10.2.72.180 192.168.56.12
httpd-fcdb8b4d8-k5ds9 / Running 2m 10.2.72.182 192.168.56.12
httpd-fcdb8b4d8-ks4qq / Running 2m 10.2.72.181 192.168.56.12
上图Pod分配了各自的IP,这些IP只能被k8s集群中的容器和节点访问
[root@k8s-node2 ~]# curl 10.2.72.180
<html><body><h1>It works!</h1></body></html>
③创建Service文件
apiVersion: v1 #Service的apiVersion
kind: Service #资源类型
metadata:
name: httpd-svc #Service的名字
spec:
selector:
app: httpd #标签选择,挑选哪些label为app: httpd的Pod作为Service的后端
ports:
- protocol: TCP #将Service的8080端口映射到Pod的80端口,使用TCP协议
port:
targetPort:
④创建Service并查看
[root@k8s-node1 ~]# kubectl apply -f httpd-svc.yaml
service "httpd-svc" created [root@k8s-node1 ~]# kubectl get service
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
httpd-svc ClusterIP 10.1.168.37 <none> /TCP 7s
kubernetes ClusterIP 10.1.0.1 <none> /TCP 8d
httpd-svc分配到一个集群IP,可以通过该IP访问后端的Pod
[root@k8s-node2 ~]# curl 10.1.168.37:
<html><body><h1>It works!</h1></body></html>
⑤查看httpd-svc和Pod的对应关系
[root@k8s-node1 ~]# kubectl describe service httpd-svc
Name: httpd-svc
Namespace: default
Labels: <none>
Annotations: kubectl.kubernetes.io/last-applied-configuration={"apiVersion":"v1","kind":"Service","metadata":{"annotations":{},"name":"httpd-svc","namespace":"default"},"spec":{"ports":[{"port":,"protocol":"TC...
Selector: app=httpd
Type: ClusterIP
IP: 10.1.168.37
Port: <unset> /TCP
TargetPort: /TCP
Endpoints: 10.2.72.180:,10.2.72.181:,10.2.72.182:
Session Affinity: None
Events: <none>
Service的Cluster IP是通过iptables映射到Pod中
2、DNS访问Service
①k8s集群中的DNS服务
[root@k8s-node1 ~]# kubectl get deployment --namespace=kube-system
NAME DESIRED CURRENT UP-TO-DATE AVAILABLE AGE
coredns 4d
heapster 4d
coredns插件是一个DNS服务,当有新的Service被创建,就会添加到DNS记录,集群中的Pod可以通过SERVICE_NAME访问Service
②创建示例
[root@k8s-node1 ~]# kubectl run busybox --rm -it --image=busybox /bin/sh
If you don't see a command prompt, try pressing enter.
/ #
/ #
/ #
/ #
/ #
/ # wget httpd-svc.default:
Connecting to httpd-svc.default: (10.1.168.37:)
saving to 'index.html'
index.html % |*************************************************************************| :: ETA
'index.html' saved
同一个命名空间下,busybox Pod可以直接通过httpd-svc访问Service,这也验证了DNS的效性。
不同命名空间下,访问Service需要带上namespace,
wget httpd-svc.demon:
二、外网访问Service
- 1、ClusterIP
- Service通过Cluster内部的IP对外提供服务,只有集群内的节点和Pod可以访问,这是默认的Service类型
- 2、NodePort
- Service通过Cluster节点的静态端口对外提供服务,Cluster外部可以通过NodeIP:访问Service
- 3、LoadBalancer
- Service 利用cloud provider特有的load balancer对外提供服务,cloud provider负责将load balancer的流量导向Service,目前支持GCP、AWS、Azur等
1、NodePort
①创建示例文件
apiVersion: v1
kind: Service
metadata:
name: httpd-svc
spec:
type: NodePort
selector:
app: httpd
ports:
- protocol: TCP
port:
targetPort:
②创建并查看
[root@k8s-node1 ~]# kubectl apply -f httpd-svc.yaml
service "httpd-svc" created
[root@k8s-node1 ~]# kubectl get svc httpd-svc
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
httpd-svc NodePort 10.1.186.145 <none> :/TCP 12s
1、EXTERNAL-IP为nodes,表示可以通过Cluster每个节点自身的IP访问Service
2、PORT(S) 8080:57643,8080是ClusterIP监听的端口,57643刚是节点上监听的端口,k8s默认会从30000~32767这个范围内分配一个可用的端口,每个节点都会监听此端口,并将请求转发给Service
③测试NodePort
[root@k8s-node1 ~]# curl 192.168.56.12:
<html><body><h1>It works!</h1></body></html>
NodePort与ClusterIP一样,也是通过iptables规则实现,负载均衡到每一个Pod,NodePort默认的是随机选择,也可以指定某个固定端口
apiVersion: v1
kind: Service
metadata:
name: httpd-svc
spec:
type: NodePort
selector:
app: httpd
ports:
- protocol: TCP
nodePort: 30000 #指节点上监听的端口
port: 8080 #指ClusterIP上监听的端口
targetPort: 80 #指Pod监听的端口
Node和ClusterIP在各自端口上接收到的请求都会通过iptables转发到Pod的targetPort
linux运维、架构之路-K8s通过Service访问Pod的更多相关文章
- linux运维架构师职业规划
1.假如你从来未接触过Linux的话,首先要做的就找一本指导书来学习.现在公认的Linux的入门书籍是“鸟哥的私房菜”,讲的很全面,鸟哥的私房菜一共分为两部,一部是基础篇,一部是服务器篇.“鸟哥的私房 ...
- k8s通过Service访问Pod
如何创建服务 1.创建Deployment #启动三个pod,运行httpd镜像,label是run:mcw-httpd,Seveice将会根据这个label挑选PodapiVersion: apps ...
- k8s通过service访问pod(五)--技术流ken
service 每个 Pod 都有自己的 IP 地址.当 controller 用新 Pod 替代发生故障的 Pod 时,新 Pod 会分配到新的 IP 地址.这样就产生了一个问题: 如果一组 Pod ...
- k8s通过service访问pod(五)
service 每个 Pod 都有自己的 IP 地址.当 controller 用新 Pod 替代发生故障的 Pod 时,新 Pod 会分配到新的 IP 地址.这样就产生了一个问题: 如果一组 Pod ...
- 从苦逼到牛逼,详解Linux运维工程师的打怪升级之路
做运维也快四年多了,就像游戏打怪升级,升级后知识体系和运维体系也相对变化挺大,学习了很多新的知识点. 运维工程师是从一个呆逼进化为苦逼再成长为牛逼的过程,前提在于你要能忍能干能拼,还要具有敏锐的嗅觉感 ...
- Nginx+Lua+Redis整合实现高性能API接口 - 网站服务器 - LinuxTone | 运维专家网论坛 - 最棒的Linux运维与开源架构技术交流社区! - Powered by Discuz!
Nginx+Lua+Redis整合实现高性能API接口 - 网站服务器 - LinuxTone | 运维专家网论坛 - 最棒的Linux运维与开源架构技术交流社区! - Powered by Disc ...
- Linux运维企业架构实战系列
Linux运维企业架构项目实战系列 项目实战1-LNMP的搭建.nginx的ssl加密.权限控制的实现 项目实战2-LVS.nginx实现负载均衡系列 2.1 项目实战2.1-实现基于LVS负载均衡集 ...
- Linux运维企业架构项目实战系列
Linux运维企业架构项目实战系列 项目实战1—LNMP的搭建.nginx的ssl加密.权限控制的实现 项目实战2—LVS.nginx实现负载均衡系列2.1 项目实战2.1—实现基于LVS负载均衡集群 ...
- Linux 运维入门到跑路书单推荐
一.基础入门 <鸟哥的Linux私房菜基础学习篇>:最具知名度的Linux入门书<鸟哥的Linux私房菜基础学习篇>,全面而详细地介绍了Linux操作系统. https://b ...
随机推荐
- flask_alembic操作
HOSTNAME = '127.0.0.1' PORT = 3306 DATABASE = 'first_sqlalchemy_demo' USERNAME = 'root' PASSWORD = ' ...
- python random 的用法
python random的里面的方法其实是Random实例化的对象. 里面几个常用的几个方import random print( random.randint(1,10) ) # 产生 1 到 1 ...
- WIN32_FIND_DATA
基本信息 编辑 关于文件的全部属性信息.总计有以下以下9种:文件的标题名.文件的属性(只读.存档,隐藏等).文件的创建时间.文件的最后访问时间.文件的最后修改时间.文件大小的高位双字.文件大小的低位双 ...
- 强大的项目管理工具maven
大概功能:构建项目,管理jar包,编译代码,自动运行单元测试.打包.生成报表,部署项目,生成web站点. 重要功能:依赖管理(maven对jar包的管理过程,能够大大的节约磁盘空间).项目的一键构建. ...
- [Python3] 040 文件 一般使用
目录 文件 1. open 函数 2. with 语句 3. 先写再读 3.1 写 3.2 读 4. "位置"的查询与移动 4.1 tell() 4.2 seek(cookie, ...
- coredump产生的几种可能情况
coredump产生的几种可能情况 造成程序coredump的原因有很多,这里总结一些比较常用的经验吧: 1,内存访问越界 a) 由于使用错误的下标,导致数组访问越界. b) 搜索字符串时,依靠字符串 ...
- Python操作 RabbitMQ、Redis、Memcache
Python操作 RabbitMQ.Redis.Memcache Memcached Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数 ...
- 【笔记】vue实现简单项目和页面跳转
此项目适合不会前端,不会vue的人. 不会vue真正的开发,这里用vue和vant-ui简单搭一个商城app的tabbar和页面跳转. 装vue-cli3.0 根据官网快速上手搭建vant项目,官网 ...
- Codeforces 1221C. Perfect Team
传送门 考虑如何保证限制,首先团队数最大就是 $min(c,m)$ 但是还不够,每个团队还要 $3$ 个人,所以还要和 $(c+m+x)/3$ 再取 $min$ 这样就满足所有限制了 #include ...
- 本人亲测-Setup Factory打包教程(整理并优化)
Setup Factory 9 总结 一:安装完毕立刻启动 result = Shell.Execute(SessionVar.Expand("%AppFolder%\\消息助手.exe&q ...