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

(시리즈 글이 5개 있습니다.)
Linux: 69. 리눅스 - "Docker Desktop for Windows" Container 환경에서 IPv6 Loopback Address 바인딩 오류
; https://www.sysnet.pe.kr/2/0/13540

개발 환경 구성: 705. "Docker Desktop for Windows" - ASP.NET Core 응용 프로그램의 소켓 주소 바인딩(IPv4/IPv6 loopback, Any)
; https://www.sysnet.pe.kr/2/0/13548

개발 환경 구성: 706. C# - 컨테이너에서 실행하기 위한 (소켓) 콘솔 프로젝트 구성
; https://www.sysnet.pe.kr/2/0/13549

닷넷: 2226. C# - "Docker Desktop for Windows" Container 환경에서의 IPv6 DualMode 소켓
; https://www.sysnet.pe.kr/2/0/13574

닷넷: 2256. ASP.NET Core 웹 사이트의 HTTP/HTTPS + Dual mode Socket (IPv4/IPv6) 지원 방법
; https://www.sysnet.pe.kr/2/0/13616




리눅스 - "Docker Desktop for Windows" Container 환경에서 IPv6 Loopback Address 바인딩 오류

예를 들어, 다음과 같이 예제 코드를 작성한 다음,

using System.Net;
using System.Net.Sockets;

namespace ConsoleApp1;

internal class Program
{
    static void Main(string[] args)
    {
        Socket socket = new Socket(AddressFamily.InterNetworkV6, SocketType.Stream, ProtocolType.Tcp);

        IPEndPoint ep = new IPEndPoint(IPAddress.IPv6Loopback, 15000);
        socket.Bind(ep);

        Thread.Sleep(5000);

        socket.Close();
    }
}

윈도우 또는 리눅스 데스크톱에서 실행하면 잘 동작할 것입니다. 하지만, Visual Studio에서 "Add" / "Docker Support..." 메뉴를 선택해 Docker 환경에서 실행하도록 바꾸면 이제 Bind에서는 다음과 같은 오류가 발생합니다.

System.Net.Sockets.SocketException
  HResult=0x80004005
  Message=Cannot assign requested address
  Source=System.Net.Sockets
  StackTrace:
   at System.Net.Sockets.Socket.DoBind(EndPoint endPointSnapshot, SocketAddress socketAddress)
   at System.Net.Sockets.Socket.Bind(EndPoint localEP)
   at ConsoleApp1.Program.Main(String[] args)

말 그대로 IPv6의 경우 Localhost Loopback 주소에 대해서는 컨테이너 환경에서 바인딩할 수가 없는 것입니다. 이에 대해서는 Any 주소를 직접 바인딩하는 식으로 우회해야 합니다.

// 아래의 코드는 Container 환경에서도 동작
IPEndPoint ep = new IPEndPoint(IPAddress.IPv6Any, 15000);

socket.Bind(ep); // IPv6Any == "::"

그런데, 저게 별 의미가 없습니다. 왜냐하면, 애당초 컨테이너 환경을 구성하는 네트워크 자체가 (IPv6가 아닌) IPv4 환경이기 때문입니다. (잘 동작합니다. ^^)




문서에 따르면,

Enable IPv6 support
; https://docs.docker.com/config/daemon/ipv6/

IPv6를 사용하기 위해 ("Docker Desktop for Windows"의 경우 %USERPROFILE%\.docker 디렉터리에 위치한) daemon.json 파일에 다음의 내용을 추가하면 된다고 합니다.

{
	"builder": { "gc": { "defaultKeepStorage": "20GB", "enabled": true } },
	"experimental": true,
        "ip6tables":  true,
	"features": { "buildkit": true }
}

하지만, 제가 해보니까 저건 그때 당시에만 "experimental"일 뿐이었고, 현재는 통합이 된 듯합니다. 그래서 그냥 ipv6 네트워크를 곧장 생성할 수 있습니다.

c:\temp> docker network create --ipv6 --subnet 2001:0DB8::/112 ip6net

c:\temp> docker network ls
NETWORK ID     NAME      DRIVER    SCOPE
1745376123f7   bridge    bridge    local
802205405723   host      host      local
10c5265fee2d   ip6net    bridge    local
4ad2d57a8bca   none      null      local

그다음, 컨테이너를 위에서 생성한 네트워크를 사용하도록 설정한 다음,

c:\temp> docker run --rm --network ip6net -p 15000:15000 --name ConsoleApp1 -it 2dee319b7378 /bin/bash

다시 AddressFamily.InterNetworkV6 + IPAddress.IPv6Loopback 바인딩을 시도하면 정상적으로 동작하는 것을 확인할 수 있습니다.




혹시나, 실수로라도 아래와 같이 바인딩을 시도하면,

Socket socket = new Socket(AddressFamily.InterNetworkV6,
    SocketType.Stream, ProtocolType.Tcp);

