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

오라클 클라우드의 리눅스 VM - 9000 MTU Jumbo Frame 테스트

지난 글에서, IP MTU의 값이 대개 1500이라고 했는데요,

이더넷(Ethernet) 환경의 TCP 통신에서 MSS(Maximum Segment Size) 확인
; https://www.sysnet.pe.kr/2/0/12521

오라클에 있는 리눅스 VM에서 mtu를 확인해 보니 9000 값이 나옵니다.

$ ip link show
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN mode DEFAULT group default qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
2: ens3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 9000 qdisc pfifo_fast state UP mode DEFAULT group default qlen 1000
    link/ether 02:00:17:00:b0:a2 brd ff:ff:ff:ff:ff:ff

정말 이렇게 해도 통신이 잘 되는지 직접 ping을 통해 확인해 볼까요? ^^ 이를 위해 우선, 오라클의 Ubuntu VM 버전은,

$ lsb_release -a
No LSB modules are available.
Distributor ID: Ubuntu
Description:    Ubuntu 20.04 LTS
Release:        20.04
Codename:       focal

ping 등의 네트워크 도구가 없으므로 별도로 설치해야 합니다.

Ping command not found on Ubuntu 20.04 Focal Fossa Linux
; https://linuxconfig.org/ping-command-not-found-on-ubuntu-20-04-focal-fossa-linux

$ sudo apt install iputils-ping

이후 지난번처럼 ping을 이용해 테스트하면,

$ ping www.microsoft.com -s 8972 -c 1 -v -M do
PING e13678.dscb.akamaiedge.net (23.201.37.168) 8972(9000) bytes of data.
From 140.91.214.3 (140.91.214.3) icmp_seq=1 Frag needed and DF set (mtu = 1500)

--- e13678.dscb.akamaiedge.net ping statistics ---
1 packets transmitted, 0 received, +1 errors, 100% packet loss, time 0ms

오류가 발생합니다. 즉, 저 MTU 값으로는 통신이 안 되는 것입니다. 왜냐하면, MTU 9000은 Jumbo Frame이 활성화되어 있는 것으로,

How to test if 9000 MTU/Jumbo Frames are working
; https://blah.cloud/hardware/test-jumbo-frames-working/

대상 서버(위의 경우 www.microsoft.com)까지의 라우터 장비를 비롯한 모든 네트워크가 이를 지원해야 하기 때문에 실패한 것입니다. (사실, TCP Connection의 3-way handshake에 MSS 크기 협상도 포함되어 때문에 상대편이 제시한 MSS 크기가 작다면 그것으로 낮춰서 통신하므로 MTU 9000으로 설정되었다고 해서 통신이 안 되는 것은 아닙니다.)

만약 MTU 9000을 꼭 테스트하고 싶다면, 가장 좋은 방법이 같은 오라클 클라우드 내의 장비끼리 통신하는 것입니다. 가령, 제 경우에 또 다른 VM이 하나 더 있었는데 그곳으로 ping을 해보면 8972까지 잘 되는 것을 확인할 수 있습니다.

$ ping -M do -c 1 -s 8972 [...oracle_vm_ip...]
PING [...oracle_vm_ip...] ([...oracle_vm_ip...]) 8972(9000) bytes of data.
8980 bytes from [...oracle_vm_ip...]: icmp_seq=1 ttl=63 time=0.437 ms

--- [...oracle_vm_ip...] ping statistics ---
1 packets transmitted, 1 received, 0% packet loss, time 0ms
rtt min/avg/max/mdev = 0.437/0.437/0.437/0.000 ms

$ ping -M do -c 1 -s 8973 [...oracle_vm_ip...]
PING [...oracle_vm_ip...] ([...oracle_vm_ip...]) 8973(9001) bytes of data.
ping: local error: message too long, mtu=9000

--- [...oracle_vm_ip...] ping statistics ---
1 packets transmitted, 0 received, +1 errors, 100% packet loss, time 0ms

그러니까, 현실적으로 봤을 때 Jumbo Frame이 활성화된 통신은 intranet 환경 정도에서나 쓸만한 것입니다.




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

