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

小偷程序做的网站能用吗万网博通

小偷程序做的网站能用吗,万网博通,常州市建设局网站电话,国家重大项目建设库网站一、需求背景与方案选型 在电商系统压力测试中,我们发现某些接口响应时间超过2秒,但难以快速定位瓶颈。本文将通过四种方案实现接口耗时统计: 方案优点适用场景Spring AOP非侵入式、灵活度高需要详细方法级统计Filter简单易用、全局覆盖快速…

一、需求背景与方案选型

在电商系统压力测试中,我们发现某些接口响应时间超过2秒,但难以快速定位瓶颈。本文将通过四种方案实现接口耗时统计:

方案优点适用场景
Spring AOP非侵入式、灵活度高需要详细方法级统计
Filter简单易用、全局覆盖快速实现入口统计
Interceptor结合请求上下文需要获取请求参数
Micrometer+Prometheus生产级监控、可视化长期性能监控分析

二、AOP方案实现(推荐)

2.1 添加依赖

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-aop</artifactId>
</dependency>

2.2 耗时统计切面

@Aspect
@Component
@Slf4j
public class ApiTimeAspect {// 定义切入点:所有Controller的public方法@Pointcut("execution(public * com.example..controller.*.*(..))")public void apiPointcut() {}@Around("apiPointcut()")public Object around(ProceedingJoinPoint joinPoint) throws Throwable {long startTime = System.currentTimeMillis();Object result;try {result = joinPoint.proceed();} finally {long cost = System.currentTimeMillis() - startTime;recordCost(joinPoint, cost);}return result;}private void recordCost(ProceedingJoinPoint joinPoint, long cost) {MethodSignature signature = (MethodSignature) joinPoint.getSignature();String methodName = signature.getDeclaringTypeName() + "." + signature.getName();log.info("API耗时统计 || 方法: {} || 耗时: {}ms", methodName, cost);// 可扩展存储到数据库// monitorService.saveApiCost(methodName, cost);}
}

2.3 自定义注解实现精准统计

@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface TimeMonitor {String value() default "";
}// 在切面中修改切入点表达式
@Pointcut("@annotation(com.example.annotation.TimeMonitor)")
public void annotationPointcut() {}// 使用示例
@RestController
public class OrderController {@TimeMonitor("创建订单接口")@PostMapping("/orders")public Order createOrder() {// 业务逻辑}
}

三、Filter方案实现(快速接入)

3.1 实现Filter

@WebFilter(urlPatterns = "/*")
@Slf4j
public class TimeCostFilter implements Filter {@Overridepublic void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {long start = System.currentTimeMillis();try {chain.doFilter(request, response);} finally {HttpServletRequest req = (HttpServletRequest) request;String uri = req.getRequestURI();long cost = System.currentTimeMillis() - start;log.info("请求路径: {} || 耗时: {}ms", uri, cost);}}
}

3.2 启用Filter扫描

@SpringBootApplication
@ServletComponentScan
public class Application {public static void main(String[] args) {SpringApplication.run(Application.class, args);}
}

四、Interceptor方案实现(结合请求参数)

4.1 实现Interceptor

@Component
@Slf4j
public class TimeInterceptor implements HandlerInterceptor {private static final ThreadLocal<Long> TIME_HOLDER = new ThreadLocal<>();@Overridepublic boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) {TIME_HOLDER.set(System.currentTimeMillis());return true;}@Overridepublic void afterCompletion(HttpServletRequest request,HttpServletResponse response,Object handler, Exception ex) {long start = TIME_HOLDER.get();long cost = System.currentTimeMillis() - start;TIME_HOLDER.remove();String params = getRequestParams(request);log.info("请求路径: {}?{} || 耗时: {}ms", request.getRequestURI(), params, cost);}private String getRequestParams(HttpServletRequest request) {return request.getParameterMap().entrySet().stream().map(entry -> entry.getKey() + "=" + Arrays.toString(entry.getValue())).collect(Collectors.joining("&"));}
}

4.2 注册Interceptor

@Configuration
public class WebConfig implements WebMvcConfigurer {@Autowiredprivate TimeInterceptor timeInterceptor;@Overridepublic void addInterceptors(InterceptorRegistry registry) {registry.addInterceptor(timeInterceptor).addPathPatterns("/api/**");}
}

五、生产级监控方案(Prometheus集成)

5.1 添加依赖

<dependency><groupId>io.micrometer</groupId><artifactId>micrometer-registry-prometheus</artifactId>
</dependency>

5.2 配置监控指标

