千家信息网

nacos中ServerStatusManager的作用是什么

发表于:2025-12-03 作者:千家信息网编辑
千家信息网最后更新 2025年12月03日,本篇文章给大家分享的是有关nacos中ServerStatusManager的作用是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。S
千家信息网最后更新 2025年12月03日nacos中ServerStatusManager的作用是什么

本篇文章给大家分享的是有关nacos中ServerStatusManager的作用是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

ServerStatusManager

nacos-1.1.3/naming/src/main/java/com/alibaba/nacos/naming/cluster/ServerStatusManager.java

@Servicepublic class ServerStatusManager {    @Resource(name = "consistencyDelegate")    private ConsistencyService consistencyService;    @Autowired    private SwitchDomain switchDomain;    private ServerStatus serverStatus = ServerStatus.STARTING;    @PostConstruct    public void init() {        GlobalExecutor.registerServerStatusUpdater(new ServerStatusUpdater());    }    private void refreshServerStatus() {        if (StringUtils.isNotBlank(switchDomain.getOverriddenServerStatus())) {            serverStatus = ServerStatus.valueOf(switchDomain.getOverriddenServerStatus());            return;        }        if (consistencyService.isAvailable()) {            serverStatus = ServerStatus.UP;        } else {            serverStatus = ServerStatus.DOWN;        }    }    public ServerStatus getServerStatus() {        return serverStatus;    }    public class ServerStatusUpdater implements Runnable {        @Override        public void run() {            refreshServerStatus();        }    }}
  • ServerStatusManager的init方法注册了ServerStatusUpdater,它实现了Runnable接口,其run方法执行refreshServerStatus;refreshServerStatus会判断consistencyService是否是available,如果是更新serverStatus为ServerStatus.UP,否则为ServerStatus.DOWN

ServerStatus

nacos-1.1.3/naming/src/main/java/com/alibaba/nacos/naming/cluster/ServerStatus.java

public enum ServerStatus {    /**     * server is up and ready for request     */    UP,    /**     * server is out of service, something abnormal happened     */    DOWN,    /**     * server is preparing itself for request, usually 'UP' is the next status     */    STARTING,    /**     * server is manually paused     */    PAUSED,    /**     * only write operation is permitted.     */    WRITE_ONLY,    /**     * only read operation is permitted.     */    READ_ONLY}
  • ServerStatus有UP、DOWN、STARTING、PAUSED、WRITE_ONLY、READ_ONLY这几种状态

TrafficReviseFilter

nacos-1.1.3/naming/src/main/java/com/alibaba/nacos/naming/web/TrafficReviseFilter.java

public class TrafficReviseFilter implements Filter {    @Autowired    private ServerStatusManager serverStatusManager;    @Autowired    private SwitchDomain switchDomain;    @Override    public void doFilter(ServletRequest request, ServletResponse response, FilterChain filterChain) throws IOException, ServletException {        HttpServletRequest req = (HttpServletRequest) request;        HttpServletResponse resp = (HttpServletResponse) response;        // request limit if exist:        String urlString = req.getRequestURI() + "?" + req.getQueryString();        Map limitedUrlMap = switchDomain.getLimitedUrlMap();        if (limitedUrlMap != null && limitedUrlMap.size() > 0) {            for (Map.Entry entry : limitedUrlMap.entrySet()) {                String limitedUrl = entry.getKey();                if (StringUtils.startsWith(urlString, limitedUrl)) {                    resp.setStatus(entry.getValue());                    return;                }            }        }        // if server is UP:        if (serverStatusManager.getServerStatus() == ServerStatus.UP) {            filterChain.doFilter(req, resp);            return;        }        // requests from peer server should be let pass:        String agent = req.getHeader("Client-Version");        if (StringUtils.isBlank(agent)) {            agent = req.getHeader("User-Agent");        }        if (StringUtils.startsWith(agent, UtilsAndCommons.NACOS_SERVER_HEADER)) {            filterChain.doFilter(req, resp);            return;        }        // write operation should be let pass in WRITE_ONLY status:        if (serverStatusManager.getServerStatus() == ServerStatus.WRITE_ONLY && !HttpMethod.GET.equals(req.getMethod())) {            filterChain.doFilter(req, resp);            return;        }        // read operation should be let pass in READ_ONLY status:        if (serverStatusManager.getServerStatus() == ServerStatus.READ_ONLY && HttpMethod.GET.equals(req.getMethod())) {            filterChain.doFilter(req, resp);            return;        }        resp.getWriter().write("server is " + serverStatusManager.getServerStatus().name() + " now, please try again later!");        resp.setStatus(HttpServletResponse.SC_SERVICE_UNAVAILABLE);    }}
  • TrafficReviseFilter会根据status及httpMethod进行读写路由,路由的不到的返回HttpServletResponse.SC_SERVICE_UNAVAILABLE

小结

ServerStatusManager的init方法注册了ServerStatusUpdater,它实现了Runnable接口,其run方法执行refreshServerStatus;refreshServerStatus会判断consistencyService是否是available,如果是更新serverStatus为ServerStatus.UP,否则为ServerStatus.DOWN

以上就是nacos中ServerStatusManager的作用是什么,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注行业资讯频道。

方法 作用 接口 更多 知识 篇文章 路由 更新 实用 小结 就是 工作会 文章 状态 看吧 知识点 行业 详情 资讯 资讯频道 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 魔兽世界服务器怎么这么卡 宅易搭互联网科技有限公司 云服务器和视频服务器 网上商城买什么服务器 存储服务器内部构成 地方棋牌软件开发需要什么证 辽宁正规软件开发哪里好 电脑数据库在哪 天津智能软件开发报价价钱 sql连接到服务器 软件开发者选项权限 皖事通 获取服务器失败怎么办 网络安全周活动讲话 浏览器代理服务器有什么好处 在哪里找软件开发公司招学徒吗 小程序服务器阿里云价格 徐汇区特殊软件开发应用范围 ftp服务器部署网站 山东朗东网络技术有限公司 网络安全员资格证书有什么用 冕宁软件开发专业 dayz服务器怎么改名字 装机要不要买二手服务器内存 wps如何自动汇总数据库 全球网络技术 在哪里找软件开发公司招学徒吗 浙江大型软件开发配件 优化网络安全技术防范服务要大力 常用的软件开发的工具 服务器有病毒
0