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

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 모드로 사용할 필요는 없습니다.)




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



donaricano-btn



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

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

비밀번호

댓글 쓴 사람
 




1  2  3  4  5  6  7  [8]  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
12370정성태10/13/2020712Linux: 33. Linux - nmcli를 이용한 고정 IP 설정
12369정성태10/21/20201847Windows: 176. Raymond Chen이 한글날에 밝히는 윈도우의 한글 자모 분리 현상 [1]
12368정성태10/12/2020654오류 유형: 668. VSIX 확장 빌드 - The "GetDeploymentPathFromVsixManifest" task failed unexpectedly.
12367정성태10/12/2020868오류 유형: 667. Ubuntu - Temporary failure resolving 'kr.archive.ubuntu.com'
12366정성태11/22/2020900.NET Framework: 950. C# 9.0 - (4) 원시 크기 정수(Native ints) [1]파일 다운로드1
12365정성태11/22/2020876.NET Framework: 949. C# 9.0 - (3) 람다 메서드의 매개 변수 무시(Lambda discard parameters)파일 다운로드1
12364정성태11/22/2020978.NET Framework: 948. C# 9.0 - (2) localsinit 플래그 내보내기 무시(Suppress emitting localsinit flag)파일 다운로드1
12363정성태11/22/20201412.NET Framework: 947. C# 9.0 - (1) 대상으로 형식화된 new 식(Target-typed new expressions) [2]파일 다운로드1
12362정성태10/11/2020681VS.NET IDE: 151. Visual Studio 2019에 .NET 5 rc/preview 적용하는 방법
12361정성태10/19/20201046.NET Framework: 946. C# 9.0을 위한 개발 환경 구성
12360정성태10/8/2020563오류 유형: 666. The type or namespace name '...' does not exist in the namespace 'Microsoft.VisualStudio.TestTools' (are you missing an assembly reference?)
12359정성태10/7/2020749오류 유형: 665. Windows - 재부팅 후 iSCSI 연결이 끊기는 문제
12358정성태10/7/2020643오류 유형: 664. Web Deploy 설치 시 "A newer version of Microsoft Web Deploy 3.6 was found on this machine." 오류
12357정성태10/7/2020535오류 유형: 663. 이벤트 로그 - The storage optimizer couldn't complete retrim on New Volume
12356정성태10/7/2020649오류 유형: 662. ASP.NET Core와 500.19, 500.21 오류 (0x8007000d)
12355정성태10/3/2020546오류 유형: 661. Hyper-V Linux VM의 Internal 유형의 가상 Switch에 대한 IP 연결이 되지 않는 경우
12354정성태10/2/2020575오류 유형: 660. Web Deploy (msdeploy.axd) 실행 시 오류 기록
12353정성태10/7/2020701개발 환경 구성: 518. 비주얼 스튜디오에서 IIS 웹 서버로 "Web Deploy"를 이용해 배포하는 방법
12352정성태10/2/2020690개발 환경 구성: 517. Hyper-V Internal 네트워크에 NAT을 이용한 인터넷 연결 제공
12351정성태10/2/2020905오류 유형: 659. Nox 실행이 안 되는 경우 - Unable to bind to the underlying transport for ...
12350정성태12/12/20201227Windows: 175. 윈도우 환경에서 클라이언트 소켓의 최대 접속 수 [2]파일 다운로드1
12349정성태9/25/2020655Linux: 32. Ubuntu 20.04 - docker를 위한 tcp 바인딩 추가
12348정성태9/25/2020585오류 유형: 658. 리눅스 docker - Got permission denied while trying to connect to the Docker daemon socket at unix:///var/run/docker.sock
12347정성태1/19/20211506Windows: 174. WSL 2의 네트워크 통신 방법
12346정성태9/25/2020582오류 유형: 657. IIS - http://localhost 방문 시 Service Unavailable 503 오류 발생
12345정성태9/25/2020563오류 유형: 656. iisreset 실행 시 "Restart attempt failed." 오류가 발생하지만 웹 서비스는 정상적인 경우
1  2  3  4  5  6  7  [8]  9  10  11  12  13  14  15  ...