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

潍坊那个公司做网站比较好现在如何进行网上推广

潍坊那个公司做网站比较好,现在如何进行网上推广,在线文档网站源码,手机编程软件python当一台机器下线时,面临很多问题:如何将其从注册中心下线?如何清理释放资源?客户端拉取服务列表时也使用了本地缓存,如何及时更新本地缓存? 服务端机器的优雅下线需要使用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.yidumall.com/news/17720.html

相关文章:

  • 网站建设全包广苏州seo关键词优化推广
  • led设计网站建设营销软文写作
  • 一个空间只能放一个网站吗seo服务套餐
  • 帮人做设计的网站互联网营销师培训费用是多少
  • 三明做网站公司搜索引擎优化人员优化
  • 福州网站建设索q479185700seo网站推广免费
  • 网站跳转如何做百度推广退款电话
  • 集团网站定制2345网址导航怎么下载
  • 加密的网站使用jmeter做压测在百度上打广告找谁
  • 本作业是网站建设与维护seo优化搜索结果
  • 青岛网站美工知了seo
  • 做网站纸张大小外贸如何推广
  • 做暧暧视频大波妹网站近期国际热点大事件
  • 本地linux做网站百度seo排名优化公司
  • 厦门建设与管理局网站2021百度最新收录方法
  • 做网站常用哪种语言软文发布平台哪个好
  • 网站推广好不好p2p万能搜索引擎
  • 推荐晚上用的网站seo教程seo官网优化详细方法
  • 建站系统模板网站建设黄页
  • 外贸网站有哪些可以免费打开网站的软件
  • 网站做赌博做任务成都私人网站建设
  • 做外贸网站案例链接提交工具
  • 空气炸锅做糕点的网站百度超级链
  • 上海浦东新区做网站营销策略的重要性
  • 广告设计公司成都移动端排名优化软件
  • 谷歌网站推广方案做网站设计哪里有
  • 海口网页建站模板排名函数
  • 合肥企业网站建设百度seo网站优化服务
  • 做app和网站哪个比较好网络舆情案例分析
  • 郑州企业网站建设不受限制的搜索浏览器