You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

292 lines
12KB

  1. using AspectCore.Extensions.DependencyInjection;
  2. using HealthMonitor.Common;
  3. using HealthMonitor.Common.helper;
  4. using HealthMonitor.Core.Cache;
  5. using HealthMonitor.Core.Context;
  6. using HealthMonitor.Core.Dal.EfCoreImpl;
  7. using HealthMonitor.Core.Dal;
  8. //using HealthMonitor.Core.Dal.Factory;
  9. using HealthMonitor.Core.DbLog;
  10. using HealthMonitor.Core.Operator;
  11. using HealthMonitor.Core.Operator.Redis;
  12. using HealthMonitor.Model.Config;
  13. using HealthMonitor.Service.Biz.db;
  14. using HealthMonitor.WebApi.Configs;
  15. using HealthMonitor.WebApi.DbLog;
  16. using Microsoft.AspNetCore.Mvc;
  17. using Microsoft.EntityFrameworkCore;
  18. using Microsoft.Extensions.Configuration;
  19. using Microsoft.Extensions.DependencyInjection;
  20. using Microsoft.Extensions.Options;
  21. using Microsoft.OpenApi.Models;
  22. using HealthMonitor.WebApi.Swagger;
  23. using HealthMonitor.Service.Cache;
  24. using TelpoDataService.Util.Clients;
  25. using HealthMonitor.Service.Sub;
  26. using HealthMonitor.Service.Resolver;
  27. using HealthMonitor.Service.Resolver.Factory;
  28. using HealthMonitor.Service.Resolver.Interface;
  29. using Serilog;
  30. using Serilog.Core;
  31. using HealthMonitor.WebApi.HttpLog;
  32. using Microsoft.Extensions.Http;
  33. using Microsoft.Extensions.DependencyInjection.Extensions;
  34. using HealthMonitor.Core.Context.Taos;
  35. using HealthMonitor.Core.Dal.Taos;
  36. namespace HealthMonitor.WebApi
  37. {
  38. public class Program
  39. {
  40. public static void Main(string[] args)
  41. {
  42. //选择配置文件appsetting.json
  43. var config = new ConfigurationBuilder()
  44. .SetBasePath(Directory.GetCurrentDirectory())
  45. .AddJsonFile("appsettings.json", optional: true, reloadOnChange: true)
  46. .Build();
  47. Log.Logger = new LoggerConfiguration()
  48. .ReadFrom.Configuration(config).Enrich.WithThreadInfo()
  49. .CreateLogger();
  50. var builder = WebApplication.CreateBuilder(args);
  51. // Add services to the container.
  52. builder.Services.AddHttpClient(Consts.DEFAULT_HTTPCLIENT_NAME, c =>
  53. {
  54. c.Timeout = TimeSpan.FromSeconds(10); //超时限制
  55. c.DefaultRequestHeaders.Add("Accept", "application/json");
  56. //c.DefaultRequestHeaders.Connection.Add("keep-alive");
  57. });
  58. // builder.Services.Configure<TDengineServiceConfig>(builder.Configuration.GetSection("TDengineServiceConfig"));
  59. builder.Services.AddSingleton<HttpHelper>();
  60. builder.Services.AddSingleton<TDengineService>();
  61. builder.Services.AddControllers();
  62. // Learn more about configuring Swagger/OpenAPI at https://aka.ms/aspnetcore/swashbuckle
  63. builder.Services.AddEndpointsApiExplorer();
  64. builder.Services.AddSwaggerGen();
  65. #region scoped MySQL 数据库
  66. builder.Services // gps_card
  67. .AddDbContextPool<GpsCardContext>((sp, options) =>
  68. {
  69. var loggerFactory = sp.GetRequiredService<EfCoreLoggerFactory>();
  70. var mySqlCon = builder.Configuration.GetConnectionString("GpsCard_Connection_String");
  71. var serverVersion = ServerVersion.AutoDetect(mySqlCon);
  72. options.UseMySql(mySqlCon, serverVersion)
  73. .UseLoggerFactory(loggerFactory);
  74. }, poolSize: 64) // health_monitor
  75. .AddDbContextPool<HealthMonitorContext>((sp, options) =>
  76. {
  77. var loggerFactory = sp.GetRequiredService<EfCoreLoggerFactory>();
  78. var mySqlCon = builder.Configuration.GetConnectionString("HealthMonitor_Connection_String");
  79. var serverVersion = ServerVersion.AutoDetect(mySqlCon);
  80. options.UseMySql(mySqlCon, serverVersion)
  81. .UseLoggerFactory(loggerFactory);
  82. }, poolSize: 64) ;
  83. builder.Services
  84. .AddScoped<IGpsCardDataAccessor, EfCoreDataAccessor>(sp =>
  85. {
  86. var context = sp.GetRequiredService<GpsCardContext>();
  87. return new EfCoreDataAccessor(context);
  88. })
  89. .AddScoped<IHealthMonitorDataAccessor, EfCoreDataAccessor>(sp =>
  90. {
  91. var context = sp.GetRequiredService<HealthMonitorContext>();
  92. return new EfCoreDataAccessor(context);
  93. });
  94. #endregion
  95. #region Taos TDengine 数据库
  96. builder.Services // td healthmonitor
  97. .AddDbContextPool<HealthMonitorTaosDataContext>((sp, options) =>
  98. {
  99. var loggerFactory = sp.GetRequiredService<EfCoreLoggerFactory>();
  100. var connStr = builder.Configuration.GetConnectionString("HealthMonitor_Taos_Connection_String");
  101. options.UseTaos(connStr)
  102. .UseLoggerFactory(loggerFactory);
  103. }, poolSize: 64);
  104. builder.Services.AddScoped<IHealthMonitorTaosDataAccessor, EfCoreDataAccessor>(sp =>
  105. {
  106. var context = sp.GetRequiredService<HealthMonitorTaosDataContext>();
  107. return new EfCoreDataAccessor(context);
  108. });
  109. #endregion
  110. #region AOP
  111. //builder.Services.Configure<RedisConfig>(builder.Configuration.GetSection("Redis"));
  112. builder.Services
  113. .Configure<ApiBehaviorOptions>(options =>
  114. {
  115. options.SuppressModelStateInvalidFilter = true;
  116. })
  117. .Configure<RedisConfig>(builder.Configuration.GetSection("Redis"))
  118. .Configure<TDengineServiceConfig>(builder.Configuration.GetSection("TDengineServiceConfig"))
  119. .Configure<ServiceConfig>(builder.Configuration.GetSection("ServiceConfig"));
  120. builder.Services
  121. .AddSingleton<IEfCoreLoggerProvider, EfCoreLogProvider>()
  122. .AddSingleton<IDurableEntityManager, DurableEntityManager>()
  123. .AddSingleton<EfCoreLoggerFactory>(sp =>
  124. {
  125. var provider = sp.GetRequiredService<IEfCoreLoggerProvider>();
  126. return new EfCoreLoggerFactory(new[] { provider });
  127. });
  128. //builder.Services.AddSingleton<IDurableEntityManager, DurableEntityManager>();
  129. //builder.Services.AddSingleton<EfCoreLoggerFactory>(sp =>
  130. //{
  131. // var provider = sp.GetRequiredService<IEfCoreLoggerProvider>();
  132. // return new EfCoreLoggerFactory(new[] { provider });
  133. //});
  134. //builder.Services
  135. // .AddSingleton<GpsCardAccessorFactory>()
  136. // .AddSingleton<HealthMonitorAccessorFactory>();
  137. //builder.Services.AddSingleton<HealthMonitorAccessorFactory>();
  138. builder.Services
  139. .AddSingleton<IGpsCardOperatorManager, GpsCardOperatorRedisManager>()
  140. .AddSingleton<IHealthMonitorOperatorManager, HealthMonitorOperatorRedisManager>();
  141. //builder.Services.AddSingleton<IHealthMonitorOperatorManager, HealthMonitorOperatorRedisManager>();
  142. //用AspectCore替换默认的IOC容器
  143. builder.Host.UseServiceProviderFactory(new DynamicProxyServiceProviderFactory());
  144. #endregion
  145. #region Cache
  146. builder.Services
  147. .AddSingleton<PersonCacheManager>()
  148. .AddSingleton<BloodPressReferenceValueCacheManager>();
  149. #endregion
  150. #region TelpoDataServices
  151. builder.Services.AddTelpoDataServices(opt =>
  152. {
  153. opt.TelpoDataUrl = builder.Configuration.GetSection("ServiceConfig:TelpoDataUrl").Value;
  154. });
  155. #endregion
  156. #region Worker
  157. builder.Services.AddSingleton<MsgQueueManager>();
  158. builder.Services.AddSingleton<IResolverFactory, ResolverFactory>();
  159. builder.Services.AddSingleton<BloodpressResolver>();
  160. builder.Services.AddSingleton<PackageProcess>();
  161. builder.Services
  162. .AddSingleton<TDengineDataSubcribe>()
  163. .AddHostedService<Worker>();
  164. #endregion
  165. builder.Host.UseSerilog();
  166. builder.Services.Replace(ServiceDescriptor.Singleton<IHttpMessageHandlerBuilderFilter, CustomLoggingFilter>());
  167. // Register the Swagger generator, defining 1 or more Swagger documents
  168. builder.Services.AddSwaggerGen(c =>
  169. {
  170. //c.SwaggerDoc(AppConsts.SWAGGER_DOC_GpsCard, new OpenApiInfo { Title = "GpsCard模块", Version = "v1", Description = "gps_card数据库服务" }); //分组显示
  171. c.SwaggerDoc(AppConsts.SWAGGER_DOC_HealthMonitor, new OpenApiInfo { Title = "HealthMonitor模块", Version = "v1", Description = "health_monitor数据库服务" }); //分组显示
  172. c.DocumentFilter<EnumDocumentFilter>();
  173. //var utilXmlFile = Path.Combine(AppContext.BaseDirectory, "HealthMonitor.Util.xml");
  174. //var webapiXmlFile = Path.Combine(AppContext.BaseDirectory, "HealthMonitor.WebApi.xml");
  175. //c.IncludeXmlComments(utilXmlFile, true);
  176. //c.IncludeXmlComments(webapiXmlFile, true);
  177. });
  178. var app = builder.Build();
  179. // Configure the HTTP request pipeline.
  180. //if (app.Environment.IsDevelopment())
  181. //{
  182. // app.UseSwagger();
  183. // app.UseSwaggerUI();
  184. //}
  185. string prefix = string.Empty;
  186. //if (!app.Environment.IsDebugOrDevelop())
  187. //{
  188. // prefix = optConfigAppSettings.Value.NginxPrefix;
  189. // if (string.IsNullOrWhiteSpace(prefix)) prefix = SERVICE_PREFIX;
  190. //}
  191. // Enable middleware to serve generated Swagger as a JSON endpoint.
  192. app.UseSwagger(c =>
  193. {
  194. c.PreSerializeFilters.Add((swagger, httpReq) =>
  195. {
  196. var scheme = httpReq.Headers.TryGetValue("X-Forwarded-Proto", out var v2) ? v2.ToString() : httpReq.Scheme;
  197. swagger.Servers = new List<OpenApiServer> { new OpenApiServer { Url = $"{scheme}://{httpReq.Host}/{prefix}" } };
  198. });
  199. c.RouteTemplate = "/{documentName}/api-docs/";
  200. });
  201. // Enable middleware to serve swagger-ui (HTML, JS, CSS, etc.),
  202. // specifying the Swagger JSON endpoint.
  203. app.UseSwaggerUI(c =>
  204. {
  205. string sub = string.IsNullOrEmpty(prefix) ? "" : $"/{prefix}";
  206. //c.SwaggerEndpoint($"{sub}/{AppConsts.SWAGGER_DOC_GpsCard}/api-docs/", "GpsCard模块"); //分组显示
  207. c.SwaggerEndpoint($"{sub}/{AppConsts.SWAGGER_DOC_HealthMonitor}/api-docs/", "HealthMonitor模块"); //分组显示
  208. c.RoutePrefix = string.Empty;
  209. });
  210. // redis default
  211. var csredis = new CSRedis.CSRedisClient(app.Services.GetService<IOptions<RedisConfig>>()!.Value.ToString());
  212. RedisHelper.Initialization(csredis);
  213. // redis db7
  214. var csredisDb7Con = app.Services.GetService<IOptions<RedisConfig>>()!.Value;
  215. csredisDb7Con.DefaultDatabase = 7;
  216. csredisDb7Con.Prefix = "TELPO";
  217. var csredisDb7 = new CSRedis.CSRedisClient(csredisDb7Con.ToString());
  218. RedisHelperDb7.Initialization(csredisDb7);
  219. app.UseHttpsRedirection();
  220. app.UseAuthorization();
  221. app.MapControllers();
  222. app.Run();
  223. }
  224. }
  225. }