Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 4개 있습니다.)

Azure 데이터베이스를 로컬 DB로 이전하는 방법

Azure DB와 Local DB를 옮기는 것은 "SQL Azure migration wziard" 도구로 할 수 있습니다.

sysnet DB를 SQL Azure 데이터베이스로 마이그레이션
; https://www.sysnet.pe.kr/2/0/1303

이번에는 경험삼아 .NET Reflector로 유명한 red-gate사의 서비스를 활용해 보았습니다.

Red Gate Cloud Services
; https://cloudservices.red-gate.com

아쉽지만 cloudservices.red-gate.com 서비스는 유료입니다. (10일 동안 trial로 무료로 사용할 수 있습니다.)

일단, red-gate 서비스를 이용해 Azure DB를 로컬 DB로 마이그레이션하기 위해서는 Azure DB를 Azure Blob 파일로 내보내야 합니다. 이를 위해 cloudservices.red-gate.com 서비스 중에 "BACK UP SQL AZURE"의 "TO AZURE" 메뉴를 선택합니다.

redgate_azure_backup_1.png

그럼, 다음과 같이 왼쪽에 Azure DB 계정 입력란이 나오고, 오른쪽에는 Blob Storage에 대한 접속 정보의 입력란이 나옵니다. (두가지 정보 모두 Azure Portal 사이트에서 구할 수 있습니다.)

redgate_azure_backup_2.png

그다음 화면에서는 Backup 작업을 예약하거나, 곧바로 실행할 수 있는 메뉴가 나옵니다. 제 경우에는 테스트용 DB가 얼마 크지 않으므로 바로 "Run now" 버튼을 눌러 실행했습니다.

그러고 나면 Azure Storage에 "bacpac" 확장자를 가진 파일이 하나 생성됩니다. 이것으로 DB 백업은 완료됩니다.




BACPAC 파일을 로컬 DB에 복원하는 방법도 cloudservices.red-gate.com 서비스에서 제공됩니다. 아래와 같이 "RESTORE SQL SERVER" / "FROM AZURE" 메뉴를 선택하고,

redgate_azure_backup_3.png

Azure Storage 측 접속 정보와, 로컬 SQL 서버의 계정 정보를 입력해야 합니다.

redgate_azure_backup_4.png

그런데, 위와 같이 입력하도록 만드는 것은 다소 현실성이 떨어집니다. 왜냐하면 로컬 SQL 서버를 red-gate 측에서 접속할 수 있도록 공용 IP(또는 DNS)와 계정 정보를 입력해야 하는데 사실 SQL 서버는 내부망에 보호되어 있는 경우가 많기 때문에 이런 식의 마이그레이션을 할 수 있는 기회가 많지 않습니다. (게다가 현재, 로컬 SQL 서버로의 접속을 하려고 위의 화면에서와 같이 IP를 입력하고 "Test" 버튼을 누르면 "Something has gone horribly wrong at our end, email support@redgatecloudservices.zendesk.com fi this keeps happening"이라는 오류 메시지가 발생하면서 진행이 안됩니다.)




그래도 BACPAC 백업 파일을 얻은 것만 해도 절반은 성공입니다. 그냥 Azure Storage에 접속해서 백업된 BACPAC파일을 로컬에 다운로드 하면 됩니다. 그럼, SQL Server Management Studio를 이용해 "Import Data-tier Application..." 메뉴를 선택하고,

redgate_azure_backup_5.png

Azure Storage에서 다운로드 받은 bacpac을 지정해 로컬 DB에 복원할 수 있습니다.




사실상 cloudservices.red-gate.com 서비스로 할 수 있었던 것은 bacpac 파일을 얻은 것이 전부입니다. 단지 이것만이라면 굳이 red-gate 서비스를 사용할 필요가 없습니다. 왜냐하면 bacpac 파일로 백업하는 것은 오히려 SQL Management Studio Service를 이용해 Azure DB에 접속한 다음 해당 데이터베이스에 대해 "Export Data-tier Application..." 메뉴를 선택해 BACPAC 파일을 간단하게 생성할 수 있기 때문입니다.

redgate_azure_backup_6.png

red-gate 서비스의 메뉴 구성을 통해 해당 서비스가 의미가 있는 부분을 찾는다면? Azure와 Amazon간의 데이터 이동을 간편화 시켰다는 것인데, 사실 클라우드 서비스를 다중으로 쓰는 경우가 많지 않을 듯 싶기 때문에 얼마나 효용성이 있을지는 좀 의문이군요.

그래도 이런 유틸리티 성격의 서비스를 발빠르게 대응해서 판매하고 있다는 것은 참 부럽습니다. ^^




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 7/10/2021]

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

비밀번호

댓글 작성자
 



2014-05-07 11시38분
[ryujh] 안녕하세요.

글을 읽으면서 아쉬운점이 생각나고 내용에 감탄하면서 다 읽다보니 마지막줄에 바로 생각했던 것과 비슷한 글이 나오네요.

