千家信息网

zuul http请求跟踪方法

发表于:2025-12-02 作者:千家信息网编辑
千家信息网最后更新 2025年12月02日,这篇文章主要讲解了"zuul http请求跟踪方法",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"zuul http请求跟踪方法"吧!@Configur
千家信息网最后更新 2025年12月02日zuul http请求跟踪方法

这篇文章主要讲解了"zuul http请求跟踪方法",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"zuul http请求跟踪方法"吧!

@Configuration@ConditionalOnClass(name = "org.apache.http.client.HttpClient")@ConditionalOnProperty(name = "ribbon.httpclient.enabled", matchIfMissing = true)public class HttpClientRibbonConfiguration {    @Bean    @ConditionalOnMissingBean(HttpClientConnectionManager.class)    public HttpClientConnectionManager httpClientConnectionManager(        IClientConfig config,        ApacheHttpClientConnectionManagerFactory connectionManagerFactory) {      Integer maxTotalConnections = config.getPropertyAsInteger(          CommonClientConfigKey.MaxTotalConnections,          DefaultClientConfigImpl.DEFAULT_MAX_TOTAL_CONNECTIONS);      Integer maxConnectionsPerHost = config.getPropertyAsInteger(          CommonClientConfigKey.MaxConnectionsPerHost,          DefaultClientConfigImpl.DEFAULT_MAX_CONNECTIONS_PER_HOST);      Integer timerRepeat = config.getPropertyAsInteger(          CommonClientConfigKey.ConnectionCleanerRepeatInterval,          DefaultClientConfigImpl.DEFAULT_CONNECTION_IDLE_TIMERTASK_REPEAT_IN_MSECS);      Object timeToLiveObj = config          .getProperty(CommonClientConfigKey.PoolKeepAliveTime);      Long timeToLive = DefaultClientConfigImpl.DEFAULT_POOL_KEEP_ALIVE_TIME;      Object ttlUnitObj = config          .getProperty(CommonClientConfigKey.PoolKeepAliveTimeUnits);      TimeUnit ttlUnit = DefaultClientConfigImpl.DEFAULT_POOL_KEEP_ALIVE_TIME_UNITS;      if (timeToLiveObj instanceof Long) {        timeToLive = (Long) timeToLiveObj;      } else if (timeToLiveObj instanceof String) {        timeToLive = Long.valueOf((String)timeToLiveObj);      }      if (ttlUnitObj instanceof TimeUnit) {        ttlUnit = (TimeUnit) ttlUnitObj;      }      final HttpClientConnectionManager connectionManager = connectionManagerFactory          .newConnectionManager(false, maxTotalConnections,              maxConnectionsPerHost, timeToLive, ttlUnit, registryBuilder);      this.connectionManagerTimer.schedule(new TimerTask() {        @Override        public void run() {          connectionManager.closeExpiredConnections();        }      }, 30000, timerRepeat);      return connectionManager;    }    @Bean    @ConditionalOnMissingBean(CloseableHttpClient.class)    public CloseableHttpClient httpClient(ApacheHttpClientFactory httpClientFactory,                        HttpClientConnectionManager connectionManager, IClientConfig config) {      Boolean followRedirects = config.getPropertyAsBoolean(          CommonClientConfigKey.FollowRedirects,          DefaultClientConfigImpl.DEFAULT_FOLLOW_REDIRECTS);      Integer connectTimeout = config.getPropertyAsInteger(          CommonClientConfigKey.ConnectTimeout,          DefaultClientConfigImpl.DEFAULT_CONNECT_TIMEOUT);      RequestConfig defaultRequestConfig = RequestConfig.custom()          .setConnectTimeout(connectTimeout)          .setRedirectsEnabled(followRedirects).build();      this.httpClient = httpClientFactory.createBuilder().          setDefaultRequestConfig(defaultRequestConfig).          setConnectionManager(connectionManager).build();      return httpClient;    }}

感谢各位的阅读,以上就是"zuul http请求跟踪方法"的内容了,经过本文的学习后,相信大家对zuul http请求跟踪方法这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!

0