Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 46. .NET Service Bus 응용 사례: SocketShifter [링크 복사], [링크+제목 복사]
조회: 21516
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
(연관된 글이 3개 있습니다.)
.NET Service Bus 응용 사례: SocketShifter


처음 .NET ServiceBus를 알게 된 것이 다음의 MSDN Magazine 글 덕분이었습니다.

Foundations - Working With The .NET Service Bus
; https://docs.microsoft.com/en-us/archive/msdn-magazine/2009/april/working-with-the-net-service-bus

글을 읽어보시면, 아주 매력적인 기능이 하나가 눈에 뜨일 텐데요. 설명보다는 글 안에 포함된 다음의 그림을 보시면 금방 이해가 되실 것입니다.

[그림 1: Relay Service 구조]
netservicebus_sample_1.gif

와~~~! 멋지죠. 이 서비스는 다음의 HTTPort/HTTHost 서비스와 유사한 기능을 제공하고 있습니다.

TCP through HTTP tunneling: 기업내 Proxy 서버 제한에서 벗어나는 방법 
; https://www.sysnet.pe.kr/2/0/118

즉, 이것을 잘 이용하면 사설망에서 서비스하고 있는 소켓 서비스를 마이크로소프트 측에서 제공하는 컴퓨터를 중계기로 하여 외부망으로부터 자유롭게 접속하는 것이 가능합니다.

그럼... 어떻게 활용해 보는 것이 좋을까요?
아래의 글에서는 이에 대한 ^^ 훌륭한 활용 예를 보여주고 있습니다.

.NET Service Bus - Remote Desktop over Firewalls!
; http://blogs.southworks.net/mwoloski/2009/07/10/net-service-bus-remote-desktop-over-firewalls/

우와~~~! 이 말은 곧, 사설 IP를 받은 회사의 컴퓨터를 집에서도 VPN 없이 Remote Desktop 연결을 할 수 있다는 것입니다. 멋지지 않나요? ^^

아쉬운 점이 있다면, .NET Service Bus 서비스가 무료로 전세계 사람들에게 제공할 수는 없기 때문에 이 프로그램을 활용하기 위해서는 각자가 "Microsoft .NET Services"에 가입해서 Relay Service를 받기 위한 환경을 설정해 놓아야 한다는 것입니다.

그럼,,, 한번 설정 과정을 따라가 볼까요?




이전에도 말씀드렸듯이, 중계 서비스는 현재 주도적으로 무료(또는 유료)로 제공되는 곳이 없기 때문에 각자가 "Microsoft .NET Services"에 가입해서 자신만의 솔루션 구성을 해줘야 합니다.

이를 위해 다음의 URL을 방문하고,

Azure 서비스 등록
Azure Services Platform .NET Services
; http://www.microsoft.com/azure/netservices.mspx

Live 로그인 후 등록 과정을 거칩니다.

Register for Azure Services 
; http://go.microsoft.com/fwlink/?LinkID=129453

그다음, Azure 서비스 중에서도 ".NET Services"로 로그인을 해서 들어갑니다.

.NET Services
Microsoft .NET Services 
; http://portal.ex.azure.microsoft.com/

"Add Solution" 메뉴를 이용해서 중계 서비스로 사용할 솔루션을 임의의 이름으로 하나 만듭니다. 저 같은 경우에는 "rdTicket"이라는 이름으로 만들었습니다. 솔루션을 만들면 곧바로 사용 가능하지 않습니다. 잠시 시간이 흐른 후, 새로 고침으로 방문을 하고 나서야 아래와 같이 "Status"가 "Active" 상태로 바뀝니다.

[그림 2: rdTicket 솔루션 생성 화면]
netservicebus_sample_2.png

이제, 우측 하단의 "Credentials" 링크를 누르고, 전환되는 화면에서 "Solution Password" 링크를 누르면 다음과 같이 솔루션의 접근 암호를 설정할 수 있는 화면이 나옵니다. 적절하게 입력하십시오.

[그림 3: rdTicket 솔루션의 암호 설정]
netservicebus_sample_3.png

