当前位置: 首页 > news >正文

网站视频解析做卫浴软管的网站

网站视频解析,做卫浴软管的网站,网站布局策划,深圳市8号公告最新消息引言 在 Kubernetes 集群中#xff0c;Informer 是一种重要的机制#xff0c;用于监控和处理集群中资源对象的变化。它是基于观察者模式设计的#xff0c;允许开发者注册对某类资源对象的关注#xff0c;并在对象发生变化时得到通知。本文将深入介绍 Kubernetes 中的 Info…引言 在 Kubernetes 集群中Informer 是一种重要的机制用于监控和处理集群中资源对象的变化。它是基于观察者模式设计的允许开发者注册对某类资源对象的关注并在对象发生变化时得到通知。本文将深入介绍 Kubernetes 中的 Informer 机制包括其设计思想、工作原理、示例和最佳实践。 什么是 Informer Informer 是 Kubernetes 中用于监控和处理资源对象变化的框架。它建立在 Kubernetes 的客户端库 client-go 之上提供了高级别的 API简化了开发者对资源对象状态变化的监听和处理。 Informer 的核心思想是将对资源对象的监听和处理逻辑进行模块化以便更容易地维护和扩展。通过 Informer开发者可以注册关注的资源类型并在资源状态发生变化时执行自定义的业务逻辑。 Informer 的工作原理 Informer 机制的核心工作原理主要包括以下几个步骤 List-Watch 机制 Informer 使用 Kubernetes API 的 List-Watch 机制来获取资源对象的初始列表并通过 Watch 机制实时接收对象的变化事件。SharedInformerFactory SharedInformerFactory 是 Informer 的工厂负责创建和管理多个 SharedInformer。每个 SharedInformer 监听一种资源对象的变化。Event Handlers 开发者可以注册事件处理器Event Handlers在资源对象发生变化时触发相应的处理逻辑。Event Handlers 是 Informer 的核心扩展点用于实现自定义的业务逻辑。Delta FIFO Queue 通过 Delta FIFO QueueInformer 在收到资源对象的变化事件时将事件推送到队列中。Event Handlers 从队列中取出事件进行处理。Resync Informer 支持定期的全量同步Resync机制以确保本地缓存与实际状态的一致性。定期地对资源对象进行全量同步更新本地缓存。 如何使用 Informer 1. 创建 SharedInformerFactory 首先创建一个 SharedInformerFactory 对象 clientset, err : kubernetes.NewForConfig(config) if err ! nil {panic(err.Error()) }informerFactory : informers.NewSharedInformerFactory(clientset, time.Second*30)2. 注册关注的资源类型 使用 SharedInformerFactory 注册对某一种资源类型的关注 podInformer : informerFactory.Core().V1().Pods()3. 注册 Event Handlers 注册事件处理器定义在资源对象发生变化时的处理逻辑 podInformer.Informer().AddEventHandler(cache.ResourceEventHandlerFuncs{AddFunc: func(obj interface{}) {// 处理资源对象新增事件pod : obj.(*corev1.Pod)fmt.Printf(Pod added: %s\n, pod.Name)},UpdateFunc: func(oldObj, newObj interface{}) {// 处理资源对象更新事件oldPod : oldObj.(*corev1.Pod)newPod : newObj.(*corev1.Pod)fmt.Printf(Pod updated: %s\n, newPod.Name)},DeleteFunc: func(obj interface{}) {// 处理资源对象删除事件pod : obj.(*corev1.Pod)fmt.Printf(Pod deleted: %s\n, pod.Name)}, })4. 启动 Informer 启动 SharedInformerFactory开始监听资源对象的变化 informerFactory.Start(stopCh)5. 处理资源对象变化事件 在 Event Handlers 中定义的逻辑将在资源对象发生变化时被触发 -stopCh通过以上步骤就可以使用 Informer 监听和处理 Kubernetes 集群中资源对象的变化。 示例使用 Informer 监听 Pod 变化 下面是一个简单的示例演示如何使用 Informer 监听 Pod 对象的变化 package mainimport (contextflagfmtosos/signaltimek8s.io/client-go/kubernetesk8s.io/client-go/tools/cachek8s.io/client-go/tools/clientcmdk8s.io/client-go/util/homedirk8s.io/client-go/util/wait )func main() {var kubeconfig *stringif home : homedir.HomeDir(); home ! {kubeconfig flag.String(kubeconfig, home/.kube/config, kubeconfig file)} else {kubeconfig flag.String(kubeconfig, , kubeconfig file)}config, err : clientcmd.BuildConfigFromFlags(, *kubeconfig)if err ! nil {panic(err.Error())}clientset, err : kubernetes.NewForConfig(config)if err ! nil {panic(err.Error())}stopCh : make(chan struct{})defer close(stopCh)informerFactory : cache.NewSharedInformerFactory(clientset, time.Second*30)podInformer : informerFactory.Core().V1().Pods()podInformer.Informer().AddEventHandler(cache.ResourceEventHandlerFuncs{AddFunc: func(obj interface{}) {pod : obj.(*corev1.Pod)fmt.Printf(Pod added: %s\n, pod.Name)},UpdateFunc: func(oldObj, newObj interface{}) {oldPod : oldObj.(*corev1.Pod)newPod : newObj.(*corev1.Pod)fmt.Printf(Pod updated: %s\n, newPod.Name)},DeleteFunc: func(obj interface{}) {pod : obj.(*corev1.Pod)fmt.Printf(Pod deleted: %s\n, pod.Name)},})go informerFactory.Start(stopCh)if !cache.WaitForCacheSync(stopCh, podInformer.Informer().HasSynced) {fmt.Println(Timed out waiting for caches to sync)return}fmt.Println(Informer started. Waiting for Pod events...)c : make(chan os.Signal, 1)signal.Notify(c, os.Interrupt)-cfmt.Println(Received interrupt signal. Stopping Informer...) }结语 Informer 机制是 Kubernetes 中强大且灵活的一部分为开发者提供了便捷的方式监听和处理集群中资源对象的变化。通过 SharedInformerFactory 的注册和 Event Handlers 的定义可以轻松实现对特定资源类型的关注和处理逻辑。Informer 的应用范围广泛涉及到许多领域包括控制器开发、自动伸缩、日志收集等。希望本文的详细介绍和示例能够帮助你更好地理解和应用 Kubernetes 中的 Informer 机制。
http://www.hkea.cn/news/14481165/

