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

网站 术语wordpress怎么开启下载收费功能

网站 术语,wordpress怎么开启下载收费功能,logo成品效果图网站,泰州住房城乡建设网站1.背景 之前写一篇文章Spring Boot集成disruptor快速入门demo#xff0c;有网友留言如下图#xff1a; 针对网友的留言#xff0c;那么我们如何解决这个问题呢 Spring-Boot应用停机时#xff0c;如何保证其内存消息都处理完成#xff1f; 2.解决方法 方法其实挺简单的有网友留言如下图 针对网友的留言那么我们如何解决这个问题呢 Spring-Boot应用停机时如何保证其内存消息都处理完成 2.解决方法 方法其实挺简单的disruptor有优雅停机方法不用我们自己去实现逻辑只需要调用 disruptor.shutdown() ;就可以实现优雅关闭。 1.禁用kill -9 使用kill -9命令强制终止进程在某些情况下可能会导致数据丢失或资源未正确释放。以下是一些原因和替代方案帮助你安全地停止应用程序 为什么避免使用kill -9 数据丢失kill -9会立即终止进程不会给应用程序任何机会去保存数据或完成正在进行的操作。 资源泄漏进程被强制终止后可能无法正确释放内存、文件句柄或网络连接等资源。 不执行清理逻辑应用程序通常在关闭时执行一些清理逻辑如关闭数据库连接、写入日志等kill -9会跳过这些步骤。 2.优雅停机方案 Spring Boot可以引入这个包 dependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-actuator/artifactId /dependency 放开shutdown接口 management:endpoints:web:exposure:include: *endpoint:shutdown:enabled: true server:port: 8088然后post http://127.0.0.1:8088/actuator/shutdown 实现优雅停机但是spring boot 2.3以下停止后不能停止api继续对外。我们可以使用过滤器来禁止api对外提供服务手动设置HttpServletResponse.SC_SERVICE_UNAVAILABLE package com.et.disruptor.config;import org.springframework.stereotype.Component;import javax.servlet.*; import javax.servlet.http.HttpServletResponse; import java.io.IOException; import java.util.concurrent.atomic.AtomicBoolean;Component public class GracefulShutdownFilter implements Filter {private final AtomicBoolean shuttingDown new AtomicBoolean(false);Overridepublic void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)throws IOException, ServletException {if (shuttingDown.get()) {((HttpServletResponse) response).setStatus(HttpServletResponse.SC_SERVICE_UNAVAILABLE);return;}chain.doFilter(request, response);}public void startShutdown() {shuttingDown.set(true);} } DisposableBean是Spring框架中的一个接口用于在Spring容器销毁Bean时执行一些自定义的清理逻辑。实现这个接口的Bean会在容器关闭时自动调用其destroy()方法。这对于需要在应用程序关闭时释放资源或执行其他清理操作的Bean非常有用。 package com.et.disruptor.config;import org.springframework.beans.factory.DisposableBean; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component;Component public class GracefulShutdownManager implements DisposableBean {Autowiredprivate GracefulShutdownFilter shutdownFilter;AutowiredMqManager mqManager;Overridepublic void destroy() throws Exception {// reject new requestsshutdownFilter.startShutdown();//graceful shutdown DisruptormqManager.shutdownDisruptor(); // wait all events to complete// wait all your self-definite task finishwaitForTasksToComplete();}private void waitForTasksToComplete() throws InterruptedException {System.out.println(Waiting for tasks to complete...);// use CountDownLatch or other//mock task processThread.sleep(100000);} } 3.disruptor优雅关闭 如果不想显示的调用shutdown 也可以用注解PreDestroy package com.et.disruptor.config;import com.et.disruptor.event.HelloEventFactory; import com.et.disruptor.event.HelloEventHandler; import com.et.disruptor.model.MessageModel; import com.lmax.disruptor.BlockingWaitStrategy; import com.lmax.disruptor.RingBuffer; import com.lmax.disruptor.dsl.Disruptor; import com.lmax.disruptor.dsl.ProducerType; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration;import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors;Configuration public class MqManager {private static DisruptorMessageModel disruptor;Bean(ringBuffer)public RingBufferMessageModel messageModelRingBuffer() {//define the thread pool for consumer message hander Disruptor touch the consumer event to process by java.util.concurrent.ExecutorSerivceExecutorService executor Executors.newFixedThreadPool(2);//define Event FactoryHelloEventFactory factory new HelloEventFactory();//ringbuffer byte sizeint bufferSize 1024 * 256;disruptor new Disruptor(factory, bufferSize, executor, ProducerType.SINGLE, new BlockingWaitStrategy());//set consumer eventdisruptor.handleEventsWith(new HelloEventHandler());//start disruptor threaddisruptor.start();//gain ringbuffer ringto product eventRingBufferMessageModel ringBuffer disruptor.getRingBuffer();return ringBuffer;}//PreDestroypublic void shutdownDisruptor() {if (disruptor ! null) {System.out.println(close Disruptor...);disruptor.shutdown(); //cl0se Disruptor}} } shudown方法源码 public void shutdown(long timeout, TimeUnit timeUnit) throws TimeoutException {long timeOutAt System.currentTimeMillis() timeUnit.toMillis(timeout);do {if (!this.hasBacklog()) {this.halt();return;}} while(timeout 0L || System.currentTimeMillis() timeOutAt);throw TimeoutException.INSTANCE; } 这里会等到所有内存消息全部处理完 private boolean hasBacklog() {long cursor this.ringBuffer.getCursor();Sequence[] var3 this.consumerRepository.getLastSequenceInChain(false);int var4 var3.length;for(int var5 0; var5 var4; var5) {Sequence consumer var3[var5];if (cursor consumer.get()) {return true;}}return false; } 以上只是一些关键代码所有代码请参见下面代码仓库 代码仓库 GitHub - Harries/springboot-demo: a simple springboot demo with some components for example: redis,solr,rockmq and so on.(Disruptor) 3.测试 启动Spring Boot应用post 请求http://127.0.0.1:8088/actuator/shutdown实现优雅停止访问http://127.0.0.1:8088/hello会报503错误后台会等待Disruptor处理内存消息后台等待处理其他的异步任务最后关闭Spring Boot应用 4.引用 https://medium.com/contact.technovisionconsulting/how-to-achieve-a-graceful-shutdown-in-spring-boot-ec93d55916edSpring Boot关闭时如何确保内存里面的mq消息被消费完 | Harries Blog™
http://www.tj-hxxt.cn/news/225102.html