"솔루션 이름"과 "암호"는 다음 단계에서 사용하기 때문에 기억해 두십시오.




다음으로, 서버 측 환경을 구성해 봅니다.

원격 터미널 서비스를 제공하는 Windows Server 2008(또는 그 외의 터미널 서비스를 제공하는 윈도우즈) 서버에 다음의 SDK를 다운로드해 설치합니다.

Microsoft .NET Services SDK (July 2009 CTP)
; http://www.microsoft.com/downloads/details.aspx?FamilyID=38d8cf79-fc39-4aef-b3fd-ef280f2e9fa6&displaylang=en

Codeplex 사이트에 방문해서 다음의 링크에서 SocketShifter 소스 코드를 다운로드 받습니다. (우측에 "Latest Version"의 "Download" 링크를 클릭하면 됩니다.)

SocketShifter - Source Code (이 글의 첨부 파일에도 올렸습니다.)
; http://socketshifter.codeplex.com/SourceControl/ListDownloadableCommits.aspx

다운로드한 소스를 Visual Studio에서 열어서, SocketShifterServer 프로젝트의 app.config을 열면 다음과 같은 내용이 있는데,

<?xml version="1.0" encoding="utf-8"?>
<configuration>
  <appSettings>
    <add key="solutionName" value="[솔루션 이름]"/>
    <add key="password" value="[솔루션 비밀번호]"/>
    <add key="servicePath" value="sb://[솔루션 이름].servicebus.windows.net/[임의의 이름]"/>
    <add key="allow" value="localhost:3389"/>
  </appSettings>
</configuration>

조금 전에 설정해 둔 .NET Services 솔루션 이름과 비밀번호를 입력하고, "servicePath"도 적절하게 변경시켜 줍니다. 저 같은 경우에는 솔루션 이름이 "rdTicket"이었기 때문에 servicePath를 다음과 같이 임의로 결정했습니다.

servicePath: sb://rdTicket.servicebus.windows.net/rd

이제 빌드를 하면 정상적으로 exe 파일이 나오는데 이를 NT 서비스로 등록하기 위해서 "Visual Studio 2008 명령행"을 실행하고 다음과 같이 InstallUtil을 이용해서 설치를 해줍니다.

C:\test\socketshifter-27275\SocketShifterServer\bin\Debug>installutil SocketShifterServer.exe
Microsoft (R) .NET Framework Installation utility Version 2.0.50727.3053
Copyright (C) Microsoft Corporation. All rights reserved.


트랜잭트 설치를 실행하고 있습니다.

설치의 Install 단계를 시작하고 있습니다.
C:\test\socketshifter-27275\SocketShifterServer\bin\Debug\SocketShifterServer.exe 어셈블리의 진행 상황을 보려면 로그 파일 내용을
검토하십시오.
파일은 C:\test\socketshifter-27275\SocketShifterServer\bin\Debug\SocketShifterServer.InstallLog 위치에 있습니다.
어셈블리 'C:\test\socketshifter-27275\SocketShifterServer\bin\Debug\SocketShifterServer.exe'을(를) 설치하고 있습니다.
영향을 받는 매개 변수:
   logtoconsole =
   assemblypath = C:\test\socketshifter-27275\SocketShifterServer\bin\Debug\SocketShifterServer.exe
   logfile = C:\test\socketshifter-27275\SocketShifterServer\bin\Debug\SocketShifterServer.InstallLog
SocketShifterServerService 서비스를 설치하고 있습니다...
SocketShifterServerService 서비스가 설치되었습니다.
EventLog 소스 SocketShifterServerService을(를) 로그 Application에 만들고 있습니다...

