WedX - журнал о программировании и компьютерных науках

Перезапуск приложения WinForm?

У меня есть приложение, которое работает на моем компьютере и компьютерах моих коллег по работе. Я иногда выкладываю обновления для этого приложения и хочу, чтобы приложение автоматически обнаруживало это (возможно, через базу данных), закрывало и снова открывало для установки новых обновлений.

Я знаю, как я могу закрыть приложение, но не знаю, как я могу снова открыть его, потому что, когда оно не запущено, я не знаю, как выполнить какой-либо код...

23.08.2010

  • Это звучит как щелчок один раз, особенно если вы используете ссылку, которую я разместил на ответ Флетчера, чтобы проверить, пока программа работает. Добавьте комментарий, если clickonce по какой-то причине у вас не работает. 23.08.2010

Ответы:


1

ClickOnce очень хорошо справляется с обновлением приложения. Я не вижу здесь проблемы, если пользователь обнаружит, что приложение не работает (поскольку вы внесли изменения на стороне сервера, что гарантирует им обновление клиента), он перезапустит приложение и получит запрос от ClickOnce. механизм обновления, сообщающий о наличии обновления (если оно было настроено) после повторного запуска приложения.

Единственный способ узнать, должно ли приложение обновляться, пока рассматриваемое приложение все еще работает, — это опросить файл развертывания ClickOnce на сервере и сравнить номер версии с текущим развертыванием. Не рекомендуется.

Редактировать:

Еще один способ гарантировать, что у ваших пользователей всегда будет самая последняя версия, — это не включать постоянный файл развертывания и заставить пользователя всегда запускаться со страницы запуска на вашем веб-сайте. Это только раздаст самую последнюю и самую лучшую версию.

