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]

... 136  137  [138]  139  140  141  142  143  144  145  146  147  148  149  150  ...
NoWriterDateCnt.TitleFile(s)
1640정성태2/24/201447592.NET Framework: 425. C# - VLC(ActiveX) 컨트롤을 레지스트리 등록 없이 사용하는 방법 [15]
1639정성태2/23/201423307기타: 41. BBS 스토어 앱 개인정보 보호 정책 안내
1638정성태2/18/201446155Windows: 90. 실행 파일로부터 관리자 요구 권한을 제거하는 방법(부제: 크랙 버전을 보다 안전하게 실행하는 방법) [8]
1637정성태2/14/201427054Windows: 89. 컴퓨터를 껐는데도 어느 순간 자동으로 켜진다면? - 두 번째 이야기
1636정성태2/14/201423111Windows: 88. Hyper-V가 설치된 컴퓨터의 윈도우 백업 설정
1635정성태2/14/201423922오류 유형: 221. SharePoint - System.InvalidOperationException: The farm is unavailable.
1634정성태2/14/201424125.NET Framework: 424. C# - CSharpCodeProvider로 컴파일한 메서드의 실행이 일반 메서드보다 더 빠르다? [1]파일 다운로드1
1633정성태2/13/201426942오류 유형: 220. 2014년 2월 13일 이후로 Visual Studio 2010 Macro가 동작하지 않는다면? [3]
1632정성태2/12/201444931.NET Framework: 423. C#에서 DirectShow를 이용한 미디어 재생 [2]파일 다운로드1
1631정성태2/11/201423682개발 환경 구성: 217. Realtek 사운드 장치에서 재생되는 오디오를 GraphEditor로 녹음하는 방법
1630정성태2/5/201424165개발 환경 구성: 216. Hyper-V에 올려진 윈도우 XP VM에서 24bit 컬러 및 ClearType 활성화하는 방법
1629정성태2/5/201433955개발 환경 구성: 215. DOS batch - 하나의 .bat 파일에서 다중 .bat 파일을 (비동기로) 실행하는 방법 [1]
1628정성태2/4/201435366Windows: 87. 윈도우 8.1에서 .NET 3.5 설치가 안된다면? [2]
1627정성태2/4/201430414개발 환경 구성: 214. SQL Server Reporting Services를 이용해 간단한 리포트 제작하는 방법
1626정성태2/4/201422411Windows: 86. 윈도우 8.1의 Skydrive 내용이 동기화가 안된다면?
1625정성태2/2/201429485.NET Framework: 422. C++과 C#의 Event 공유파일 다운로드1
1624정성태2/2/201425146.NET Framework: 421. ASP.NET에서 Server.CreateObject와 COM Interop 클래스 생성의 차이점
1623정성태2/1/201429931개발 환경 구성: 213. x86/x64별로 나뉘어진 어셈블리를 한 프로젝트에서 참조하는 방법 [1]파일 다운로드1
1622정성태1/31/201430249VC++: 74. 어떤 것을 쓰면 좋을까요? wvnsprintf, _vsnwprintf_s, StringCbVPrintfW [4]
1621정성태1/31/201422046.NET Framework: 420. 베트남의 11학년(한국의 고2)이 45분만에 푼다는 알고리즘 문제파일 다운로드1
1620정성태1/30/201432135.NET Framework: 419. C# - BigDecimal파일 다운로드1
1619정성태1/30/201428810VS.NET IDE: 85. T4를 이용한 INotifyPropertyChanged 코드 자동 생성파일 다운로드1
1618정성태1/29/201444422Linux: 2. 우분투에서 Active Directory 계정을 이용한 파일 공유
1617정성태1/29/201425710.NET Framework: 418. Thread.Abort 호출의 hang 현상 [1]
1616정성태1/29/201426322디버깅 기술: 63. windbg 디버깅 사례: AppDomain 간의 static 변수 사용으로 인한 crash
1615정성태1/29/201428124.NET Framework: 417. WPF WebBrowser 컨트롤에서 SHDocVw.IWebBrowser2 인터페이스를 구하는 방법 및 순수 WPF 웹 브라우저 컨트롤 소개
... 136  137  [138]  139  140  141  142  143  144  145  146  147  148  149  150  ...