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

做网站云服务器还是云虚拟主机优化推广公司哪家好

做网站云服务器还是云虚拟主机,优化推广公司哪家好,东莞大型网站建设哪家好,域名访问网站的知识当一台机器下线时,面临很多问题:如何将其从注册中心下线?如何清理释放资源?客户端拉取服务列表时也使用了本地缓存,如何及时更新本地缓存? 服务端机器的优雅下线需要使用ShutdownHook,这相当于添…

        当一台机器下线时,面临很多问题:如何将其从注册中心下线?如何清理释放资源?客户端拉取服务列表时也使用了本地缓存,如何及时更新本地缓存?

        服务端机器的优雅下线需要使用ShutdownHook,这相当于添加了一个关闭钩子,这个钩子是一个线程,它在JVM关闭时(即程序结束时)被调用,清理资源,优雅下机。

   public void clearAll() {log.info("addShutdownHook for clearAll");// 添加了一个关闭钩子,这个钩子是一个线程,它在JVM关闭时(即程序结束时)被调用,清理资源,优雅下机Runtime.getRuntime().addShutdownHook(new Thread(() -> {try {InetSocketAddress inetSocketAddress = new InetSocketAddress(InetAddress.getLocalHost().getHostAddress(), NettyRpcServer.PORT);CuratorUtils.clearRegistry(CuratorUtils.getZkClient(), inetSocketAddress);} catch (UnknownHostException ignored) {}// 操作完整、优雅,便于释放连接资源,便于自定义清理逻辑ThreadPoolFactoryUtil.shutDownAllThreadPool();}));}

          在钩子线程中需要编写从注册中心当中删除节点的逻辑,如下所示:

  // RPC Server端 本机所注册服务的缓存private static final Set<String> REGISTERED_PATH_SET = ConcurrentHashMap.newKeySet();public static void clearRegistry(CuratorFramework zkClient, InetSocketAddress inetSocketAddress) {REGISTERED_PATH_SET.stream().parallel().forEach(p -> {try {// 是本机在ZK注册的节点if (p.endsWith(inetSocketAddress.toString())) {// 根据路径名删除节点zkClient.delete().forPath(p);}} catch (Exception e) {log.error("clear registry for path [{}] fail", p);}});log.info("All registered services on the server are cleared:[{}]", REGISTERED_PATH_SET.toString());}

           在注册中心ZK当中删除节点之后,需要释放线程池资源:

  public static void shutDownAllThreadPool() {log.info("call shutDownAllThreadPool method");THREAD_POOLS.entrySet().parallelStream().forEach(entry -> {ExecutorService executorService = entry.getValue();// 停止接收新的任务,但已提交的任务会继续执行executorService.shutdown();log.info("shut down thread pool [{}] [{}]", entry.getKey(), executorService.isTerminated());try {// 等待线程池中的任务在指定的时间内完成。如果在指定时间内线程池未能终止,会抛出 InterruptedExceptionexecutorService.awaitTermination(10, TimeUnit.SECONDS);} catch (InterruptedException e) {log.error("Thread pool never terminated");// 指定时间内线程池未能终止,立即停止所有正在执行的任务executorService.shutdownNow();}});}

            自定义关闭线程池的逻辑可以更加优雅的实现线程池资源的释放。可以达到停止接受新的任务,继续在一定等待时间范围内执行已提交的任务,超出等待时间在强制终止线程池。

 

          

http://www.hrbkazy.com/news/24678.html

相关文章:

  • 昆明网站建设价格低推广网址
  • dedecms怎么把一个网站的文章导出导到另一个站里seo搜索引擎优化怎么做
  • 网站怎样做有利于seo无需下载直接进入的网站的代码
  • 有没有专门做线下活动的网站seo网站优化推广教程
  • theappbuilder外贸网站建设优化
  • 网商网站怎么做东莞营销网站建设优化
  • 网站被恶意刷流量优化排名工具
  • 某企业网站网页设计模板今日国内重大新闻事件
  • 网站建设时间表怎样做网站卖自己的产品
  • 买了域名怎么做网站百度联盟项目看广告挣钱
  • 网站设计与制作合同百度问答app下载
  • 广东网站建设开发做一个个人网站
  • 网站官网seo中文全称是什么
  • 免费网站建设品牌专业放心关键词优化参考价格
  • 做一些购物网站火星时代教育培训机构怎么样
  • flash网站模板中心开封网站seo
  • 做球服的网站有哪些网站设计是做什么的
  • 驾校网站建设方案厦门seo优化多少钱
  • 挂机宝 可以做网站站长之家seo工具
  • 学做效果图的网站全网媒体发布平台
  • 百度做网站怎么样怎么制作网页广告
  • 电子商务网站流程设计seo怎么刷关键词排名
  • 提供企业网站建设定制数字营销策略有哪些
  • 多语种网站建设开发域名注册平台哪个好
  • 建网站卖虚拟资源需要怎么做代做百度首页排名
  • 门户网站的特点和优势东莞seo技术
  • 网站设计策划书模板seo职业
  • 高价做单网站网页制作与设计
  • 学校网站做几级等保推广之家
  • 索菲亚全屋定制官方网站游戏推广员好做吗