Install 단계는 완료되었으며 Commit 단계를 시작하고 있습니다.
C:\test\socketshifter-27275\SocketShifterServer\bin\Debug\SocketShifterServer.exe 어셈블리의 진행 상황을 보려면 로그 파일 내용을 검토하십시오.
파일은 C:\test\socketshifter-27275\SocketShifterServer\bin\Debug\SocketShifterServer.InstallLog 위치에 있습니다.
어셈블리 'C:\test\socketshifter-27275\SocketShifterServer\bin\Debug\SocketShifterServer.exe'을(를) 커밋하고 있습니다.
영향을 받는 매개 변수:
   logtoconsole =
   assemblypath = C:\test\socketshifter-27275\SocketShifterServer\bin\Debug\SocketShifterServer.exe
   logfile = C:\test\socketshifter-27275\SocketShifterServer\bin\Debug\SocketShifterServer.InstallLog

Commit 단계가 완료되었습니다.

트랜잭트 설치가 완료되었습니다.

이제 서비스 관리자를 열어서 정상적으로 서비스로 등록되었는지 확인합니다.

[그림 4: Socket Shifter 서비스 등록 확인]
netservicebus_sample_4.png

서비스가 현재 "Local Service" 계정으로 되어 있는데, Windows Vista/2008에서는 접근 거부 오류가 발생할 것입니다. "Local System" 계정으로 바꿔주거나 혹은 적절하게 권한 설정을 해주시면 되겠습니다.

서비스가 정상적으로 시작된 것을 확인하고 나서, 다음 클라이언트 작업으로 넘어갑니다.




mstsc.exe를 실행해서 서버에 접근할 PC의 경우에는 설정이 다소 간단합니다. 역시 이 컴퓨터에도 .NET Services SDK를 설치하고,

Microsoft .NET Services SDK (July 2009 CTP)
; http://www.microsoft.com/downloads/details.aspx?FamilyID=38d8cf79-fc39-4aef-b3fd-ef280f2e9fa6&displaylang=en

이전에 codeplex에서 다운로드 받은 Socket Shifter 솔루션에서 "SocketShifterClient" 프로젝트의 app.config을 상황에 맞게 편집해 줍니다.

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <appSettings>
    <add key="solutionName" value="[솔루션 이름]"/>
    <add key="servicePath" value="[서버에서 구성한 servicePath 주소]"/>
    <add key="password" value="[솔루션 비밀번호]"/>
    <add key="localPort" value="1000"/>
    <add key="remoteHost" value="localhost"/>
    <add key="remotePort" value="3389"/>
  </appSettings>
</configuration>

이제 빌드하고, 응용 프로그램을 로컬에 실행시켜 둡니다.




사전 준비 작업은 위의 단계로 모두 완료되었습니다. 이제 mstsc.exe를 실행해서 실제로 원격 서버에 접속해 보는데요. 방법은, SocketShifterClient 응용 프로그램의 app.config에 등록한 localPort를 기준으로 주소를 다음과 같이 입력해 주면 됩니다.

[그림 5: mstsc 실행]
netservicebus_sample_5.png

그럼, mstsc.exe는 로컬에 실행된 SocketShifterClient.exe에 연결을 하고, SocketShifterClient.exe는 다시 app.config에 기록된 servicePath로 연결을 합니다. 그리곤 SocketShifterServer에게 remoteHost가 localhost이고, remotePort가 3389인 곳으로 접속을 시도하도록 합니다.

와~~~ 끝내주죠. ^^

이와 함께, ".NET Service Bus - Remote Desktop over Firewalls!" 글에서는 또 하나의 링크를 제공해 주고 있는데요.

.NET Services March 2009 CTP: Host a Public Website At The Kitchen Table or from a Coffee Shop! No Kidding.
; https://docs.microsoft.com/en-us/archive/blogs/clemensv/net-services-march-2009-ctp-host-a-public-website-at-the-kitchen-table-or-from-a-coffee-shop-no-kidding

이런 응용 사례로... 뭐 또 다른 좋은 아이디어가 있지 않을까요? ^^



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

[연관 글]






[최초 등록일: ]
[최종 수정일: 6/23/2021]

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

비밀번호

댓글 작성자
 



2009-07-15 08시52분
Windows Azure Platform Pricing
; (broken) http://blogs.msdn.com/robinm/archive/2009/07/14/windows-azure-platform-pricing.aspx
kevin25
2022-02-11 10시52분
fatedier/frp
 - A fast reverse proxy to help you expose a local server behind a NAT or firewall to the internet.