우리나라의 회사(제가 알고 있는 범위에서)는 '영업' 그 자체로 신경을 쓰는 건지... 어쩔 수 없는 건지, 근원(생산)보다는 결과(수익)를 더 중요시하는 것 같다는 제 생각입니다.

비유가 잘못되었다면 알려주시면 좋을 것 같습니다.
[guest]
2014-05-08 02시46분
[ryujh] 위 글에 대해 보충하자면
수익을 중요시하는 것이 문제라는 뜻으로 느껴진다면 잘못된 비유이므로
근원(생산, 창조)도 신경을 쓰면 좋을 것 같다는 뜻으로 알립니다.
유지관리를 주로 해온 개발자로서 개발부터 잘해야겠는 생각으로 반성합니다.
[guest]

... 16  17  18  19  20  21  22  23  24  [25]  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
13024정성태4/7/20226662.NET Framework: 1189. C# - 런타임 환경에 따라 달라진 AppDomain.GetCurrentThreadId 메서드
13023정성태4/6/20226988.NET Framework: 1188. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 transcoding.c 예제 포팅 [3]
13022정성태3/31/20226935Windows: 202. 윈도우 11 업그레이드 - "PC Health Check"를 통과했지만 여전히 업그레이드가 안 되는 경우 해결책
13021정성태3/31/20227122Windows: 201. Windows - INF 파일을 이용한 장치 제거 방법
13020정성태3/30/20226908.NET Framework: 1187. RDP 접속 시 WPF UserControl의 Unloaded 이벤트 발생파일 다운로드1
13019정성태3/30/20226869.NET Framework: 1186. Win32 Message를 Code로부터 메시지 이름 자체를 구하고 싶다면?파일 다운로드1
13018정성태3/29/20227365.NET Framework: 1185. C# - Unsafe.AsPointer가 반환한 포인터는 pinning 상태일까요? [5]
13017정성태3/28/20227135.NET Framework: 1184. C# - GC Heap에 위치한 참조 개체의 주소를 알아내는 방법 - 두 번째 이야기 [3]
13016정성태3/27/20228088.NET Framework: 1183. C# 11에 추가된 ref 필드의 (우회) 구현 방법파일 다운로드1
13015정성태3/26/20229354.NET Framework: 1182. C# 11 - ref struct에 ref 필드를 허용 [1]
13014정성태3/23/20227931VC++: 155. CComPtr/CComQIPtr과 Conformance mode 옵션의 충돌 [1]
13013정성태3/22/20226165개발 환경 구성: 641. WSL 우분투 인스턴스에 파이썬 2.7 개발 환경 구성하는 방법
13012정성태3/21/20225489오류 유형: 803. C# - Local '...' or its members cannot have their address taken and be used inside an anonymous method or lambda expression
13011정성태3/21/20227056오류 유형: 802. 윈도우 운영체제에서 웹캠 카메라 인식이 안 되는 경우
13010정성태3/21/20225930오류 유형: 801. Oracle.ManagedDataAccess.Core - GetTypes 호출 시 "Could not load file or assembly 'System.DirectoryServices.Protocols...'" 오류
13009정성태3/20/20227633개발 환경 구성: 640. docker - ibmcom/db2 컨테이너 실행
13008정성태3/19/20226930VS.NET IDE: 176. 비주얼 스튜디오 - 솔루션 탐색기에서 프로젝트를 선택할 때 csproj 파일이 열리지 않도록 만드는 방법
13007정성태3/18/20226525.NET Framework: 1181. C# - Oracle.ManagedDataAccess의 Pool 및 그것의 연결 개체 수를 알아내는 방법파일 다운로드1
13006정성태3/17/20227658.NET Framework: 1180. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 remuxing.c 예제 포팅
13005정성태3/17/20226466오류 유형: 800. C# - System.InvalidOperationException: Late bound operations cannot be performed on fields with types for which Type.ContainsGenericParameters is true.
13004정성태3/16/20226479디버깅 기술: 182. windbg - 닷넷 메모리 덤프에서 AppDomain에 걸친 정적(static) 필드 값을 조사하는 방법
13003정성태3/15/20226582.NET Framework: 1179. C# - (.NET Framework를 위한) Oracle.ManagedDataAccess 패키지의 성능 카운터 설정 방법
13002정성태3/14/20227410.NET Framework: 1178. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 http_multiclient.c 예제 포팅
13001정성태3/13/20227769.NET Framework: 1177. C# - 닷넷에서 허용하는 메서드의 매개변수와 호출 인자의 최대 수
13000정성태3/12/20227393.NET Framework: 1176. C# - Oracle.ManagedDataAccess.Core의 성능 카운터 설정 방법
12999정성태3/10/20226907.NET Framework: 1175. Visual Studio - 프로젝트 또는 솔루션의 Clean 작업 시 응용 프로그램에서 생성한 파일을 함께 삭제파일 다운로드1
... 16  17  18  19  20  21  22  23  24  [25]  26  27  28  29  30  ...