Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 2개 있습니다.)
(시리즈 글이 8개 있습니다.)
개발 환경 구성: 399. Synology NAS(DS216+II)에 gcc 컴파일러 설치
; https://www.sysnet.pe.kr/2/0/11705

개발 환경 구성: 403. Synology NAS(DS216+II)에 docker 설치 후 .NET Core 2.1 응용 프로그램 실행하는 방법
; https://www.sysnet.pe.kr/2/0/11713

개발 환경 구성: 404. (opkg가 설치된) Synology NAS(DS216+II)에 cmake 설치
; https://www.sysnet.pe.kr/2/0/11718

Linux: 3. Synology NAS(DS216+II)에서 FTDI 장치를 C/C++로 제어
; https://www.sysnet.pe.kr/2/0/11733

Linux: 4. Synology NAS(DS216+II)에 FTDI 장치 연결 후 C#(.NET Core)으로 DTR 제어
; https://www.sysnet.pe.kr/2/0/11734

사물인터넷: 51. Synology NAS(DS216+II)를 이용한 원격 컴퓨터의 전원 스위치 제어
; https://www.sysnet.pe.kr/2/0/11740

개발 환경 구성: 446. Synology NAS를 Windows 10에서 iSCSI로 연결하는 방법
; https://www.sysnet.pe.kr/2/0/11967

개발 환경 구성: 720. Synology NAS - docker 원격 제어를 위한 TCP 바인딩 추가
; https://www.sysnet.pe.kr/2/0/13712




Synology NAS를 Windows 10에서 iSCSI로 연결하는 방법

사실, 처음 DS216+II NAS 장비를 구매했을 때는 Hyper-V의 디스크 사용량을 분산시키기 위해서였습니다. 그런데, 공유 폴더 방식으로 VHDX 파일을 지정하면,

\\ds216_nas\temp\test.vhdx

다음과 같은 식의 오류가 발생합니다.

The Virtual Machine Management service encountered an error while configuring the hard disk on virtual machine test1.

'test1' failed to add resources to 'test1'.

An unexpected error occurred: The user name or password is incorrect. (0x8007052E).

'test1' failed to add resources. (Virtual machine ID 33C49F31-7CE4-4BFE-9CE3-A13536385E0A)

'test1' encountered an unexpected error: The user name or password is incorrect. (0x8007052E). (Virtual machine ID 33C49F31-7CE4-4BFE-9CE3-A13536385E0A)

왜냐하면, Hyper-V의 작업자 프로세스(vmwp.exe)는 제한된 권한의 "Virtual machine ID"에 해당하는 계정으로 공유 폴더를 접근하기 때문에 저게 가능하려면 \\ds216_nas\temp 폴더를 거의 익명 접근 수준으로 내려야 합니다. 또는, NAS 장비 및 그에 접근하려는 클라이언트 측의 컴퓨터를 Active Directory에 가입시킨 후, Hyper-V를 호스팅하는 서버 컴퓨터의 제어 위임(Delegation)을 설정해야 합니다. 이에 대해서는 다음의 글에 나오니 참고하시고.

Hyper-V Server 2012 won’t mount ISO from a network share
; https://anotheritblog.net/2013/07/10/hyper-v-server-2012-wont-mount-iso-from-a-network-share/




어쨌든 DS216+II 장비를 Hyper-V 등의 서비스에서 접근하고 싶다면 공유 폴더로는 현실성이 없고, 그보다는 NAS 장비를 iSCSI Target으로 동작하도록 설정하는 것이 좋습니다.

방법은, Synology DiskStation에 접속, Main Menu로 들어가 "iSCSI Manager(이후 이름 변경: SAN Manager)"를 실행해 "LUN"을 생성하는 것으로 시작합니다.

iscsi_nas_0.png

위의 화면에서 "Next" 버튼을 누르면 (iSCSI Target 설정이 없는 경우) 새로 iSCSI Target을 생성할 것을 알리는 단계로 넘어가고,

iscsi_nas_1.png

이후, iSCSI Target과 관련한 정보를 입력하게 됩니다.