[연관 글]


donaricano-btn



[최초 등록일: ]
[최종 수정일: 1/31/2021]

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)
12725정성태7/21/2021355오류 유형: 741. Failed to find the "go" binary in either GOROOT() or PATH
12724정성태7/21/2021549개발 환경 구성: 582. 윈도우 환경에서 Visual Studio Code + Go (Zip) 개발 환경 [1]
12723정성태7/21/2021257오류 유형: 740. SharePoint - Alternate access mappings have not been configured 경고
12722정성태7/20/2021258오류 유형: 739. MSVCR110.dll이 없어 exe 실행이 안 되는 경우
12721정성태7/20/2021222오류 유형: 738. The trust relationship between this workstation and the primary domain failed. - 세 번째 이야기
12720정성태7/19/2021286Linux: 43. .NET Core/5+ 응용 프로그램의 Ubuntu (Debian) 패키지 준비
12719정성태7/19/2021186오류 유형: 737. SharePoint 설치 시 "0x800710D8 The object identifier does not represent a valid object." 오류 발생
12718정성태7/19/2021237개발 환경 구성: 581. Windows에서 WSL로 파일 복사 시 root 소유권으로 적용되는 문제파일 다운로드1
12717정성태7/18/2021244Windows: 195. robocopy에서 파일의 ADS(Alternate Data Stream) 정보 복사를 제외하는 방법
12716정성태7/17/2021274개발 환경 구성: 580. msbuild의 Exec Task에 robocopy를 사용하는 방법파일 다운로드1
12715정성태7/17/2021968오류 유형: 736. Windows - MySQL zip 파일 버전의 "mysqld --skip-grant-tables" 실행 시 비정상 종료
12714정성태7/16/2021285오류 유형: 735. VCRUNTIME140.dll, MSVCP140.dll, VCRUNTIME140.dll, VCRUNTIME140_1.dll이 없어 exe 실행이 안 되는 경우
12713정성태7/16/2021355.NET Framework: 1077. C# - 동기 방식이면서 비동기 규약을 따르게 만드는 Task.FromResult파일 다운로드1
12712정성태7/15/2021244개발 환경 구성: 579. Azure - 리눅스 호스팅의 Site Extension 제작 방법
12711정성태7/15/2021246개발 환경 구성: 578. Azure - Java Web App Service를 위한 Site Extension 제작 방법
12710정성태7/15/2021348개발 환경 구성: 577. MQTT - emqx.io 서비스 소개
12709정성태7/14/2021190Linux: 42. 실행 중인 docker 컨테이너에 대한 구동 시점의 docker run 명령어를 확인하는 방법
12708정성태7/14/2021358Linux: 41. 리눅스 환경에서 디스크 용량 부족 시 원인 분석 방법
12707정성태7/14/2021520오류 유형: 734. MySQL - Authentication method 'caching_sha2_password' not supported by any of the available plugins.
12706정성태7/14/2021461.NET Framework: 1076. C# - AsyncLocal 기능을 CallContext만으로 구현하는 방법 [2]파일 다운로드1
12705정성태7/13/2021298VS.NET IDE: 168. x64 DLL 프로젝트의 컨트롤이 Visual Studio의 Designer에서 보이지 않는 문제 - 두 번째 이야기
12704정성태7/12/2021212개발 환경 구성: 576. Azure VM의 서비스를 Azure Web App Service에서만 접근하도록 NSG 설정을 제한하는 방법
12703정성태7/11/2021256개발 환경 구성: 575. Azure VM에 (ICMP) ping을 허용하는 방법
12702정성태7/11/2021231오류 유형: 733. TaskScheduler에 등록된 wacs.exe의 Let's Encrypt 인증서 업데이트 문제
12701정성태7/9/2021260.NET Framework: 1075. C# - ThreadPool의 스레드는 반환 시 ThreadStatic과 AsyncLocal 값이 초기화 될까요?파일 다운로드1
12700정성태7/8/2021436.NET Framework: 1074. RuntimeType의 메모리 누수? [1]
1  2  3  4  5  [6]  7  8  9  10  11  12  13  14  15  ...