zookeeper向管控平台上报状态

server/2024/9/22 19:42:53/

问题

在你的场景中,由于 Django 应用启动了 4 个 uWSGI 进程,每个进程都会创建一个节点并上报状态,因此出现了 4 次状态上报的情况。这在大多数情况下是不合理的,尤其是在你只期望应用上报一次状态时。

要解决这个问题并优雅地进行修改,以下是几种常见的解决方案:

解决方案

  1. 使用单个进程上报状态 你可以通过 主进程 或 第一个工作进程 来进行上报,避免每个进程都上报。具体方法如下:

    方法一:仅在主进程上报 使用 uWSGI 的 --master 选项,确保只有主进程(master
    process)负责上报状态。你可以在创建 Zookeeper 节点时,检查当前进程是否为主进程,非主进程则不执行上报逻辑。
    import uwsgi if uwsgi.masterpid() == os.getpid():
    # 只有主进程执行上报逻辑
    report_status_to_zookeeper() 方法二:第一个 worker 进程上报 如果你希望使用第一个工作进程来上报状态,而不是主进程,可以使用进程 ID 来判断: import os if os.getpid()
    == min(uwsgi.workers(), key=lambda w: w[‘pid’])[‘pid’]:
    # 只有第一个 worker 执行上报逻辑
    report_status_to_zookeeper()

  2. 使用分布式锁 你可以使用 Zookeeper
    分布式锁机制,确保只有一个进程可以成功获取锁,获取锁的进程上报状态。这样即使启动多个进程,也只有一个进程可以创建节点并上报。 from
    kazoo.client import KazooClient from kazoo.recipe.lock import Lock

    zk = KazooClient(hosts=‘127.0.0.1:2181’) zk.start()

    lock = Lock(zk, “/my/lock/path”)

    with lock:
    –获取锁后上报状态 report_status_to_zookeeper()

  3. 使用共享存储或标志位 你可以使用
    Redis、数据库等共享存储系统,或者在本地文件系统中写入标志位,确保只有一个进程进行状态上报。例如,第一次上报后设置一个标志位,其他进程检测到标志位已存在就不再重复上报。
    from redis import Redis

    redis = Redis()

    if not redis.get(“status_reported”):
    –设置标志位,并上报状态 redis.set(“status_reported”, “1”) report_status_to_zookeeper()

  4. 在管理平台端处理重复上报 如果管理平台端支持去重机制,也可以通过在平台端处理重复上报的逻辑,从而避免对你应用层的改动。


http://www.ppmy.cn/server/120423.html

相关文章

【Unity实战】SO反序列化正确姿势

此篇博文算是【C#实战】Newtonsoft.Json基类子类解析_newtonsoft.json不能转化子类-CSDN博客的一个补充,因为我发现ScriptableObject并不是传统的new()就能解决的问题。 SomeClass must be instantiated using the ScriptableObject.CreateInstance method instead…

C++类和对象(下)

文章目录 const成员函数取地址运算符重载初始化列表类型转换static成员友元内部类匿名对象 const成员函数 概念:将const修饰的成员函数称之为const成员函数 定义:const修饰成员函数时,放到成员函数参数列表的后面 例: class Date…

Selenium等待机制:理解并应用显式等待与隐式等待,解决页面加载慢的问题

目录 引言 等待机制的重要性 显式等待(Explicit Wait) 原理 应用方式 代码示例 优点与缺点 隐式等待(Implicit Wait) 原理 应用方式 代码示例 优点与缺点 解决页面加载慢的问题 1. 合理设置等待时间 2. 优先使用显…

【JavaEE初阶】多线程6(线程池\定时器)

欢迎关注个人主页:逸狼 创造不易,可以点点赞吗~ 如有错误,欢迎指出~ 目录 实例3:线程池 参数解释 核心线程数, 最大线程数 允许空闲的最大时间 ,时间单位 任务队列(阻塞队列) 线程工厂>工厂设计模式 拒绝策略 使用举例 模拟实现一个线…

如何在Linux Centos7系统中挂载群晖共享文件夹

前景:企业信息化各种系统需要上传很多的图片或者是文件,文件如何在群晖中显示,当文件或者图片上传到linux指定文件夹内,而文件夹又与群晖共享文件夹进行挂载,就能保证上传的文件或者图片出现在群晖并在群晖里进行管理。…

Mac 上,终端如何开启 proxy

文章目录 为什么要这么做前提步骤查看 port查看代理的port配置 bash测试 为什么要这么做 mac 上的终端比较孤僻吧,虽然开了,但是终端并不走🪜…产生的现象就是,浏览器可以访问🌍,但是终端不可以访问&#…

深入理解与避免Java 死锁

在 Java 编程中,死锁是一个让人头疼但又至关重要的问题。理解死锁的产生条件以及如何避免死锁,对于编写高效、稳定的多线程程序至关重要。本文将深入探讨 Java 死锁的四个必要条件,并通过具体的例子和解决方案帮助读者更好地理解和避免死锁。…

集群聊天服务器项目【C++】(六)MySql数据库

前面已经介绍了网络模块和业务模块,本章介绍数据模块,同样保持模块解耦的特性,即业务模块不能出现数据模块内容,如出现SQL语句,接下来看看怎么实现的。 1.环境安装 第一章已经介绍了MySql安装,但注意需要…