IPEndPoint ep = new IPEndPoint(IPAddress.Loopback, 15000);
socket.Bind(ep);

이런 오류를 보게 될 것입니다. ^^

Unhandled exception. System.Net.Sockets.SocketException (10014): The system detected an invalid pointer address in attempting to use a pointer argument in a call.
   at System.Net.Sockets.Socket.UpdateStatusAfterSocketErrorAndThrowException(SocketError error, Boolean disconnectOnFailure, String callerName)
   at System.Net.Sockets.Socket.DoBind(EndPoint endPointSnapshot, SocketAddress socketAddress)
   at System.Net.Sockets.Socket.Bind(EndPoint localEP)
   at ConsoleApp1.Program.Main(String[] args)




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







[최초 등록일: ]
[최종 수정일: 1/30/2024]

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

비밀번호

댓글 작성자
 




... 151  152  153  154  155  156  157  158  159  160  161  [162]  163  164  165  ...
NoWriterDateCnt.TitleFile(s)
1032정성태5/1/201129992웹: 18. IIS Express를 NT 서비스로 변경
1031정성태4/30/201130959웹: 17. IIS Express - "IIS Installed Versions Manager Interface"의 IIISExpressProcessUtility 구하는 방법 [1]파일 다운로드1
1030정성태4/30/201153371개발 환경 구성: 118. IIS Express - localhost 이외의 호스트 이름으로 접근하는 방법 [4]파일 다운로드1
1029정성태4/28/201142323개발 환경 구성: 117. XCopy에서 파일/디렉터리 확인 질문 없애기 [2]
1028정성태4/27/201139748오류 유형: 119. Visual Studio 2010 SP1 설치 후 Windows Phone 개발자 도구로 인한 재설치 문제 [3]
1027정성태4/25/201128884디버깅 기술: 40. 상황별 GetFunctionPointer 반환값 정리 - x86파일 다운로드1
1026정성태4/25/201147522디버깅 기술: 39. DebugDiag 1.1을 사용한 덤프 분석 [7]
1025정성태4/24/201129350개발 환경 구성: 116. IIS 7 관리자 - Active Directory Certification Authority로부터 SSL 사이트 인증서 받는 방법 [2]
1024정성태4/22/201130676오류 유형: 118. Windows 2008 서버에서 Event Viewer / PowerShell 실행 시 비정상 종료되는 문제 [1]
1023정성태4/20/201131553.NET Framework: 210. Windbg 환경에서 확인해 본 .NET 메서드 JIT 컴파일 전과 후 [1]
1022정성태4/19/201126829디버깅 기술: 38. .NET Disassembly 창에서의 F11(Step-into) 키 동작파일 다운로드1
1021정성태4/18/201129257디버깅 기술: 37. .NET 4.0 응용 프로그램의 Main 함수에 BreakPoint 걸기
1020정성태4/18/201130014오류 유형: 117. Failed to find runtime DLL (mscorwks.dll), 0x80004005
1019정성태4/17/201130796디버깅 기술: 36. Visual Studio의 .NET Disassembly 창의 call 호출에 사용되는 주소의 의미는? [1]파일 다운로드1
1018정성태4/16/201134630오류 유형: 116. 윈도우 업데이트 오류 - 0x8020000E
1017정성태4/14/201129120개발 환경 구성: 115. MSBuild - x86/x64, .NET 2/4, debug/release 빌드에 대한 배치 처리파일 다운로드1
1016정성태4/13/201145299개발 환경 구성: 114. Windows Thin PC 설치 [2]
1015정성태4/9/201130603.NET Framework: 209. AutoReset, ManualReset, Monitor.Wait의 차이파일 다운로드1
1014정성태4/7/2011108085오류 유형: 115. ORA-12516: TNS:listener could not find available handler with matching protocol stack [2]
1013정성태4/7/201125823Team Foundation Server: 45. SharePoint 2010 + TFS 2010 환경에서 ProcessGuidance.html 파일 다운로드 문제
1012정성태4/6/201134564.NET Framework: 208. WCF - 접속된 클라이언트의 IP 주소 알아내는 방법 [1]
1011정성태3/31/201136947오류 유형: 114. 인증서 갱신 오류 - The request contains no certificate template information.
1010정성태3/30/201127732개발 환경 구성: 113. 응용 프로그램 디자인 스케치 도구 - SketchFlow [4]
1009정성태3/29/201140054개발 환경 구성: 112. Visual Studio 2010 - .NET Framework 소스 코드 디버깅 [4]
1008정성태3/27/201132386.NET Framework: 207. C# - Right operand가 음수인 Shift 연산 결과 [2]
1007정성태3/16/201133324개발 환경 구성: 111. Excel - XML 파일 연동 [5]파일 다운로드1
... 151  152  153  154  155  156  157  158  159  160  161  [162]  163  164  165  ...