首页 > 其他分享 >k8s实战入门——Service

k8s实战入门——Service

时间:2022-11-10 12:12:35浏览次数:54  
标签:kubectl 入门 Service -- svc nginx k8s port

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

 

标签:kubectl,入门,Service,--,svc,nginx,k8s,port
From: https://www.cnblogs.com/gys001/p/16876610.html

相关文章

  • 使用kubekey搭建k8s集群,一键安装!
    前言KubeKey是KubeSphere公司用go语言开发的一款云原生容器工具,使用KubeKe可以轻松、高效、灵活地单独或整体安装Kubernetes。安装准备主机名IP作用master1......
  • Kubernetes(k8s)部署Promehteus监控
    一、概述Prometheus是一个开源监控系统,生态包括了很多组件,它们中的一些是可选的:主服务PrometheusServer负责抓取和存储时间序列数据客户库负责检测应用程序代码支持......
  • K8s系列---【KubeSphere部署完mysql8.0再部署mysql5.0导致mysql5.0启动失败的问题】
    KubeSphere部署完mysql8.0再部署mysql5.0导致mysql5.0启动失败的问题1.报错InnoDB:Tableflagsare0inthedatadictionarybuttheflagsinfile./ibdata1are0x......
  • K8s系列---【安装nfs文件系统(为k8s提供动态创建pv的能力)】
    安装nfs文件系统(为k8s提供动态创建pv的能力)1.1安装nfs-server#在每个机器执行下面这条命令(包含master)。yuminstall-ynfs-utils下面的/nfs/data目录可以自定义,......
  • Android内存泄漏:谨慎使用getSystemService
    Android中有很多服务,比如PowerManager,AlarmManager,NotificationManager等,通常使用起来也很方便,就是使用Context.getSystemService方法来获得。一次在公司开发项目开发中,突......
  • MyBatis快速入门
    1.查询user表中创建数据首先创建mysql数据库,并更新里面内容 2.创建模块,导入坐标3.编写MyBatis核心配置文件4.编写SQL映射文件5.编码......
  • 【人工智能】机器学习入门之监督学习(一)有监督学习
    机器学习入门之监督学习(一)有监督学习简介监督学习算法是常见算法之一,主要分为有监督学习和无监督学习。本文主要记录了有监督学习中的分类算法和回归算法,其中回归算法是......
  • pytorch入门
    初衷:看不懂论文开源代码参考:B站小土堆(土堆yyds~)   PyTorch深度学习快速入门教程(绝对通俗易懂!)【小土堆】_哔哩哔哩_bilibili 1.环境配置参考:(39条消息)win10......
  • K8s系列---【KubeSphere部署Mysql】
    KubeSphere部署Mysql(有状态副本集)扫盲:什么是有状态副本集?例如,部署一个mysql,如果服务挂了,K8s会自动拉起一个mysql服务,但是拉起的mysql服务仍然得有服务挂掉之......
  • PlinkManageServiceImplTest
    1importorg.apache.commons.io.FileUtils;2importorg.junit.Assert;3importorg.junit.Before;4importorg.junit.BeforeClass;5importorg.junit.T......