public static void Main(string[] args)
        {
            Log.Logger = new LoggerConfiguration()
                         .MinimumLevel.Debug()
                         .MinimumLevel.Override("Microsoft", LogEventLevel.Information)
                         .Enrich.FromLogContext()
                         .WriteTo.Console()
                         .CreateLogger();

            var isService = true;

            if (Debugger.IsAttached || args.Contains("--console"))
            {
                Log.Information("Setting isService to true");
                isService = false;
            }

            var pathToContentRoot = Directory.GetCurrentDirectory();

            if (isService)
            {
                var pathToExe = Process.GetCurrentProcess().MainModule.FileName;
                pathToContentRoot = Path.GetDirectoryName(pathToExe);
            }

            var filter = new MetricsFilter();

            filter.WhereContext(c => c == MetricsRegistry.RabbitMqContext);
            var webHostArgs = args.Where(arg => arg != "--console").ToArray();

            var host = WebHost.CreateDefaultBuilder(webHostArgs)
                       .ConfigureServices(services => services.AddAutofac())
                       .UseContentRoot(pathToContentRoot)
                       .UseMetrics(options => {
                options.EndpointOptions = endpointOptions => {
                    endpointOptions.MetricsEndpointOutputFormatter = new MetricsPrometheusTextOutputFormatter();
                };
            })
                       .UseStartup <Startup>()
                       .UseSerilog()
                       .Build();

            if (isService)
            {
                Log.Information("Running as a service");
                host.RunAsService();
            }
            else
            {
                Log.Information("Running as a console app");
                host.Run();
            }
        }
Exemplo n.º 2
0
        public static IWebHost BuildWebHost(string[] args)
        {
            var filter = new MetricsFilter();

            filter.WhereContext(c => c == MetricsRegistry.Context);

            return(WebHost.CreateDefaultBuilder(args)
                   .ConfigureMetricsWithDefaults(builder =>
            {
                builder.Filter.With(filter);
                builder.Report.ToInfluxDb("http://127.0.0.1:8086", "appmetricsreservoirs");
            })
                   .UseMetrics()
                   .UseStartup <Startup>()
                   .Build());
        }