iscsi_nas_2.png

위에서는 "CHAP(Challenge Handshake Authentication Protocol)" 인증을 설정했지만 보안이 굳이 필요 없다면 하지 않아도 됩니다. 이렇게 설정을 완료하면, 다음과 같은 구성으로 (iSCSI Target과 함께) LUN이 생성됩니다.

iscsi_nas_3.png

Synology 측의 설정은 이게 끝입니다. 이제 다른 PC에서 위에서 LUN-1로 할당한 디스크를 마운팅해서 사용할 수 있습니다.




마운팅은, Windows 10에서 해보겠습니다. "시작" 메뉴에서 "iSCSI Initiator"라고 입력/실행하면, 최초 실행인 경우 NT 서비스를 자동 시작으로 변경할 것인지를 묻는 창이 뜹니다.

The Microsoft iSCSI service is not running. The service is required to be started for iSCSI to function correctly. To start the service now and have the service start automatically each time the computer restarts, click the Yes button.


확인을 하고, 넘어가면 iSCSI Initiator 설정 창이 뜨는데, 다음과 같이 NAS 장비의 네트워크 IP를 입력하고 "Quick Connect..." 버튼을 누르면,

iscsi_nas_4.png

알아서 앞에서 설정한 iSCSI Target을 찾아 선택할 수 있는 창을 띄워줍니다. (참고로, iSCSI Target에 CHAP 인증을 한 경우 이 과정이 오래 걸릴 수 있습니다.)

iscsi_nas_5.png

위의 화면에서 "Unable to Login to the target"이라고 나오는 것은 CHAP 인증에 대한 계정을 아직 입력한 적이 없기 때문입니다. 상관없이 그냥 "Done" 버튼을 누르면 속성 창의 "Discovered targets" 목록에 다음과 같이 뜨고,

iscsi_nas_6.png

이 상태에서 "Connect" 버튼을 누르면 "Connect To Target" 대화창이 뜨면서,

iscsi_nas_7.png

위와 같이 "Advanced..." 버튼을 통해 "Enable CHAP log on" 체크 후 Synology NAS에서 iSCSI Target을 생성할 때 입력했던 바로 그 계정 정보를 "Name"과 "Target secret" 란에 입력하면 됩니다.

이렇게 완료하고 "Disk Management" MMC 창에 가면, 새로운 Disk 항목을 볼 수 있고 "디스크 초기화" 후 "New Simple Volume..." 메뉴로 포맷해 일반 디스크처럼 사용할 수 있습니다.




현실적으로 봤을 때, iSCSI 접속의 경우 마운팅이 하나의 PC에 독점적으로 이뤄지기 때문에 "공유" 목적의 NAS 장비에 대한 장점이 없어집니다. 그렇게 하느니 차라리 외장 하드를 구매하는 것이 더 좋습니다. 물론, 그나마 좋은 점이 있다면 RAID가 된다는 정도... 일 텐데 그래도 너무 과합니다.

참고로, NAS - 100M LAN - PC 연결을 하는 경우라면 Hyper-V의 VHDX를 호스팅하기에는 너무 느립니다. 다행히 DS216+II 장비가 Gigabit 랜을 지원하므로 그걸로 연결한다면 그나마 좀 나을 수는 있지만... 글쎄요... 이 부분은 나중에 기회가 되면 설정을 해보겠습니다. ^^




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 8/14/2024]

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

비밀번호

댓글 작성자
 




