Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

(시리즈 글이 4개 있습니다.)
개발 환경 구성: 491. 윈도우에 OpenVPN 설치 - 서버 측 구성
; https://www.sysnet.pe.kr/2/0/12224

개발 환경 구성: 492. 윈도우에 OpenVPN 설치 - 클라이언트 측 구성
; https://www.sysnet.pe.kr/2/0/12225

개발 환경 구성: 493. OpenVPN의 네트워크 구성
; https://www.sysnet.pe.kr/2/0/12226

개발 환경 구성: 515. OpenVPN - 재부팅 후 ICS(Internet Connection Sharing) 기능이 동작 안하는 문제
; https://www.sysnet.pe.kr/2/0/12325




OpenVPN - 재부팅 후 ICS(Internet Connection Sharing) 기능이 동작 안하는 문제

OpenVPN 서비스를,

OpenVPN의 네트워크 구성
; https://www.sysnet.pe.kr/2/0/12226

ICS와 함께 사용하는 경우, 재부팅 후에는 OpenVPN 클라이언트 측의 인터넷 사용이 잘 안되는 문제가 있습니다. 검색해 보면,

ICS doesn't work after computer or service restart on Windows 10
; https://support.microsoft.com/en-us/help/4055559/ics-doesn-t-work-after-computer-or-service-restart-on-windows-10

위의 조치에 따라 ICS 서비스를 "Automatic"으로 설정하고 레지스트리 키까지 생성해 봐도,

경로: HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\SharedAccess
이름: EnableRebootPersistConnection
타입: DWORD
값: 1

잘 안 됩니다. 그러니까, 낮은 확률로 될 때도 있고, 설령 동작해도 잠시 후에 다시 동작을 안 하는 식의 문제가 발생합니다.




가만 보면, 인터넷이 가능한 네트워크에 ICS를 설정하면 "TAP-Windows Adapter V9"는 그 순간 "192.168.137.1/255.255.255.0"으로 네트워크 설정이 됩니다.

shared_net_with_open_vpn_2.png

반면, OpenVPN 서비스를 시작하면 "TAP-Windows Adapter V9" 어댑터는 다시 IP 설정이 초기화됩니다.

shared_net_with_open_vpn_1.png

그래서 그 상태에서 재차 "ICS 공유"를 해제/설정을 하면 다시 인터넷 연결이 가능해지곤 합니다.

아마도, ICS가 설정하는 기본 네트워크와 OpenVPN이 사용하는 10.0.8.0 네트워크가 서로 연결이 안 되는 듯한데요. 그래서 시도를 해봤습니다. 이를 위해 server.ovpn에 ICS의 192.168.137.0 네트워크에 참여하도록 server 값을 바꾼 후,

# 기존 설정
# server 10.8.0.0 255.255.255.0

# 신규 설정
server 192.168.137.0 255.255.255.0

재부팅을 몇 번 했는데... 오호~~~ ^^ 잘 됩니다.

정리해 보면,

  1. OpenVPN 설치 후,
  2. 기존 인터넷 가능한 어댑터에서 "TAP-Windows Adapter V9"로 인터넷 공유를 설정하고,
  3. 서비스 관리자에서 "Internet Connection Sharing (ICS)"를 "Automatic (Delayed Start)"로, "OpenVPNService" 서비스를 "Automatic"으로 각각 바꾸고,
  4. server.ovpn의 "server ..." 설정을 "server 192.168.137.0 255.255.255.0"으로 변경

재부팅하면 VPN 클라이언트 연결 후 인터넷 공유까지 잘 되는 것을 확인할 수 있습니다.




참고로, 위와 같은 상황을 Bridge를 이용해 해결할 수도 있습니다. Windows에서 Bridge 설정은 예전에 한 번 다룬 적이 있는데요,

Hyper-V의 네트워크 유형 (2)
; https://www.sysnet.pe.kr/2/0/915#bridge

OpenVPN과 연동할 때는, 그냥 단순히 다음과 같이 TAP 어댑터 단독으로만 Bridge를 구성한 후,

shared_net_with_open_vpn_3.png

인터넷 연결이 가능한(위의 예제에서는 "Ethernet 2") 어댑터의 ICS 대상을 새로 생긴 "Bridge"로 연결하면 됩니다. 이후, OpenVPN 측의 server.ovpn 설정을 바꿔야 하는데요, 기존 "server" 설정과 "dev tap"은 주석 처리하고 "server-bridge"와 함께 "dev tun" 설정을 합니다.