相关文章:

  • 公司网站建设的重要性网站开发 实战
  • 左侧导航网站替网站做任务怎么做的
  • 济南做网站哪好一条 wordpress
  • 网站建设设计制作包头什么是网站名称
  • 北京市住房城乡建设部网站首页建设银行国际互联网网站是什么
  • 网站域名绑定上海新闻
  • 网站的建设思路黑龙江公共资源交易网官网
  • 无锡网络公司无锡网站推广湛江关键词优化报价
  • 2在线做网站在线生成个人网站免费观看
  • 在意派建设好网站后我网站关键词太多
  • 网站的投资和建设项目企业做网站能赚钱么
  • 做果盘网站做游戏破解版的网站
  • 如何创建网站和域名成都私人做网站建设的公司
  • 适合服务行业做推广的网站微信商户平台
  • 国外的自建网站怎么做中企动力是国企性质吗
  • 合肥高端网站建设公司哪家好百色seo快速排名
  • 比较好的前端网站网站的外链接数
  • 合肥网站排名提升最好看免费观看高清视频了
  • 网站运营每天做的网站设计与网页配色实例精讲pdf
  • 蓝色大气网站源码企业宣传手册模板免费
  • 做金融怎么进基金公司网站即便你卖的是
  • 那个网站可以接做网页私活网站建设服务费计入会计科目
  • 福清市建设局监督站网站企业推广平台
  • 广东省建设合同备案网站电子产品网站建设
  • 北京营销型网站推广樱花12e56
  • 手机网站建设目标邦拓网站建设
  • 手机号注册的网站工信部网站验证码
  • 个人网站注册流程2022年国际十大新闻
  • wordpress手机网站插件十大正规兼职平台
  • 做画册好的国外网站推荐安亭公司网站建设