Передача аргументов рабочей службе из другого приложенияC#

Место общения программистов C#
Ответить
Anonymous
 Передача аргументов рабочей службе из другого приложения

Сообщение Anonymous »

У меня сейчас настроена рабочая служба, которая сейчас просто регистрирует события. У меня есть другое приложение, в котором я хотел бы запускать и останавливать рабочую службу по мере запуска и остановки этого приложения. Итак, я думаю, что в первом приложении я могу вызвать приложение рабочей службы с аргументами, как показано здесь:
using (ServiceController servcontol = new ServiceController("Worker Service"))
{
string[] args = new string[2];
args[0] = "info1";
args[1] = "info2";
servcontol.Start(args);
}

Таким образом, это приложение будет принимать безопасно зашифрованные данные, расшифровывать и передавать их рабочей службе в качестве аргументов. Чего я не могу понять, так это где и как в рабочей службе я получаю доступ к этим аргументам. Я знаю, что могу добавить данные в файл appsetting.json, но в идеале мне бы хотелось, чтобы динамические данные передавались первым приложением, чтобы передаваемая информация оставалась более безопасной.
Моя рабочая служба содержит файлы program.cs и worker.cs, как показано здесь — program.cs:
using Microsoft.Extensions.Logging.Configuration;
using Microsoft.Extensions.Logging.EventLog;
using Serilog;
using System.ServiceProcess;

var builder = Host.CreateApplicationBuilder(args);

builder.Services.AddWindowsService(options =>
{
options.ServiceName = "My Worker Service";
});

Log.Logger = new LoggerConfiguration()
.MinimumLevel.Debug()
.MinimumLevel.Override("Microsoft", Serilog.Events.LogEventLevel.Information)
.Enrich.FromLogContext()
.WriteTo.File(@"C:\Temp\Workerservice\Logfile.txt")
.CreateLogger();

try
{
Log.Information("Starting Service");
builder.Services.AddHostedService();

var host = builder.Build();
host.Run();
}
catch (Exception ex)
{
Log.Fatal(ex, "Issue starting service");
return;
}
finally
{
Log.CloseAndFlush(); // log anything in buffer before closing.
}

worker.cs выглядит следующим образом:
using Serilog;

namespace My_WorkerService_V1
{
public class Worker : BackgroundService
{
private readonly ILogger _logger;

public Worker(ILogger logger)
{
_logger = logger;
}

protected override async Task ExecuteAsync(CancellationToken stoppingToken)
{
while (!stoppingToken.IsCancellationRequested)
{
if (_logger.IsEnabled(LogLevel.Information))
{
_logger.LogInformation("WS running at: {time}", DateTimeOffset.Now);
}

// 20/10/25 basically SFTP code in here..

await Task.Delay(1000, stoppingToken);
}
}

public override Task StartAsync(CancellationToken cancellationToken)
{
return base.StartAsync(cancellationToken);
}

public override Task StopAsync(CancellationToken cancellationToken)
{
return base.StopAsync(cancellationToken);
}
}
}


Подробнее здесь: https://stackoverflow.com/questions/797 ... pplication
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»