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

建筑效果图网站推荐钦州网站建设排名

建筑效果图网站推荐,钦州网站建设排名,手机网站收录,得力企业网站建设在分布式系统中,traceId 需要在服务之间传递,以确保整个请求链路的日志能够被追踪。下面我们通过一个具体的例子,展示如何通过 A 服务调用 B 服务时传递 traceId,并确保日志中能够正确记录 traceId。 实现思路 A 服务生成 traceId…

在分布式系统中,traceId 需要在服务之间传递,以确保整个请求链路的日志能够被追踪。下面我们通过一个具体的例子,展示如何通过 A 服务调用 B 服务时传递 traceId,并确保日志中能够正确记录 traceId


实现思路

  1. A 服务生成 traceId:在 A 服务的 HandlerInterceptor 中生成 traceId,并将其放入 MDC

  2. A 服务调用 B 服务时传递 traceId:在 A 服务调用 B 服务时,将 traceId 通过 HTTP 头传递给 B 服务。

  3. B 服务接收 traceId:在 B 服务中,通过 HandlerInterceptor 或过滤器从 HTTP 头中提取 traceId,并将其放入 MDC

  4. 日志输出 traceId:在 A 服务和 B 服务的日志配置中,确保 traceId 能够被输出。


代码实现

1. A 服务代码
(1) TraceIdInterceptor 生成 traceId

java

复制

import org.slf4j.MDC;
import org.springframework.stereotype.Component;
import org.springframework.web.servlet.HandlerInterceptor;import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.util.UUID;@Component
public class TraceIdInterceptor implements HandlerInterceptor {private static final String TRACE_ID = "traceId";@Overridepublic boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {// 生成唯一的 traceIdString traceId = UUID.randomUUID().toString();// 将 traceId 放入 MDCMDC.put(TRACE_ID, traceId);return true;}@Overridepublic void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {// 请求完成后清理 MDC 中的 traceIdMDC.remove(TRACE_ID);}
}
(2) 注册 TraceIdInterceptor

java

复制

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;@Configuration
public class WebConfig implements WebMvcConfigurer {@Autowiredprivate TraceIdInterceptor traceIdInterceptor;@Overridepublic void addInterceptors(InterceptorRegistry registry) {registry.addInterceptor(traceIdInterceptor);}
}
(3) 调用 B 服务时传递 traceId

在 A 服务中,使用 RestTemplate 或 Feign 调用 B 服务时,将 traceId 添加到 HTTP 头中。

java

复制

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.slf4j.MDC;
import org.springframework.http.HttpHeaders;
import org.springframework.http.HttpMethod;
import org.springframework.http.RequestEntity;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;import java.net.URI;@RestController
public class AServiceController {private static final Logger logger = LoggerFactory.getLogger(AServiceController.class);private final RestTemplate restTemplate = new RestTemplate();@GetMapping("/call-b-service")public String callBService() {// 获取当前请求的 traceIdString traceId = MDC.get("traceId");logger.info("A Service - Calling B Service with traceId: {}", traceId);// 设置 HTTP 头,传递 traceIdHttpHeaders headers = new HttpHeaders();headers.add("X-Trace-Id", traceId);// 调用 B 服务RequestEntity<Void> request = new RequestEntity<>(headers, HttpMethod.GET, URI.create("http://localhost:8081/b-service"));ResponseEntity<String> response = restTemplate.exchange(request, String.class);return "A Service received response from B Service: " + response.getBody();}
}

2. B 服务代码
(1) TraceIdFilter 接收 traceId

在 B 服务中,使用过滤器从 HTTP 头中提取 traceId,并将其放入 MDC

java

复制

import org.slf4j.MDC;
import org.springframework.stereotype.Component;import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;
import java.util.UUID;@Component
public class TraceIdFilter implements Filter {private static final String TRACE_ID = "traceId";@Overridepublic void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)throws IOException, ServletException {HttpServletRequest httpRequest = (HttpServletRequest) request;// 从 HTTP 头中获取 traceIdString traceId = httpRequest.getHeader("X-Trace-Id");if (traceId == null || traceId.isEmpty()) {// 如果头中没有 traceId,生成一个新的traceId = UUID.randomUUID().toString();}// 将 traceId 放入 MDCMDC.put(TRACE_ID, traceId);try {chain.doFilter(request, response);} finally {// 请求完成后清理 MDC 中的 traceIdMDC.remove(TRACE_ID);}}@Overridepublic void init(FilterConfig filterConfig) throws ServletException {}@Overridepublic void destroy() {}
}
(2) 注册 TraceIdFilter

java

复制

import org.springframework.boot.web.servlet.FilterRegistrationBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;@Configuration
public class FilterConfig {@Beanpublic FilterRegistrationBean<TraceIdFilter> traceIdFilter() {FilterRegistrationBean<TraceIdFilter> registrationBean = new FilterRegistrationBean<>();registrationBean.setFilter(new TraceIdFilter());registrationBean.addUrlPatterns("/*");return registrationBean;}
}
(3) B 服务接口

java

复制

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.slf4j.MDC;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;@RestController
public class BServiceController {private static final Logger logger = LoggerFactory.getLogger(BServiceController.class);@GetMapping("/b-service")public String bService() {// 获取当前请求的 traceIdString traceId = MDC.get("traceId");logger.info("B Service - Processing request with traceId: {}", traceId);return "Hello from B Service!";}
}

3. 日志配置

在 A 服务和 B 服务的 logback.xml 中,配置日志输出格式,确保 traceId 能够被打印出来。

xml

复制

<configuration><appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender"><encoder><pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - [%X{traceId}] %msg%n</pattern></encoder></appender><root level="info"><appender-ref ref="STDOUT" /></root>
</configuration>

运行 HTML


测试流程