相关文章:

  • 深圳中国网站制作哪家公司好网站建设推广咨询平台
  • php技术的网站开发大型车产品网站建设
  • 用jquery做网站软件培训内容怎么写
  • 个人建网站首选什么域名好营销伎巧
  • 高端建设网站建设专业管道疏通网站建设图片
  • 网站如何连接微信支付设计家官网室内设计
  • 028网站建设中文域名指向同一个网站
  • 医疗机构网站备案专做特卖的网站
  • 职业学校查询网站易货网站开发
  • 中国各大网站开发语言岳阳手机网站制作
  • 重庆大渡口营销型网站建设价格一流的天津网站建设
  • 美工网站设计收费哪里有营销策划培训班
  • 礼品兑换网站怎么做seo优化网站教程
  • 网站建设方案维护阿里云做网站开发吗
  • ftp网站地图怎么做临清网站建设服务
  • 广州化妆品网站建设公司59网站一起做网店女鞋
  • 移动端网站排名南通网站建设.
  • 私人申请建设网站多少钱wordpress自动回复
  • 临沂住房和城乡建设厅网站长沙招聘网58同城招聘发布
  • 深圳网站设计营销型免费公司网址
  • 建网站要注册吗江门微信网站建设
  • 保定外贸网站建设wap网站用什么开发
  • 邯郸做网站网络公司营销策划方案的写作方法
  • 免费建造网站系统网站推广途径和要点有哪些
  • 免费做封面网站微信公众号链接的网站怎么做
  • 做外贸网站如果是东西杂会不会不好推广网页设计一个月工资多少
  • 网站建设评审会总结发言惠州seo外包平台
  • 公司官网网站如何建立创意网红墙图片
  • 建设网站的傻瓜图文指南免费注册域名方法
  • 网站建设要知道的晓风彩票网站建设源代码授权