23.08.2010
  • msdn.microsoft.com/en-us/library/ms404263.aspx идет о том, как настроить clickonce для проверки обновлений через определенные промежутки времени. 23.08.2010
  • ClickOnce продолжает меня удивлять. Я продолжаю находить сообщения об этих маленьких функциях. 23.08.2010
  • ClickOnce и метод ручной проверки обновлений, описанный в этой ссылке MS, великолепны, однако по какой-то причине метод Application.restart() закрывает приложение, но затем фактически не возвращает его снова. 02.09.2016

  • 2

    Как насчет создания небольшого приложения для обновления. Когда ваше приложение обнаруживает обновление, оно запускает приложение обновления и закрывается. Приложение обновления загружает и устанавливает обновление, а затем перезапускает основное приложение и закрывается.

    В качестве альтернативы, если приложение может обновляться при открытии, почему его нужно выключать? Не может ли он просто освободить любые ресурсы, которые он использует, и т. д., и выполнить обновление.

    23.08.2010
  • Недостатком того, когда он открывается, является то, что пользователь может держать приложение открытым в течение длительного времени, в течение нескольких недель подряд, если он переводит свою машину в спящий режим или блокирует ее после завершения работы с ней, а не выключается. Иногда требуется что-то более активное 23.08.2010
  • Я согласен. Но, похоже, его приложение не нужно закрывать для обновления, поскольку оно обновляется при запуске — просто вопрос, почему оно не может обновляться в любое время с небольшим управлением ресурсами. 23.08.2010

  • 3

    Процесс, который вам действительно нужен, выглядит примерно так:

    1. Приложение обнаруживает, что требуется обновление, и выполняет приложение обновления, а затем завершает работу.
    2. Приложение Update загружает и устанавливает обновление
    3. Обновление приложения перезапускает «основное» приложение

    «Приложению обновления» могут потребоваться права администратора для запуска, если вы обновляете файлы на компьютере с Vista/Windows7 из-за UAC, поэтому вы, вероятно, захотите встроить манифест, чтобы решить эту проблему.

    Чтобы запустить другой процесс, вам нужно выполнить следующий код: System.Diagnostics.Process.Start(), например:

    Process p = new Process();
    p.StartInfo.FileName = "C:\\Windows\\System32\cmd.exe";
    p.Start();
    
    23.08.2010

    4

    Если вы используете ClickOnce (и ваш тег предполагает, что это так?), вы можете настроить его так, чтобы ваше приложение проверяло наличие обновлений при запуске.

    23.08.2010

    5

    У меня была похожая проблема, но моя была связана с неуправляемой утечкой памяти, которую я не мог найти в приложении, которое должно работать 24/7. С заказчиком я договорился, что безопасное время для перезапуска приложения — 03:00, если потребление памяти превышает заданное значение.

    Я попробовал Application.Restart, но поскольку он, похоже, использует какой-то механизм, который запускает новый экземпляр, когда он уже запущен, я выбрал другую схему. Я использовал трюк, при котором дескрипторы файловой системы сохраняются до тех пор, пока процесс, создавший их, не умрет. Итак, из приложения я сбросил файл на диск и не Dispose() дескриптор. Я также использовал файл для отправки исполняемого файла «я» и начального каталога (чтобы добавить гибкости).

    Код:

    _restartInProgress = true;
    string dropFilename = Path.Combine(Application.StartupPath, "restart.dat");
    StreamWriter sw = new StreamWriter(new FileStream(dropFilename, FileMode.Create, FileAccess.ReadWrite, FileShare.ReadWrite));
    sw.WriteLine(Application.ExecutablePath);
    sw.WriteLine(Application.StartupPath);
    sw.Flush();
    Process.Start(new ProcessStartInfo
    {
        FileName = Path.Combine(Application.StartupPath, "VideoPhill.Restarter.exe"),
        WorkingDirectory = Application.StartupPath,
        Arguments = string.Format("\"{0}\"", dropFilename)
    });
    Close();
    

    Close() в конце инициирует завершение работы приложения, а дескриптор файла, который я использовал для StreamWriter здесь, будет оставаться открытым до тех пор, пока процесс действительно не умрет. Затем...

    Restarter.exe вступает в действие. Он ПЫТАЕТСЯ прочитать файл в эксклюзивном режиме, не позволяя ему получить доступ до тех пор, пока основное приложение не будет мертво, затем запускает основное приложение, удаляет файл и существует. Я думаю, что это не может быть проще:

    static void Main(string[] args)
    {
        string filename = args[0];
        DateTime start = DateTime.Now;
        bool done = false;
        while ((DateTime.Now - start).TotalSeconds < 30 && !done)
        {
            try
            {
                StreamReader sr = new StreamReader(new FileStream(filename, FileMode.Open, FileAccess.ReadWrite, FileShare.ReadWrite));
                string[] runData = new string[2];
                runData[0] = sr.ReadLine();
                runData[1] = sr.ReadLine();
                Thread.Sleep(1000);
                Process.Start(new ProcessStartInfo { FileName = runData[0], WorkingDirectory = runData[1] });
                sr.Dispose();
                File.Delete(filename);
                done = true;
            }
            catch (Exception ex)
            {
                Console.WriteLine(ex.Message);
            }
            Thread.Sleep(1000);
        }
    }
    
    09.04.2011
  • Это кажется хорошим ответом на проблему Application.Restart(), однако при использовании ClickOnce запуск исполняемого файла приложения напрямую вызывает другие проблемы. Возможно, мне придется изучить, как правильно перезапустить приложение ClickOnce в рамках описанной выше структуры. 02.09.2016
  • Новые материалы

    Объяснение документов 02: BERT
    BERT представил двухступенчатую структуру обучения: предварительное обучение и тонкая настройка. Во время предварительного обучения модель обучается на неразмеченных данных с помощью..

    Как проанализировать работу вашего классификатора?
    Не всегда просто знать, какие показатели использовать С развитием глубокого обучения все больше и больше людей учатся обучать свой первый классификатор. Но как только вы закончите..

    Работа с цепями Маркова, часть 4 (Машинное обучение)
    Нелинейные цепи Маркова с агрегатором и их приложения (arXiv) Автор : Бар Лайт Аннотация: Изучаются свойства подкласса случайных процессов, называемых дискретными нелинейными цепями Маркова..

    Crazy Laravel Livewire упростил мне создание электронной коммерции (панель администратора и API) [Часть 3]
    Как вы сегодня, ребята? В этой части мы создадим CRUD для данных о продукте. Думаю, в этой части я не буду слишком много делиться теорией, но чаще буду делиться своим кодом. Потому что..

    Использование машинного обучения и Python для классификации 1000 сезонов новичков MLB Hitter
    Чему может научиться машина, глядя на сезоны новичков 1000 игроков MLB? Это то, что исследует это приложение. В этом процессе мы будем использовать неконтролируемое обучение, чтобы..

    Учебные заметки: создание моего первого пакета Node.js
    Это мои обучающие заметки, когда я научился создавать свой самый первый пакет Node.js, распространяемый через npm. Оглавление Глоссарий I. Новый пакет 1.1 советы по инициализации..

    Забудьте о Matplotlib: улучшите визуализацию данных с помощью умопомрачительных функций Seaborn!
    Примечание. Эта запись в блоге предполагает базовое знакомство с Python и концепциями анализа данных. Привет, энтузиасты данных! Добро пожаловать в мой блог, где я расскажу о невероятных..


    Для любых предложений по сайту: [email protected]