  1. 启动 A 服务和 B 服务。

  2. 访问 A 服务的 /call-b-service 接口。

  3. 查看 A 服务和 B 服务的日志输出,确保 traceId 一致。

A 服务日志示例:

复制

2023-10-01 12:00:00.000 [http-nio-8080-exec-1] INFO  AServiceController - [123e4567-e89b-12d3-a456-426614174000] A Service - Calling B Service with traceId: 123e4567-e89b-12d3-a456-426614174000

B 服务日志示例:

复制

2023-10-01 12:00:00.100 [http-nio-8081-exec-1] INFO  BServiceController - [123e4567-e89b-12d3-a456-426614174000] B Service - Processing request with traceId: 123e4567-e89b-12d3-a456-426614174000

总结

通过上述实现,我们完成了 A 服务调用 B 服务时的 traceId 传递和日志跟踪。traceId 通过 HTTP 头在服务间传递,并通过 MDC 在日志中输出,确保整个请求链路的日志能够被追踪。

http://www.dtcms.com/wzjs/574387.html

相关文章:

  • 高端大气酒店网站源码国内工程机械行业网站建设现状
  • 长沙多用户商城网站建设时尚网站网页设计
  • 一般网站用什么做的wordpress zidai模板
  • 建设网站地图秦皇岛网站建设报价
  • 电子商务网站建设教学总结给个免费的网址
  • wap网站乱码网站建设管理维护责任书
  • 济宁网站建设专家app开发公司一般多少人
  • 企业为什么需要网站也可以用
  • 芜湖网站建设全包仅需800元eclipse用来做网站前端
  • 文具网站建设广告公司名字免费起名大全
  • 网站怎么进行网络推广对网站和网页的认识
  • 网站建设织梦源码怎样设计app软件
  • 网站建设维护预算wordpress口语主题
  • 网站建设服装项目设计书wordpress 简书主题
  • 三河网站seo成都代理注册公司电话
  • 玉树营销网站建设服务wordpress 纯静态
  • 桐城网站设计微信如何做有趣的短视频网站
  • 网站开发和房屋装修公司哪家好
  • WordPress的站内地图中国做网站的网站
  • 网络教育网站建设方案loft设计方案
  • 移动通网站建设班级网站的建设
  • 保定市住房和城乡建设厅网站公众号文章模板素材
  • 建设网站的分析鞍山吧百度贴吧
  • 房产网站建设网站推广html网站标签
  • 怎么查找网站建设大酒店网站源代码
  • 海口模板建站平台网站建设的技术体会
  • 怎么做网站页面深圳西乡
  • 个人做网站需要备案吗汽车可以做哪些广告视频网站
  • 做网站和微信小程序东莞百度快速排名优化
  • 阿里云服务器怎么放网站奢侈品+++网站建设方案