不积跬步,无以至千里
博客
Python
Python
Flask
Django
FastAPI
设计模式(Python语言)
数据结构与算法(Python语言)
爬虫
数据分析
Java
Java
SpringBoot
SprintCloud
CC++
C语言
C++语言
Go
Go
设计模式(Go)
数据结构与算法(Go)
云计算
云计算理论
Linux
Shell
云原生
云原生理论
Docker
Kubernetes
Kubersphere
DevOps
Git
Gitlab
Jenkins
Nexus
Harbor
SonarQube
Grafana
OpenQA
建木
禅道
Compass-CI
前端
HTML
CSS
JavaScript
BootStrap
Vue
React
Markdown
数据库
MySql
Redis
MongoDB
H2 Database
Liquibase
ElasticStack
中间件
MQ
Kafka
Nginx
cpolar
阿里云
测试
测试理论
安全测试
压力测试
Pytest
UnitTest
考试
软考中级(软件设计师考试)
软考高级(系统架构设计师考试)
登录
注册
Kubernetes----HeadLess类型的Service
收藏本文
作者:redrose2100 类别:Kubernetses 日期:2022-05-23 14:26:32 阅读:305 次 消耗积分:0 分
# 一、Headless类型Service简介 在某些场景下,开发人员可能不想使用Service提供的负载均衡功能,而希望自己来控制负载均衡策略,针对这种情况,Kubernetes提供了Headless Service,这类Service不会分配ClusterIP,如果想要访问Service,只能通过service的域名进行查询 # 二、环境准备 编写deployment.yaml文件,内容如下: ```yaml apiVersion: v1 kind: Namespace metadata: name: dev --- apiVersion: apps/v1 kind: Deployment metadata: name: pc-deployment namespace: dev spec: replicas: 3 selector: matchLabels: app: nginx-pod template: metadata: labels: app: nginx-pod spec: containers: - name: nginx image: nginx:1.17.1 ports: - containerPort: 80 ``` 然后使用如下命令创建资源 ```bash [root@master service]# kubectl apply -f deployment.yaml namespace/dev created deployment.apps/pc-deployment created [root@master service]# ``` 查看创建的资源如下: ```bash [root@master service]# kubectl get deploy,pod -n dev -o wide NAME READY UP-TO-DATE AVAILABLE AGE CONTAINERS IMAGES SELECTOR deployment.apps/pc-deployment 3/3 3 3 17m nginx nginx:1.17.1 app=nginx-pod NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES pod/pc-deployment-5ffc5bf56c-mqwst 1/1 Running 0 17m 10.244.2.191 node2
pod/pc-deployment-5ffc5bf56c-qbznm 1/1 Running 0 17m 10.244.1.53 node1
pod/pc-deployment-5ffc5bf56c-zxnsx 1/1 Running 0 17m 10.244.2.190 node2
[root@master service]# ``` ## 三、创建Headless类型的Service 编辑headless.yaml文件,内容如下: ```yaml apiVersion: v1 kind: Service metadata: name: service-headless namespace: dev spec: selector: app: nginx-pod clusterIP: None type: ClusterIP ports: - port: 80 targetPort: 80 ``` 使用如下命令创建服务 ```bash [root@master service]# kubectl apply -f headless.yaml service/service-headless created [root@master service]# ``` 查看创建的资源 ```bash [root@master service]# kubectl get service,deployment,pod -n dev -o wide NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE SELECTOR service/service-headless ClusterIP None
80/TCP 99s app=nginx-pod NAME READY UP-TO-DATE AVAILABLE AGE CONTAINERS IMAGES SELECTOR deployment.apps/pc-deployment 3/3 3 3 8m50s nginx nginx:1.17.1 app=nginx-pod NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES pod/pc-deployment-5ffc5bf56c-mqwst 1/1 Running 0 8m50s 10.244.2.191 node2
pod/pc-deployment-5ffc5bf56c-qbznm 1/1 Running 0 8m50s 10.244.1.53 node1
pod/pc-deployment-5ffc5bf56c-zxnsx 1/1 Running 0 8m50s 10.244.2.190 node2
[root@master service]# ``` 此时服务因为没有ClusterIP,所以此时不能使用ip去访问了,只能使用域名访问了,即 service-headless.dev.svc.cluster.local,这里面格式是 ```bash [service的名字].[命名空间].svc.cluster.local ``` 首先登录pod查看域名解析 ```bash [root@master service]# kubectl exec -it pod/pc-deployment-5ffc5bf56c-mqwst -n dev /bin/bash kubectl exec [POD] [COMMAND] is DEPRECATED and will be removed in a future version. Use kubectl exec [POD] -- [COMMAND] instead. root@pc-deployment-5ffc5bf56c-9bg6w:/# root@pc-deployment-5ffc5bf56c-9bg6w:/# cat /etc/resolv.conf nameserver 10.96.0.10 search dev.svc.cluster.local svc.cluster.local cluster.local options ndots:5 root@pc-deployment-5ffc5bf56c-9bg6w:/# ``` 然后查看域名解析,具体查看域名的命令如下 ```bash [root@master service]# dig @10.96.0.10 service-headless.dev.svc.cluster.local ; <<>> DiG 9.11.4-P2-RedHat-9.11.4-26.P2.el7_9.9 <<>> @10.96.0.10 service-headless.dev.svc.cluster.local ; (1 server found) ;; global options: +cmd ;; Got answer: ;; WARNING: .local is reserved for Multicast DNS ;; You are currently testing what happens when an mDNS query is leaked to DNS ;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 62573 ;; flags: qr aa rd; QUERY: 1, ANSWER: 3, AUTHORITY: 0, ADDITIONAL: 1 ;; WARNING: recursion requested but not available ;; OPT PSEUDOSECTION: ; EDNS: version: 0, flags:; udp: 4096 ;; QUESTION SECTION: ;service-headless.dev.svc.cluster.local. IN A ;; ANSWER SECTION: service-headless.dev.svc.cluster.local. 30 IN A 10.244.2.190 service-headless.dev.svc.cluster.local. 30 IN A 10.244.1.53 service-headless.dev.svc.cluster.local. 30 IN A 10.244.2.191 ;; Query time: 0 msec ;; SERVER: 10.96.0.10#53(10.96.0.10) ;; WHEN: Mon Apr 04 11:57:01 CST 2022 ;; MSG SIZE rcvd: 229 [root@master service]# ```
始终坚持开源开放共享精神,同时感谢您的充电鼓励和支持!
版权所有,转载本站文章请注明出处:redrose2100, http://blog.redrose2100.com/article/281
上一篇:
Kubernetes----ClusterIP类型的Service
下一篇:
Kubernetes----NodePort类型的Service
你的昵称:
你的评论:
提示:登录后添加有效评论可享受积分哦!
点此登录
搜索
个人成就
DevOps技术交流微信群
加微信邀请进群
常用网站链接
开源软件洞察
云原生技术栈全景图
Python语言官方文档
Go语言官方文档
Docker官方文档
Jenkins中文用户手册
Markdown语法官方教程
Harbor官方文档
openQA官方文档
云原生开源社区
开源中国
Kubernetes中文文档
Kubernetes中文社区
Kubersphere官方文档
BootStrap中文网站
JavaScript中文网
NumPy官方文档
Pandas官方文档
GitLink确实开源网站
数据库排名网站
编程语言排名网站
SEO综合查询网站
数学加减法练习自动生成网站
Kickstart Generator
文章分类
最新文章
最多阅读
特别推荐
×
Close
登录
注册
找回密码
登录邮箱:
登录密码:
图片验证码:
注册邮箱:
注册密码:
邮箱验证码:
发送邮件
注册邮箱:
新的密码:
邮箱验证码:
发送邮件