kubernates学习笔记【12】:service介绍,service代理模式分类

一. Service定义

    Kubernetes Service 定义了这样一种概念: -个[Pod]的逻辑分组,-种可以访问它们的策略--通常称为微服务。这一组Pod能够被Service 访问到,通常是通过Label selector来访问

      

二. Service类型


      Service在K8s中有以下四种类型:

      1. Clusterlp: 默认类型,自动分配-个仅Cluster内部可以访问的虚拟IP

      2. NodePort: 在ClusterIP基础上为Service在每台机器.上绑定个端口,这样就可以通过: NodePort来访

      问该服务

      3. LoadBalancer: 在NodePort的基础上,借助cloud provider创建-一个外部负载均衡器,并将请求转发

      到: NodePort

      4. ExternalName: 把集群外部的服务引入到集群内部来,在集群内部直接使用。没有任何类型代理被创建,

      这只有kubernetes 1.7或更高版本的kube-dns才支持

三. Service代理


     在Kubernetes集群中,每个Node运行一个kube-proxy 进程。kube-proxy 负责为Service 实现了一种VIP (虚拟IP)的形式,而不是ExternalName 的形式。 在Kubernetes v1.0版本,代理完全在userspace. 在Kubernetes v1.1版本,新增了iptables代理,但并不是默认的运行模式。从Kubermetes v1.2起,默认就是iptables代理。在Kubernetes v1.8.0-beta.0中,添加了ipvs代理在Kubernetes 1.14版本开始默认使用ipvs代理

     在Kubernetes v1.0版本,Service 是"4层”(TCP/UDP overIP)概念。在Kubernetesv1.1版本,新增了Ingress API (beta 版),用来表示“7层”(HTTP) 服务。

     看下图:

四. Service代理模式分类

  1. userspace

这种方式是需要经过kube-proxy的,比较消耗时间

  2. iptables代理模式

     这种方式不需要经过kube-proxy,只需要经过iptables的防火墙,而它的pod信息还是有service,kube-proxy来维护的。

  3. IPVS代理模式


      这种模式,kube-proxy 会监视Kubernetes Service 对象和Endpoints, 调用netlink 接口以相应地创建ipvs规则并定期与Kubernetes Service 对象和Endpoints 对象同步ipvs规则,以确保ipvs状态与期望一致。访问服务时,流量将被重定向到其中-个后端Pod

      与iptables类似,ipvs 于netfilter的hook功能,但使用哈希表作为底层数据结构并在内核空间中工作。这意味着ipvs可以更快地重定向流量,并且在同步代理规则时具有更好的性能。此外,ipvs 为负载均衡算法提供了更多选项,例如:

      ●rr:轮询调度

      ●lc:最小连接数

      ●dh:目标哈希

      ●sh:源哈希

      ●sed:最短期望延迟

      ● nq:不排队调度

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
代理模式是一种结构型设计模式,它通过代理对象来控制对原始对象的访问。下面是一个C#中使用代理模式的示例,假设有一个远程数据库服务,我们需要在本地应用程序中访问该服务的数据,但是由于网络延迟等原因,直接访问远程服务时可能会存在性能问题,因此我们可以使用代理模式来实现本地缓存,减少对远程服务的访问。 ```csharp // 定义远程服务接口 public interface IDatabaseService { List<string> GetData(); } // 实现远程服务 public class RemoteDatabaseService : IDatabaseService { public List<string> GetData() { // 模拟远程服务,返回数据 return new List<string> { "data1", "data2", "data3" }; } } // 定义代理,实现远程服务接口 public class DatabaseServiceProxy : IDatabaseService { private readonly RemoteDatabaseService _remoteService; private List<string> _cachedData; public DatabaseServiceProxy() { _remoteService = new RemoteDatabaseService(); } public List<string> GetData() { if (_cachedData == null) { // 第一次访问时,从远程服务获取数据,并缓存到本地 _cachedData = _remoteService.GetData(); } // 返回缓存的数据 return _cachedData; } } // 客户端代码 class Program { static void Main(string[] args) { // 使用代理访问远程服务 IDatabaseService databaseService = new DatabaseServiceProxy(); var data = databaseService.GetData(); Console.WriteLine("Data: " + string.Join(",", data)); } } ``` 在上面的示例中,我们定义了远程服务接口`IDatabaseService`和实现`RemoteDatabaseService`,代理`DatabaseServiceProxy`实现了该接口,并使用远程服务对象`_remoteService`来实现实际的数据获取,同时在代理中缓存了远程服务的数据,以便下一次访问时直接从缓存中获取,避免了频繁的网络访问。客户端代码中,我们使用代理来访问远程服务,并输出获取到的数据。 这个示例展示了代理模式的一个常见应用场景,即在访问远程服务时使用代理进行控制和优化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值