# 기존 설정
# server 10.8.0.0 255.255.255.0
# dev tap

# 신규 설정
server-bridge 192.168.137.1 255.255.255.0 192.168.137.50 192.168.137.100
dev tun

이와 함께 마찬가지로, 클라이언트 측에서도 "client.ovpn"에서 "dev tap"을 주석 처리하고 "dev tun"으로 설정하면, 서버 재부팅 후에도 정상적으로 ICS까지 잘 동작하는 것을 확인할 수 있습니다.

(물론, 기존에 ICS 대상을 다중으로 설정해야 할 필요가 없는 환경이라면 굳이 OpenVPN을 server-bridge 모드로 사용할 필요는 없습니다.)




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 9/12/2020]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 106  107  108  109  [110]  111  112  113  114  115  116  117  118  119  120  ...
NoWriterDateCnt.TitleFile(s)
11211정성태5/26/201722630오류 유형: 391. BeginInvoke에 전달한 람다 함수에 CS1660 에러가 발생하는 경우
11210정성태5/25/201722949기타: 65. ActiveX 없는 전자 메일에 사용된 "개인정보 보호를 위해 암호화된 보안메일"의 암호화 방법
11209정성태5/25/201770739Windows: 143. Windows 10의 Recovery 파티션을 삭제 및 새로 생성하는 방법 [16]
11208정성태5/25/201729198오류 유형: 390. diskpart의 set id 명령어에서 "The specified type is not in the correct format." 오류 발생
11207정성태5/24/201730302Windows: 142. Windows 10의 복구 콘솔로 부팅하는 방법
11206정성태5/24/201723510오류 유형: 389. DISM.exe - The specified image in the specified wim is already mounted for read/write access.
11205정성태5/24/201723115.NET Framework: 658. C#의 tail call 구현은? [1]
11204정성태5/22/201732614개발 환경 구성: 316. 간단하게 살펴보는 Docker for Windows [7]
11203정성태5/19/201719899오류 유형: 388. docker - Host does not exist: "default"
11202정성태5/19/201721226오류 유형: 387. WPF - There is no registered CultureInfo with the IetfLanguageTag 'ug'.
11201정성태5/16/201724589오류 유형: 386. WPF - .NET 3.5 이하에서 TextBox에 한글 입력 시 TextChanged 이벤트의 비정상 종료 문제 [1]파일 다운로드1
11200정성태5/16/201721340오류 유형: 385. WPF - 폰트가 없어 System.IO.FileNotFoundException 예외가 발생하는 경우
11199정성태5/16/201722522.NET Framework: 657. CultureInfo.GetCultures가 반환하는 값
11198정성태5/10/201724788.NET Framework: 656. Windows Forms의 오류(Exception) 처리 방법에 대한 차이점 설명
11197정성태5/8/201720787개발 환경 구성: 315. VHD 파일의 최소 크기파일 다운로드1
11196정성태5/4/201722313오류 유형: 384. Msvm_ImageManagementService WMI 객체를 사용할 때 오류 상황 정리 [1]
11195정성태5/3/201723127.NET Framework: 655. .NET Framework 4.7 릴리스
11194정성태5/3/201724603오류 유형: 383. net use 명령어로 네트워크 드라이브 연결 시 "System error 67 has occurred." 오류 발생
11193정성태5/3/201722435Windows: 141. 설치된 Windows로부터 설치 이미지를 만드는 방법
11192정성태5/2/201724019Windows: 140. unattended.xml/autounattend.xml 파일을 마련하는 방법
11191정성태5/2/201724845Windows: 139. Dell Venue 8 Pro 태블릿에 USB를 이용한 윈도우 운영체제 설치 방법
11190정성태5/2/201730222Windows: 138. Windows 운영체제의 ISO 설치 파일에 미리 Device driver를 준비하는 방법
11189정성태5/2/201721417Windows: 137. Windows 7 USB/DVD DOWNLOAD TOOL로 98%에서 실패하는 경우
11188정성태4/27/201724308VC++: 118. Win32 HANDLE 자료형의 이모저모 [2]
11187정성태4/26/201725287개발 환경 구성: 314. C# - PowerPoint 확장 Add-in 만드는 방법 [1]파일 다운로드1
11186정성태4/24/201723235VS.NET IDE: 117. Visual Studio 확장(VSIX)을 이용해 사용자 매크로를 추가하는 방법 [1]파일 다운로드1
... 106  107  108  109  [110]  111  112  113  114  115  116  117  118  119  120  ...