Microsoft MVP성태의 닷넷 이야기
사물인터넷: 44. 넷두이노(Netduino)의 네트워크 설정 방법 [링크 복사], [링크+제목 복사],
조회: 10741
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

넷두이노(Netduino)의 네트워크 설정 방법

기본 설정 상태에서 넷두이노로 네트워크 프로그램을 하면 랜 선이 적절하게 연결되어 있어도 인터넷 통신이 안 됩니다. 실제로 다음과 같이 네트워크 환경을 확인해 보면,

foreach (NetworkInterface ni in NetworkInterface.GetAllNetworkInterfaces())
{
    Trace.Print(ni.NetworkInterfaceType + ": " + ni.IPAddress);
}

디버그 상태에서 ni 값에는 다음의 정보들이 보입니다.

DnsAddresses    {string[0]} string[]
GatewayAddress  "192.168.5.1"   string
IPAddress   "192.168.5.100" string
IsDhcpEnabled   0   bool {int}
IsDynamicDnsEnabled 0   bool {int}
NetworkInterfaceType    Ethernet    Microsoft.SPOT.Net.NetworkInformation.NetworkInterfaceType
PhysicalAddress {byte[6]}   byte[]
    [0] 0   byte
    [1] 0   byte
    [2] 0   byte
    [3] 0   byte
    [4] 0   byte
    [5] 1   byte
SubnetMask  "255.255.255.0" string

왜냐하면, 저게 (firmware 초기화할 때마다) 기본 상태이기 때문입니다. 이를 바꾸려면 MFDeploy를 실행해 다음과 같이 "Target" / "Configuration" / "Network" 메뉴를 선택해 직접 네트워크 환경을 설정하면 됩니다.

netduino_network_env_1.png

또는 코드 상으로도 저 설정을 모두 제어할 수 있는데, 가령 DHCP 환경을 위해서는 다음과 같이 할 수 있습니다.

Microsoft.SPOT.Net.NetworkInformation.NetworkInterface ni
    = Microsoft.SPOT.Net.NetworkInformation.NetworkInterface.GetAllNetworkInterfaces()[0];

ni.EnableDynamicDns();
ni.EnableDhcp();
ni.RenewDhcpLease();

반면 고정 IP를 사용하는 환경이라면 이렇게 할 수 있습니다.

ni.EnableStaticIP("192.168.0.5", "255.255.255.0", "192.168.0.1");
ni.EnableStaticDns(new string[] { "8.8.8.8", "8.8.4.4" });

물론 MAC 주솟값도 변경할 수 있습니다.

ni.PhysicalAddress = new byte[] { 0x00, 0x00, 0x00, 0x00, 0x00, 0x06 };




MFDeploy로 네트워크 설정을 한 후 "Update" 버튼을 눌렀을 때 다음과 같은 오류가 발생할 수 있습니다.

Unable to erase configuration sector memory

제 경험상, MFDeploy와 맞지 않는 firmware를 업데이트한 경우에 그랬습니다. 문제는, MFDeploy를 마이크로소프트의 .NET Micro Framework에서 배포하고 firmware는 넷두이노 제조사가 배포하다 보니 MFDeploy가 맞지 않는 경우가 제법 발생합니다.

따라서 역시 제 경험상, MFDeploy보다는 그냥 코드 상으로 네트워크 환경을 맞춰주는 것이 더 좋습니다.




넷두이노 플러스는 넷두이노 기본 제품에서 이더넷 기능이 추가된 것입니다. 그런데, 랜 선을 연결해도 소켓 부위의 LED가 점등하지 않고 다음과 같이 GetAllNetworkInterfaces 메서드를 호출하면,

Microsoft.SPOT.Net.NetworkInformation.NetworkInterface ni
    = Microsoft.SPOT.Net.NetworkInformation.NetworkInterface.GetAllNetworkInterfaces()[0];

System.NotSupportedException 예외가 발생한다면?

Exception thrown: 'System.NotSupportedException' in Microsoft.SPOT.Net.dll
An unhandled exception of type 'System.NotSupportedException' occurred in Microsoft.SPOT.Net.dll

해당 제품과 맞는 펌웨어를 설치한 것인지 확인해 보는 것이 좋습니다. 제 경우에 실수로 넷두이노 플러스에 넷두이노 펌웨어를 ^^; 올렸더니 네트워크 기능 빼고 모든 기능이 잘 되어 뭐가 문제인지 찾는데 시간을 들였던 적이 있습니다.




참고로, 제가 보유하고 있는 초기 넷두이노 플러스 제품은 다음의 사양을 가지고 있습니다.

Atmel 32-bit microcontroller
48Mhz, ARM7
14 Digital I/O Pins
6 Analog Inputs
Arduino Shield Compatible
100mbps ethernet
MicroSD socket (up to 2GB)
Code Storage: 64KB
RAM: 50+ KB

사실 저 공간이, 특히 RAM은 50+ KB 정도만 여유가 있기 때문에 웹 프로그래밍을 할 때 매우 조심해야 합니다. 일례로 제 홈페이지조차도 초기 페이지가 27,226(26.5KB) 용량이 되는데 이를 위해 "byte [] buf = new byte [27226]"과 같이 메모리 할당을 시도하면 OOM 오류가 발생합니다. (다행히 OOM이 발생해도 다운되지는 않습니다.)