; https://github.com/fatedier/frp/
정성태

1  2  [3]  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13560정성태2/19/20242073디버깅 기술: 195. windbg 분석 사례 - Semaphore 잠금으로 인한 Hang 현상 (닷넷)
13559정성태2/19/20242938오류 유형: 895. ASP.NET - System.Security.SecurityException: 'Requested registry access is not allowed.'
13558정성태2/18/20242162닷넷: 2217. C# - 최댓값이 1인 SemaphoreSlim 보다 Mutex 또는 lock(obj)를 선택하는 것이 나은 이유
13557정성태2/18/20241913Windows: 258. Task Scheduler의 Author 속성 값을 변경하는 방법
13556정성태2/17/20241957Windows: 257. Windows - Symbolic (hard/soft) Link 및 Junction 차이점
13555정성태2/15/20242112닷넷: 2216. C# - SemaphoreSlim 사용 시 주의점
13554정성태2/15/20241856VS.NET IDE: 189. Visual Studio - 닷넷 소스코드 디컴파일 찾기가 안 될 때
13553정성태2/14/20241938닷넷: 2215. windbg - thin/fat lock 없이 동작하는 Monitor.Wait + Pulse
13552정성태2/13/20241887닷넷: 2214. windbg - Monitor.Enter의 thin lock과 fat lock
13551정성태2/12/20242084닷넷: 2213. ASP.NET/Core 웹 응용 프로그램 - 2차 스레드의 예외로 인한 비정상 종료
13550정성태2/11/20242198Windows: 256. C# - Server socket이 닫히면 Accept 시켰던 자식 소켓이 닫힐까요?
13549정성태2/3/20242500개발 환경 구성: 706. C# - 컨테이너에서 실행하기 위한 (소켓) 콘솔 프로젝트 구성
13548정성태2/1/20242330개발 환경 구성: 705. "Docker Desktop for Windows" - ASP.NET Core 응용 프로그램의 소켓 주소 바인딩(IPv4/IPv6 loopback, Any)
13547정성태1/31/20242084개발 환경 구성: 704. Visual Studio - .NET 8 프로젝트부터 dockerfile에 추가된 "USER app" 설정
13546정성태1/30/20241941Windows: 255. (디버거의 영향 등으로) 대상 프로세스가 멈추면 Socket KeepAlive로 연결이 끊길까요?
13545정성태1/30/20241858닷넷: 2212. ASP.NET Core - 우선순위에 따른 HTTP/HTTPS 호스트:포트 바인딩 방법
13544정성태1/30/20241882오류 유형: 894. Microsoft.Data.SqlClient - Could not load file or assembly 'System.Security.Permissions, ...'
13543정성태1/30/20241880Windows: 254. Windows - 기본 사용 중인 5357 포트 비활성화는 방법
13542정성태1/30/20241912오류 유형: 893. Visual Studio - Web Application을 실행하지 못하는 IISExpress - 두 번째 이야기
13541정성태1/29/20241954VS.NET IDE: 188. launchSettings.json의 useSSL 옵션
13540정성태1/29/20242075Linux: 69. 리눅스 - "Docker Desktop for Windows" Container 환경에서 IPv6 Loopback Address 바인딩 오류
13539정성태1/26/20242364개발 환경 구성: 703. Visual Studio - launchSettings.json을 이용한 HTTP/HTTPS 포트 바인딩
13538정성태1/25/20242417닷넷: 2211. C# - NonGC(FOH) 영역에 .NET 개체를 생성파일 다운로드1
13537정성태1/24/20242500닷넷: 2210. C# - Native 메모리에 .NET 개체를 생성파일 다운로드1
13536정성태1/23/20242587닷넷: 2209. .NET 8 - NonGC Heap / FOH (Frozen Object Heap) [1]
13535정성태1/22/20242431닷넷: 2208. C# - GCHandle 구조체의 메모리 분석
1  2  [3]  4  5  6  7  8  9  10  11  12  13  14  15  ...