PDA

Показать полную графическую версию : Реконнект VPN и перезапуск служб в C# и CMD


VVolf
28-03-2013, 10:21
Приветствую всех!

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

Предыстория:
Дома 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
приложение которое постоянно, с неким промежутком, пингует 8.8.8.8 »
Хорошо, а проверка того, что предыдущие проверки закончились, производится? Ведь может получиться так, что проверки и перезапуски "подвисли", а тут подошла след. проверка, она наложилась на предыдущую и покатился ком... Возможно, из-за этого идут перебои. Служба постоянно ребутится, связь прерывается.
Для теста могу предложить только убрать проверку по интервалу и запускать вручную, предварительно проверив состояние служб.

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

Delirium
29-03-2013, 02:03
Немного по логике.
try
{
service.Stop(); // Останавливаем службу
service.WaitForStatus(ServiceControllerStatus.Stopped, new TimeSpan(0, 1, 0)); // Ждем в течении 1 минуты переход службы в остановленное состояние
} »
finally
{
// Пробуем запустить службу
try
{
service.Start(); // Запускаем службу
service.WaitForStatus(ServiceControllerStatus.Running, new TimeSpan(0, 1, 0)); // Ждем в течении 1 минуты переход службы в запущенное состояние
} »

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

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

VVolf
29-03-2013, 11:33
В планировщик не затолкать, потому что в программе реализована еще и индикация состояния сети, батник этого не сделает.

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

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

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

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

VVolf
01-04-2013, 09:44
Доброе утро!

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

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

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




© OSzone.net 2001-2012