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

网站视频解析网站建设与网络编辑课程心得

网站视频解析,网站建设与网络编辑课程心得,鞍山建设工程信息网站,小鱼儿网站做啥用的引言 在 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/14353149/

相关文章:

  • 天津艺匠做网站怎么样惠州seo怎么做
  • 贵州交通建设集团有限公司网站网站设计尺寸规范
  • 小程序 微网站做怎样的网站能赚钱
  • 成都学校网站建设公司用html做网站源代码
  • 做众筹的网站唐山市做网站
  • 晋城市住房保障和城乡建设局网站网络机房建设方案
  • 在网站做电子画册网站怎么接广告赚钱
  • 企迪网沈阳seo优化
  • 网站admin密码忘记了怎么办两个wordpress联通
  • 黄岛开发区做网站的公司百度开发者中心
  • 电商网站有哪些官网网站有后台更新不了
  • 效益型网站建立简单网站
  • seo 网站 结构整站营销系统
  • 阜阳网站建设云平台做网站是怎样赚钱的
  • 怎么自己设计logoseo优化包括什么
  • 建设银行网站怎么看交易记录手机做任务网站
  • 在机关网站建设会上讲话英文版wordpress如何转换
  • 班级网站的建设调查表简单网站建设的费用
  • 网站建设中主页指的是建设网站基础
  • 公司网站的建设与运营管理制度企业网站收录
  • 大型网站建设方案常见问题wordpress插件改图标
  • iis 网站制作阳江打卡网红店
  • 做跨境都有哪些网站南宁手机做网站设计
  • 网站首页设计网站建设需要资质么
  • rss网站推广法韩国最新新闻消息
  • 收录好的网站恢复原来的百度
  • 企业网站 程序免费咨询制度
  • 网站如何集成微信支付中国建设银行人才招聘网站
  • 个人做网站做什么样的话免费有效的推广平台
  • 建设厅网站上人员怎么导出如何增加网站转化率