현재는 초기 넷두이노 플러스 제품이 생산 중단되고 동일한 가격으로 넷두이노 3 이더넷 제품을 구매할 수 있습니다. 3 제품의 경우 1GB 넘는 Code 저장 공간과 3배 정도 넓어진 164+ KB 공간의 RAM을 제공하기 때문에 좀 더 여유가 생긴 것은 사실이지만 그래도 PC 기반의 프로그램을 하던 개발자들은 보다 더 꼼꼼하게 메모리 사용량을 따져가면서 프로그램을 해야 할 필요가 있습니다.




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 9/27/2018]

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

비밀번호

댓글 작성자
 




... 61  62  [63]  64  65  66  67  68  69  70  71  72  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
12067정성태11/27/201911744디버깅 기술: 137. 실제 사례를 통해 Debug Diagnostics 도구가 생성한 닷넷 웹 응용 프로그램의 성능 장애 보고서 설명 [1]파일 다운로드1
12066정성태11/27/201911604디버깅 기술: 136. windbg - C# PInvoke 호출 시 마샬링을 담당하는 함수 분석 - OracleCommand.ExecuteReader에서 OpsSql.Prepare2 PInvoke 호출 분석
12065정성태11/25/201910485디버깅 기술: 135. windbg - C# PInvoke 호출 시 마샬링을 담당하는 함수 분석파일 다운로드1
12064정성태11/25/201912667오류 유형: 580. HTTP Error 500.0/500.33 - ANCM In-Process Handler Load Failure
12063정성태11/21/201911694디버깅 기술: 134. windbg - RtlReportCriticalFailure로부터 parameters 정보 찾는 방법
12062정성태11/21/201911774디버깅 기술: 133. windbg - CoTaskMemFree/FreeCoTaskMem에서 발생한 덤프 분석 사례 - 두 번째 이야기
12061정성태11/20/201911936Windows: 167. CoTaskMemAlloc/CoTaskMemFree과 윈도우 Heap의 관계
12060정성태11/20/201912314디버깅 기술: 132. windbg/Visual Studio - HeapFree x64의 동작 분석
12059정성태11/20/201911904디버깅 기술: 131. windbg/Visual Studio - HeapFree x86의 동작 분석
12058정성태11/19/201912716디버깅 기술: 130. windbg - CoTaskMemFree/FreeCoTaskMem에서 발생한 덤프 분석 사례
12057정성태11/18/20199838오류 유형: 579. Visual Studio - Memory 창에서 유효한 주소 영역임에도 "Unable to evaluate the expression." 오류 출력
12056정성태11/18/201913673개발 환경 구성: 464. "Microsoft Visual Studio Installer Projects" 프로젝트로 EXE 서명 및 MSI 파일 서명 방법파일 다운로드1
12055정성태11/17/20199397개발 환경 구성: 463. Visual Studio의 Ctrl + Alt + M, 1 (Memory 1) 등의 단축키가 동작하지 않는 경우
12054정성태11/15/201910746.NET Framework: 869. C# - 일부러 GC Heap을 깨뜨려 GC 수행 시 비정상 종료시키는 예제
12053정성태11/15/201912423Windows: 166. 윈도우 10 - 명령행 창(cmd.exe) 속성에 (DotumChe, GulimChe, GungsuhChe 등의) 한글 폰트가 없는 경우
12052정성태11/15/201911521오류 유형: 578. Azure - 일정(schedule)에 등록한 runbook이 1년 후 실행이 안 되는 문제(Reason - The key used is expired.)
12051정성태11/14/201913999개발 환경 구성: 462. 시작하자마자 비정상 종료하는 프로세스의 메모리 덤프 - procdump [1]
12050정성태11/14/201911674Windows: 165. AcLayers의 API 후킹과 FaultTolerantHeap
12049정성태11/13/201911758.NET Framework: 868. (닷넷 프로세스를 대상으로) 디버거 방식이 아닌 CLR Profiler를 이용해 procdump.exe 기능 구현
12048정성태11/12/201912523Windows: 164. GUID 이름의 볼륨에 해당하는 파티션을 찾는 방법
12047정성태11/12/201914382Windows: 163. 안전하게 eject시킨 USB 장치를 물리적인 재연결 없이 다시 인식시키는 방법
12046정성태10/29/201910363오류 유형: 577. windbg - The call to LoadLibrary(...\sos.dll) failed, Win32 error 0n193
12045정성태10/27/20199705오류 유형: 576. mstest.exe 실행 시 "Visual Studio Enterprise is required to execute the test." 오류 - 두 번째 이야기
12044정성태10/27/20199934오류 유형: 575. mstest.exe - System.Resources.MissingSatelliteAssemblyException: The satellite assembly named "Microsoft.VisualStudio.ProductKeyDialog.resources.dll, ..."
12043정성태10/27/201910740오류 유형: 574. Windows 10 설치 시 오류 - 0xC1900101 - 0x4001E
12042정성태10/26/201911135오류 유형: 573. OneDrive 하위에 위치한 Documents, Desktop 폴더에 대한 권한 변경 시 "Unable to display current owner"
... 61  62  [63]  64  65  66  67  68  69  70  71  72  73  74  75  ...