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

做网站云服务器还是云虚拟主机个人接外包项目平台

做网站云服务器还是云虚拟主机,个人接外包项目平台,wp打开wordpress,温州网站的优化当一台机器下线时,面临很多问题:如何将其从注册中心下线?如何清理释放资源?客户端拉取服务列表时也使用了本地缓存,如何及时更新本地缓存? 服务端机器的优雅下线需要使用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.mmbaike.com/news/104602.html

相关文章:

  • 网站备案注销原因分销系统
  • 自己做的网站打开很慢seo是做什么工作的
  • 网站建设服务公谷歌paypal官网注册入口
  • 精美网站设计欣赏网站查询网
  • web毕业设计代做网站seo实战培训
  • 珠海学网站开发百度关键词推广方案
  • 山东住房城乡建设部网站国外常用的seo站长工具
  • 重庆seo外包平台个人网站如何优化关键词
  • 网站源码查询seo与sem的关系
  • 深圳场站建设发展有限公司蚂蚁bt
  • 哪里有做网站的单位刷网站关键词工具
  • wordpress 标签云插件下载宁波seo服务快速推广
  • 上海网络开发公司优化设计七年级下册数学答案
  • 外包 网站开发公司电脑编程培训学校
  • p2p网站开发的流程图seo规则
  • 禅城网站建设多少钱西安seo优化推广
  • 赣州网站建设方案百度学术官网
  • 网站开发公司 经营范围企业网络推广网站
  • 在线微信小程序seo百度快速排名
  • 房产公司网站建设方案ppt短链接在线生成官网
  • 网站建设报价单及项目收费明细表西安自动seo
  • 公司网站访问非法网站的作用seo的方法
  • 12306网站 谁做的优秀营销软文100篇
  • 高端制作网站哪家专业百度信息流投放技巧
  • 呼市建设委员会官方网站百度搜索入口网址
  • 哪些公司适合做线上推广qq关键词排名优化
  • 长沙个人做网站排名seo搜索优化软件
  • dede英文网站it培训机构出来能找到工作吗
  • 网站建设 从用户角度开始网络运营
  • 做垂直网站百度词条优化