@Configuration
public class MetricsConfig {@Beanpublic TimedAspect timedAspect(MeterRegistry registry) {return new TimedAspect(registry);}
}// 在Controller方法上添加注解
@RestController
public class ProductController {@Timed(value = "product.detail.time", description = "商品详情接口耗时")@GetMapping("/products/{id}")public Product getDetail(@PathVariable Long id) {// 业务逻辑}
}

5.3 Prometheus配置示例

scrape_configs:- job_name: 'spring_app'metrics_path: '/actuator/prometheus'static_configs:- targets: ['localhost:8080']

六、性能优化建议

  1. 异步日志写入:避免日志输出阻塞请求线程
@Async
public void saveCostLog(String method, long cost) {// 异步存储到数据库
}
  1. 采样率控制:高并发场景下按比例采样
if (random.nextDouble() < 0.1) { // 10%采样率recordCost(joinPoint, cost);
}
  1. 异常处理:确保统计逻辑不破坏主流程
try {recordCost(...);
} catch (Exception e) {log.error("耗时统计异常", e);
}

七、方案对比与选型建议

维度AOP方案Filter方案Interceptor方案Prometheus方案
实现复杂度
数据粒度方法级请求级请求级方法级
性能影响低(纳秒级)
扩展性
生产可维护性极高

选型建议

  • 快速验证:Filter方案
  • 精准统计:AOP+自定义注解
  • 生产监控:Prometheus+Micrometer

扩展阅读

  • Spring AOP官方文档
  • Micrometer监控指南
  • 阿里巴巴Java诊断工具Arthas

掌握接口耗时统计技巧,让系统性能优化有据可依! 🚀


文章转载自:

http://7z8vgcnq.dgckn.cn
http://m2Dagfbz.dgckn.cn
http://WBCEkkPn.dgckn.cn
http://Q81xZPdc.dgckn.cn
http://DbBT22lC.dgckn.cn
http://y18Jq7HG.dgckn.cn
http://COHqt1LY.dgckn.cn
http://ZttpaYRG.dgckn.cn
http://Sn2CJBY6.dgckn.cn
http://ZkC98avo.dgckn.cn
http://gQrvqH7X.dgckn.cn
http://Ow2lHT52.dgckn.cn
http://ViUgZ5TS.dgckn.cn
http://rJkSBmGM.dgckn.cn
http://5MfCGwxT.dgckn.cn
http://LkafAhvt.dgckn.cn
http://54QOY9Z4.dgckn.cn
http://X5PbYMuY.dgckn.cn
http://SKhudMjM.dgckn.cn
http://jjMGlzZt.dgckn.cn
http://9NIdFxIL.dgckn.cn
http://ruaBBKBd.dgckn.cn
http://MBtfLltv.dgckn.cn
http://Ms4o9RHy.dgckn.cn
http://PfqCRK3F.dgckn.cn
http://IaYpDJv4.dgckn.cn
http://NYRC1n2C.dgckn.cn
http://ueJxJITG.dgckn.cn
http://GrwAL2We.dgckn.cn
http://fkwYSvtF.dgckn.cn
http://www.dtcms.com/wzjs/657796.html

相关文章:

  • 成都网站建设 seo建筑工程资质合作
  • 佛山市网站建设平台友链通
  • 不收费的网站有哪些黑龙江建设网ca数字证书如何注销
  • 建设网站商城需要多少费用建设限额哪里看
  • 个人购物网站需要备案吗国内公司名字可以做国外网站
  • 企业网站建设东莞怎么样在百度做网站
  • 怎样优化手机网站做网站排版
  • 数码产品网站建设策划书太湖手机网站建设
  • 收费企业邮箱哪家好seo确定关键词
  • 菏泽网站开发新网站提交百度收录
  • 网站代码规范性网站建设最好公司
  • 淄博手机网站wordpress网页loder插件
  • 吴中网站建设济南市公共资源交易中心官网
  • 网站建设 运维 管理包括怎么做韩剧网站的翻译
  • 给公司做网站的费用入什么科目网站推广方式案例
  • 江西城乡建设部网站首页wordpress相册主题
  • 如何做好网站的推广工作广州公司注册资本减资流程及步骤
  • gta5买房网站建设中wordpress做分类网站
  • 创建网站平台十堰网站整站优化公司
  • 电商网站h5模板下载大有网网站
  • 汉源网站建设用vue-cli做的网站
  • 吉林大学建设工程学院 旧网站怎么建一个卖东西的网站
  • 轴承 网站建设 企炬百度搜题网页版入口
  • 织梦cms小说网站采集矢量图片素材库
  • 吉粤建设工程股份有限公司网站单页营销网站怎么做
  • seo整站优化新站快速排名毕业设计ppt答辩模板
  • 帮别人备案网站吗wordpress 开源项目
  • 企业网站策划书机械设计网站推荐
  • 网站建设需求报价明细怎么做可以直播的网站吗
  • 最专业网站建设模版建网站