|
@@ -20,7 +20,7 @@ namespace FastGithub.Http
|
|
|
/// <summary>
|
|
|
/// 非首次生命周期
|
|
|
/// </summary>
|
|
|
- private readonly TimeSpan nextLifeTime = TimeSpan.FromMinutes(1d);
|
|
|
+ private readonly TimeSpan nextLifeTime = TimeSpan.FromSeconds(100d);
|
|
|
|
|
|
/// <summary>
|
|
|
/// LifetimeHttpHandler清理器
|
|
@@ -30,7 +30,7 @@ namespace FastGithub.Http
|
|
|
/// <summary>
|
|
|
/// LazyOf(LifetimeHttpHandler)缓存
|
|
|
/// </summary>
|
|
|
- private readonly ConcurrentDictionary<DomainConfig, Lazy<LifetimeHttpHandler>> httpHandlerLazyCache = new();
|
|
|
+ private readonly ConcurrentDictionary<LifeTimeKey, Lazy<LifetimeHttpHandler>> httpHandlerLazyCache = new();
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
@@ -45,20 +45,31 @@ namespace FastGithub.Http
|
|
|
/// <summary>
|
|
|
/// 创建httpClient
|
|
|
/// </summary>
|
|
|
+ /// <param name="domain"></param>
|
|
|
/// <param name="domainConfig"></param>
|
|
|
/// <returns></returns>
|
|
|
- public HttpClient CreateHttpClient(DomainConfig domainConfig)
|
|
|
+ public HttpClient CreateHttpClient(string domain, DomainConfig domainConfig)
|
|
|
{
|
|
|
- var lifetimeHttpHandlerLazy = this.httpHandlerLazyCache.GetOrAdd(domainConfig, CreateLifetimeHttpHandlerLazy);
|
|
|
- var lifetimeHttpHandler = lifetimeHttpHandlerLazy.Value;
|
|
|
+ var lifeTimeKey = new LifeTimeKey(domain, domainConfig);
|
|
|
+ var lifetimeHttpHandler = this.httpHandlerLazyCache.GetOrAdd(lifeTimeKey, CreateLifetimeHttpHandlerLazy).Value;
|
|
|
return new HttpClient(lifetimeHttpHandler, disposeHandler: false);
|
|
|
|
|
|
- Lazy<LifetimeHttpHandler> CreateLifetimeHttpHandlerLazy(DomainConfig domainConfig)
|
|
|
+ Lazy<LifetimeHttpHandler> CreateLifetimeHttpHandlerLazy(LifeTimeKey lifeTimeKey)
|
|
|
{
|
|
|
- return new Lazy<LifetimeHttpHandler>(() => this.CreateLifetimeHttpHandler(domainConfig, this.firstLiftTime), true);
|
|
|
+ return new Lazy<LifetimeHttpHandler>(() => this.CreateLifetimeHttpHandler(lifeTimeKey, this.firstLiftTime), true);
|
|
|
}
|
|
|
}
|
|
|
|
|
|
+ /// <summary>
|
|
|
+ /// 创建LifetimeHttpHandler
|
|
|
+ /// </summary>
|
|
|
+ /// <param name="lifeTimeKey"></param>
|
|
|
+ /// <param name="lifeTime"></param>
|
|
|
+ /// <returns></returns>
|
|
|
+ private LifetimeHttpHandler CreateLifetimeHttpHandler(LifeTimeKey lifeTimeKey, TimeSpan lifeTime)
|
|
|
+ {
|
|
|
+ return new LifetimeHttpHandler(this.domainResolver, lifeTimeKey, lifeTime, this.OnLifetimeHttpHandlerDeactivate);
|
|
|
+ }
|
|
|
|
|
|
/// <summary>
|
|
|
/// 当有httpHandler失效时
|
|
@@ -66,26 +77,14 @@ namespace FastGithub.Http
|
|
|
/// <param name="lifetimeHttpHandler">httpHandler</param>
|
|
|
private void OnLifetimeHttpHandlerDeactivate(LifetimeHttpHandler lifetimeHttpHandler)
|
|
|
{
|
|
|
- var domainConfig = lifetimeHttpHandler.DomainConfig;
|
|
|
- this.httpHandlerLazyCache[domainConfig] = CreateLifetimeHttpHandlerLazy(domainConfig);
|
|
|
+ var lifeTimeKey = lifetimeHttpHandler.LifeTimeKey;
|
|
|
+ this.httpHandlerLazyCache[lifeTimeKey] = CreateLifetimeHttpHandlerLazy(lifeTimeKey);
|
|
|
this.httpHandlerCleaner.Add(lifetimeHttpHandler);
|
|
|
|
|
|
- Lazy<LifetimeHttpHandler> CreateLifetimeHttpHandlerLazy(DomainConfig domainConfig)
|
|
|
+ Lazy<LifetimeHttpHandler> CreateLifetimeHttpHandlerLazy(LifeTimeKey lifeTimeKey)
|
|
|
{
|
|
|
- return new Lazy<LifetimeHttpHandler>(() => this.CreateLifetimeHttpHandler(domainConfig, this.nextLifeTime), true);
|
|
|
+ return new Lazy<LifetimeHttpHandler>(() => this.CreateLifetimeHttpHandler(lifeTimeKey, this.nextLifeTime), true);
|
|
|
}
|
|
|
}
|
|
|
-
|
|
|
- /// <summary>
|
|
|
- /// 创建LifetimeHttpHandler
|
|
|
- /// </summary>
|
|
|
- /// <param name="domainConfig"></param>
|
|
|
- /// <param name="lifeTime"></param>
|
|
|
- /// <returns></returns>
|
|
|
- private LifetimeHttpHandler CreateLifetimeHttpHandler(DomainConfig domainConfig, TimeSpan lifeTime)
|
|
|
- {
|
|
|
- var httpClientHandler = new HttpClientHandler(domainConfig, this.domainResolver);
|
|
|
- return new LifetimeHttpHandler(httpClientHandler, lifeTime, this.OnLifetimeHttpHandlerDeactivate);
|
|
|
- }
|
|
|
}
|
|
|
}
|