千家信息网

nacos中ServerStatusManager的作用是什么

发表于:2024-09-21 作者:千家信息网编辑
千家信息网最后更新 2024年09月21日,本篇文章给大家分享的是有关nacos中ServerStatusManager的作用是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。S
千家信息网最后更新 2024年09月21日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安全错误 数据库的锁怎样保障安全 海康摄像头服务器增强型端口 黑龙江软件开发代理商共同合作 网络安全等级如何确定 科技大学互联网 深圳程序软件开发需要多少钱 徐汇区品质数据库服务清单 表针倒转打一个网络安全用语 网络安全教育网上师生互动 win11服务器哪个版本最好 怎么画数据库表结构 广州餐饮软件开发费用是多少 国泰君安全行情服务器 数据库分析设计怎么写 服务器系统安全日志查看 泡泡云个人云服务器 魔法觉醒预下载服务器 网络安全机制的意义 观看 护苗网络安全课 活动 前端都是用什么软件开发的 机关网络安全讲话材料 软件开发过程中进行检查软件 应用系统数据库无柱状图 mc服务器装备有bug 广丰软件开发 小程序开发 数据库 僵尸毁灭工程服务器停止运行 通用软件开发工程师 笔试 菲律宾游戏软件开发 知网数据库中的网页资源更新速度 大话西游手游时间服务器收费吗
0