namespace ASC.ElasticSearch; [Singletone] public class Client { public ElasticClient Instance { get { if (_client != null) { return _client; } lock (_locker) { if (_client != null) { return _client; } using var scope = _serviceProvider.CreateScope(); var CoreConfiguration = _serviceProvider.GetService(); var launchSettings = CoreConfiguration.GetSection(Tenant.DefaultTenant) ?? _settings; var uri = new Uri(string.Format("{0}://{1}:{2}", launchSettings.Scheme, launchSettings.Host, launchSettings.Port)); var settings = new ConnectionSettings(new SingleNodeConnectionPool(uri)) .RequestTimeout(TimeSpan.FromMinutes(5)) .MaximumRetries(10) .ThrowExceptions(); if (_logger.IsTraceEnabled) { settings.DisableDirectStreaming().PrettyJson().EnableDebugMode(r => { //Log.Trace(r.DebugInformation); //if (r.RequestBodyInBytes != null) //{ // Log.TraceFormat("Request: {0}", Encoding.UTF8.GetString(r.RequestBodyInBytes)); //} if (r.HttpStatusCode != null && (r.HttpStatusCode == 403 || r.HttpStatusCode == 500) && r.ResponseBodyInBytes != null) { _logger.TraceFormat("Response: {0}", Encoding.UTF8.GetString(r.ResponseBodyInBytes)); } }); } try { if (Ping(new ElasticClient(settings))) { _client = new ElasticClient(settings); _client.Ingest.PutPipeline("attachments", p => p .Processors(pp => pp .Attachment(a => a.Field("document.data").TargetField("document.attachment")) )); } } catch (Exception e) { _logger.Error(e); } return _client; } } } private static volatile ElasticClient _client; private static readonly object _locker = new object(); private readonly ILog _logger; private readonly Settings _settings; private readonly IServiceProvider _serviceProvider; public Client(IOptionsMonitor option, IServiceProvider serviceProvider, Settings settings) { _logger = option.Get("ASC.Indexer"); _settings = settings; _serviceProvider = serviceProvider; } public bool Ping() { return Ping(Instance); } private bool Ping(ElasticClient elasticClient) { if (elasticClient == null) { return false; } var result = elasticClient.Ping(new PingRequest()); _logger.DebugFormat("Ping {0}", result.DebugInformation); return result.IsValid; } }