Запуск программы Net Core на MacOS Launchd Startup Script - PullRequest
0 голосов
/ 14 ноября 2018

Я создал скрипт, который использовал поток, чтобы продолжать работать каждую минуту.Сценарий должен сообщить мне, если есть изменения в публичном IP.Это приложение NetCore:

static void Main(string[] args)
    {
        try
        {
            var timer = new System.Threading.Timer(e => CheckIP(), null,
                TimeSpan.Zero, TimeSpan.FromMinutes(1));

            Console.ReadLine();
        }
        catch (Exception e)
        {
            Console.WriteLine("Error Main(): " + e.Message);
        }
    }

public static void CheckIP()
    {
        try
        {
            string externalip = new WebClient().DownloadString("http://icanhazip.com");
            if (string.IsNullOrEmpty(_CurrentIp) || !_CurrentIp.Equals(externalip))
            {
                _CurrentIp = externalip;
                NotifyChanges(); //Notify me if IP is changed via some HttpClient post
                Console.WriteLine("At: " + DateTime.Now + " | " + externalip);
            }
        }
        catch (Exception e) {
            Console.WriteLine("Error (): " + e.Message);
        }
    }

Если я запускаю скрипт, используя: dotnet /Users/alvinalvin/Scripts/ReportIP.sh, он работает нормально.Это ReportIP.sh:

#!/bin/bash
/usr/local/share/dotnet/dotnet /Users/alvinalvin/Scripts/MyHome/MyHome.dll

Затем я использую launchd , чтобы запустить скрипт при запуске.Это / Library / LaunchDaemons / com.startup.plist

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">

<plist version="1.0">

  <dict>

    <key>Label</key>

    <string>com.startup</string>

    <key>ProgramArguments</key>

    <array>

       <string>/Users/alvinalvin/Scripts/ReportIP.sh</string>

    </array>

    <key>RunAtLoad</key>

    <true/>

    <key>KeepAlive</key>

    <true/>

    <key>StandardOutPath</key>

    <string>/tmp/startup.stdout</string>

    <key>StandardErrorPath</key>

    <string>/tmp/startup.stderr</string>

  </dict>

</plist>

Результат ошибки следующий:

(com.startup):Служба работала только в течение 0 секунд.Вытеснение респауна на 10 секунд.

Я полагаю, что это проблема:

  1. Невозможно запустить приложение с потоком в нем
  2. Console.ReadLine ()проблема в том, что он работает в фоновом режиме
  3. Console.WriteLine (), вызывая проблему, потому что нет консоли, на которой работает

Но я не уверен, что здесь происходит.Мне нужна помощь.

Есть ли способ добиться этого?

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...