• 博客园logo
  • 会员
  • 周边
  • 新闻
  • 博问
  • 闪存
  • 众包
  • 赞助商
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
gys001
博客园    首页    新随笔    联系   管理    订阅  订阅

k8s实战入门——Service

Service

通过Deployment来创建一组Pod来提供具有高可用性的服务。

虽然每个Pod都会分配一个单独的Pod IP,然而却存在如下两问题:

- Pod IP 会随着Pod的重建产生变化
- Pod IP 仅仅是集群内可见的虚拟IP,外部无法访问
这样对于访问这个服务带来了难度。因此,kubernetes设计了Service来解决这个问题。

Service可以看作是一组同类Pod对外的访问接口。借助Service,应用可以方便地实现服务发现和负载均衡。

image-20200408194716912

创建集群内部可访问的Service
暴露Service
kubectl expose deployment xxx --name=服务名 --type=ClusterIP --port=暴露的端口 --target-port=指向集群中的Pod的端口 [-n 命名空间]
注:ClusterIP是默认type类型的,即不指定也是ClusterIP
--port=暴露的端口是service的IP端口
[root@master
~]# kubectl expose deploy nginx --name=svc-nginx --type=ClusterIP --port=80 --target-port=80 -n dev

 查看Service

kubectl get service [-n 命名空间] [-o wide]

[root@master ~]# kubectl get svc svc-nginx -n dev -o wide

# 这里产生了一个CLUSTER-IP,这就是service的IP,在Service的生命周期中,这个地址是不会变动的
# 可以通过这个IP访问当前service对应的Pod

[root@master ~]# curl 10.102.145.225:80
#若端口是80,则可省略
创建集群外部也可访问的Service
# 上面创建的Service的type类型为ClusterIP,这个ip地址只用集群内部可访问
# 如果需要创建外部也可以访问的Service,需要修改type为NodePort

kubectl expose deployment xxx --name=服务名 --type=NodePort --port=暴露的端口 --target-port=指向集群中的Pod的端口 [-n 命名空间]

# 会产生一个外部也可以访问的Service

[root@master ~]# kubectl expose deploy nginx --name=svc-nginx2 --type=NodePort --port=80 --target-port=80 -n dev

[root@master ~]# kubectl get svc -n dev -o wide

[root@master ~]# curl 192.168.1.50:31458

# 接下来就可以通过集群外的主机访问 节点IP: 31458访问服务了
# 例如在的电脑主机上通过浏览器访问下面的地址

删除Service
kubectl delete service xxx [-n 命名空间]

[root@master ~]# kubectl delete svc svc-nginx -n dev
yaml配置方式

创建一个svc-nginx.yaml,内容如下:

apiVersion: v1
kind: Service
metadata:
  name: svc-nginx        #svc的名字
  namespace: dev
spec:
  clusterIP: 10.109.179.231 #指定svc的内网ip,若不写则默认随机分配
  ports:
  - port: 80
    protocol: TCP
    targetPort: 80
  selector:
    run: nginx
  type: ClusterIP      #默认是ClusterIP,可不写
然后就可以执行对应的创建和删除命令了:
创建
[root@master ~]# kubectl create svc svc-nginx -n dev

删除
[root@master ~]# kubectl delete svc svc-nginx -n dev

删除所有
[root@master ~]# kubectl delete svc --all -n dev

参考
黑马B站k8s课程https://www.bilibili.com/video/BV1Qv41167ck/
https://gitee.com/yooome/golang/blob/main/k8s%E8%AF%A6%E7%BB%86%E6%95%99%E7%A8%8B-%E8%B0%83%E6%95%B4%E7%89%88/k8s%E8%AF%A6%E7%BB%86%E6%95%99%E7%A8%8B.md
https://www.yuque.com/fairy-era/yg511q/xyqxge

 

posted @ 2022-11-10 12:03  gys001  阅读(106)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3