... 91  92  93  94  95  96  97  98  99  100  101  102  [103]  104  105  ...
NoWriterDateCnt.TitleFile(s)
11355정성태11/15/201724331사물인터넷: 7. Raspberry Pi Zero(OTG)를 다른 컴퓨터에 연결해 가상 마우스로 쓰는 방법 [2]파일 다운로드2
11354정성태11/14/201728548사물인터넷: 6. Raspberry Pi Zero(OTG)를 다른 컴퓨터에 연결해 가상 키보드로 쓰는 방법 [8]
11353정성태11/14/201725701사물인터넷: 5. Raspberry Pi Zero(OTG)를 다른 컴퓨터에 연결해 가상 이더넷 카드로 쓰는 방법 [1]
11352정성태11/14/201721742사물인터넷: 4. Samba를 이용해 윈도우와 Raspberry Pi간의 파일 교환 [1]
11351정성태11/7/201725060.NET Framework: 698. C# 컴파일러 대신 직접 구현하는 비동기(async/await) 코드 [6]파일 다운로드1
11350정성태11/1/201721015디버깅 기술: 108. windbg 분석 사례 - Redis 서버로의 호출을 기다리면서 hang 현상 발생
11349정성태10/31/201721453디버깅 기술: 107. windbg - x64 SOS 확장의 !clrstack 명령어가 출력하는 Child SP 값의 의미 [1]파일 다운로드1
11348정성태10/31/201717927디버깅 기술: 106. windbg - x64 역어셈블 코드에서 닷넷 메서드 호출의 인자를 확인하는 방법
11347정성태10/28/201721483오류 유형: 424. Visual Studio - "클래스 다이어그램 보기" 시 "작업을 완료할 수 없습니다. 해당 인터페이스를 지원하지 않습니다." 오류 발생
11346정성태10/25/201718042오류 유형: 423. Windows Server 2003 - The client-side extension could not remove user policy settings for 'Default Domain Policy {...}' (0x8007000d)
11338정성태10/25/201716608.NET Framework: 697. windbg - SOS DumpMT의 "BaseSize", "ComponentSize" 값에 대한 의미파일 다운로드1
11337정성태10/24/201718745.NET Framework: 696. windbg - SOS DumpClass/DumpMT의 "Vtable Slots", "Total Method Slots", "Slots in VTable" 값에 대한 의미파일 다운로드1
11336정성태10/20/201719427.NET Framework: 695. windbg - .NET string의 x86/x64 메모리 할당 구조
11335정성태10/18/201718413.NET Framework: 694. 닷넷 - <Module> 클래스의 용도
11334정성태10/18/201719535디버깅 기술: 105. windbg - k 명령어와 !clrstack을 조합한 호출 스택을 얻는 방법
11333정성태10/17/201718735오류 유형: 422. 윈도우 업데이트 - Code 9C48 Windows update encountered an unknown error.
11332정성태10/17/201719659디버깅 기술: 104. .NET Profiler + 디버거 연결 + .NET Exceptions = cpu high
11331정성태10/16/201718026디버깅 기술: 103. windbg - .NET 4.0 이상의 환경에서 모든 DLL에 대한 심벌 파일을 로드하는 파이썬 스크립트
11330정성태10/16/201717246디버깅 기술: 102. windbg - .NET 4.0 이상의 환경에서 DLL의 심벌 파일 로드 방법 [1]
11329정성태10/15/201721356.NET Framework: 693. C# - 오피스 엑셀 97-2003 .xls 파일에 대해 32비트/64비트 상관없이 접근 방법파일 다운로드1
11328정성태10/15/201724295.NET Framework: 692. C# - 하나의 바이너리로 환경에 맞게 32비트/64비트 EXE를 실행하는 방법파일 다운로드1
11327정성태10/15/201718125.NET Framework: 691. AssemblyName을 .csproj에서 바꾼 경우 빌드 오류 발생하는 문제파일 다운로드1
11326정성태10/15/201718431.NET Framework: 690. coreclr 소스코드로 알아보는 .NET 4.0의 모듈 로딩 함수 [1]
11325정성태10/14/201719216.NET Framework: 689. CLR 4.0 환경에서 DLL 모듈의 로드 주소(Base address) 알아내는 방법
11324정성태10/13/201720816디버깅 기술: 101. windbg - "*** WARNING: Unable to verify checksum for" 경고 없애는 방법
11322정성태10/13/201718233디버깅 기술: 100. windbg - .NET 4.0 응용 프로그램의 Main 메서드에 Breakpoint 걸기
... 91  92  93  94  95  96  97  98  99  100  101  102  [103]  104  105  ...