Компьютерный форум OSzone.net  

Компьютерный форум OSzone.net (http://forum.oszone.net/index.php)
-   Программирование и базы данных (http://forum.oszone.net/forumdisplay.php?f=21)
-   -   Реконнект VPN и перезапуск служб в C# и CMD (http://forum.oszone.net/showthread.php?t=257294)

VVolf 28-03-2013 10:21 2120539

Реконнект VPN и перезапуск служб в C# и CMD
 
Приветствую всех!

Столкнулся с, необъяснимой для меня, проблемой, может кто-нибудь сможет растолковать причину?

Предыстория:
Дома 2 компа, в первый (основной) приходит интернет от провайдера и он раздает его на wi-fi точку доступа и второй комп. На основном стоит Win 8 и на нем наблюдается проблема отсутствия реконнекта VPN при обрыве связи и он не хочет сразу раздавать интернет, пока не перезагрузишь службу "SharedAccess".
Для решения проблемы в начале создал bat-файл в котором выполняются 3 простых действия: подключение VPN и остановка / запуск службы "SharedAccess".

Текст файла:
Код:

rasdial VpnName UserName Password
echo net stop SharedAccess && net start SharedAccess

Работает все отлично, VPN подключается и интернет сразу начинает раздаваться. Проблема в том, что его можно засунуть максимум в автозагрузку, что бы при загрузке интернет подключался, либо использовать при обрыве связи (вручную запустить).
Следующим шагом решил создать приложение которое постоянно, с неким промежутком, пингует 8.8.8.8 и, при длительном отсутствии ответа, реконнектит VPN и перезапускает службы, в общем делает то же самое что и bat-файл.

Часть текста, который за это у меня отвечает:
Код:

System.Diagnostics.Process.Start("rasdial.exe", "VpnName /d"); // Отключаем VPN, на случай если он просто подвис.
System.Diagnostics.Process.Start("rasdial.exe", "VpnName UserName Password"); // Подключаем VPN
 
// Создаем отдельный поток в котором будет перезапускаться служба расшаривания интерната
Thread serviceRestart = new Thread(new ThreadStart(delegate
{
                    ServiceController service = new ServiceController("SharedAccess"); // Инициализируем экземпляр ServiceController и связываем его со службой расшаривания интернет (SharedAccess)
                    // Пробуем остановить службу
                    try
                    {
                        service.Stop(); // Останавливаем службу
                        service.WaitForStatus(ServiceControllerStatus.Stopped, new TimeSpan(0, 1, 0)); // Ждем в течении 1 минуты переход службы в остановленное состояние
                    }
                    // Если не получилось пишем ошибка в лог файл
                    catch (Exception ex)
                    {
                        System.IO.File.AppendAllText(@"BTReconnect_log.txt", "Остановка службы неудалась, ошибка: " + ex.Message + ". Время: " + DateTime.Now + "\n"); // Пишем текст ошибки в файл
                    }
                    finally
                    {
                        // Пробуем запустить службу
                        try
                        {
                            service.Start(); // Запускаем службу
                            service.WaitForStatus(ServiceControllerStatus.Running, new TimeSpan(0, 1, 0)); // Ждем в течении 1 минуты переход службы в запущенное состояние
                        }
                        // Если что-то не получилось пишем ошибка в лог файл
                        catch (Exception ex)
                        {
                            System.IO.File.AppendAllText(@"BTReconnect_log.txt", "Запуск службы неудался, ошибка: " + ex.Message + ". Время: " + DateTime.Now + "\n"); // Пишем текст ошибки в файл
                        }
                        finally
                        {
                            // Если служба работает, пишем в лог состояние после перезапуска VPN соединения и попытки перезапуска службы
                            if (service.Status == ServiceControllerStatus.Running)
                                System.IO.File.AppendAllText(@"BTReconnect_log.txt", "Служба запущена. Время: " + DateTime.Now + "\n");
 
                            System.IO.File.AppendAllText(@"BTReconnect_log.txt", "===> *************** <===\n\n"); // Дописываем в файл разделить
                        }
                    }
                }));
 
                serviceRestart.Start(); // Запускаем поток

Суть проблемы в следующем:
Созданное приложение, вроде как, функционирует, т.е. пингует адрес 8.8.8.8 , при разрыве соединения реконнектит интернет и перезапускает службы, но есть большое НО:
Интернет на основном компьютере начинает работать с большими задержками, тот же адрес (8.8.8.8) пингуется через раз и нет раздачи инета на второй комп и точку доступа.

Помогите понять, где косяк в приложении?

P.S. Работающий батник тоже пытался запускать через приложение, результат тот же, сеть работает с перебоями и нет раздачи интернета.

При необходимости могу выложить весь проект.

Delirium 28-03-2013 15:23 2120738

Цитата:

Цитата VVolf
приложение которое постоянно, с неким промежутком, пингует 8.8.8.8 »

Хорошо, а проверка того, что предыдущие проверки закончились, производится? Ведь может получиться так, что проверки и перезапуски "подвисли", а тут подошла след. проверка, она наложилась на предыдущую и покатился ком... Возможно, из-за этого идут перебои. Служба постоянно ребутится, связь прерывается.
Для теста могу предложить только убрать проверку по интервалу и запускать вручную, предварительно проверив состояние служб.

VVolf 28-03-2013 15:42 2120764

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

Delirium 29-03-2013 02:03 2121195

Немного по логике.
Цитата:

Цитата VVolf
try
{
service.Stop(); // Останавливаем службу
service.WaitForStatus(ServiceControllerStatus.Stopped, new TimeSpan(0, 1, 0)); // Ждем в течении 1 минуты переход службы в остановленное состояние
} »

Цитата:

Цитата VVolf
finally
{
// Пробуем запустить службу
try
{
service.Start(); // Запускаем службу
service.WaitForStatus(ServiceControllerStatus.Running, new TimeSpan(0, 1, 0)); // Ждем в течении 1 минуты переход службы в запущенное состояние
} »

В первом try идет попытка остановить службу. Допустим, WaitForStatus вывалилась с ошибкой. Мы пишем ошибку в лог (catch) и затем в finally пытаемся стартануть службу, которая не ответила своевременно. Мне кажется, надо в finally убивать в жесткую службу, предварительно сделав проверку на ее статус.

Цитата:

Цитата VVolf
Проблема в том, что его можно засунуть максимум в автозагрузку, что бы при загрузке интернет подключался, либо использовать при обрыве связи »

А почему бы не затолкать в планировщик?

VVolf 29-03-2013 11:33 2121351

В планировщик не затолкать, потому что в программе реализована еще и индикация состояния сети, батник этого не сделает.

Вот что еще вывел тестовым путем:
если создать батник с таким текстом:

Код:

@echo off
:loop
ping ya.ru -n 6 || (rasdial VpnName UserName Password && (net stop SharedAccess && net start SharedAccess))
goto loop

и запустить его как bat-файл, то все отрабатывает нормально, т.е. соединение перезапускается вместе со службами и идет раздача на второй компьютер.
А если этот файл сконвертировать в exe (использовал Advanced BAT to EXE Converter) и запустить, то происходит то же, что и с приложением созданным в C# - соединение переподключается, но сеть работает с задержками и нет раздачи интернет на второй компьютер.

Поэтому появился следующий вопрос:
Есть ли какие-нибудь ограничения в Windows вообще или только в Win 8 на запуск VPN соединений или перезагрузки служб приложением .exe? Или быть может нужны дополнительные аргументы для запуска?

VVolf 29-03-2013 16:02 2121562

Еще апдейт информации! )
Тупит служба "SharedAccess", т.е. если ее отключить после реконнекта и не включать, то сеть работает стабильно, пинг ровный (но нет раздачи интернет на второй комп), а если включить, даже с помощью консоли, пинг начинает прерываться.
Есть у кого-нибудь идеи почему так может быть и как с этим бороться?

Delirium 30-03-2013 00:11 2121915

Цитата:

Цитата VVolf
Есть ли какие-нибудь ограничения »

Да нет, на это нет никаких ограничений.
Вообще ситуация странная. Можно проверить еще вот что: SharedAccess зависит от нескольких служб, возможно какая то из них(например, диспетчер подключений удаленного доступа) при его рестарте не работает?

Ну и совсем не в тему вопрос: А нельзя приобрести маршрутизатор простенький рублей за 900, дабы все проблемы исчезли?

VVolf 01-04-2013 09:44 2123266

Доброе утро!

Согласен, ситуация совсем странная. Все необходимые для работы "SharedAccess" службы включены, да и не в них по идее дело, т.к. если через bat-файл все нормально работает.
Простенький маршрутизатор не подходит, т.к. пока ни один маршрутизатор не давал такую же скорость передачи данных как по схеме от компьютера компьютеру через сетевую карту. А на дорогой пока денег жалко.
+ дело еще в том, что я только начал учить C# и хочется разобраться в проблеме, что бы в будущем не натыкаться на эти же грабли.

Delirium 01-04-2013 14:03 2123468

VVolf, да проблема то в том, что твой код вполне корректен, если не считать того нюанса, что я указывал выше. Попробуй сделать так: практически после каждой строки пиши в текстовик лог действия. Прямо после каждой строки с пояснением. А когда будут косяки, проанализируй лог. Может быть какая либо операция по порядку не отрабатывает или еще что.
Можешь, если хочешь, весь проект сюда или еще куда выложить, я посмотрю.

VVolf 01-04-2013 17:34 2123677

Вложений: 1
Лог есть, пишет все что происходит в файл. По файлу видно что все отрабатывает :-/
Проект во вложении, буду очень признателен если посмотришь.


Время: 10:55.

Время: 10:55.
© OSzone.net 2001-