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]

... 106  107  108  109  110  111  112  [113]  114  115  116  117  118  119  120  ...
NoWriterDateCnt.TitleFile(s)
11100정성태11/7/201628818개발 환경 구성: 304. Wi-Fi Direct 지원 여부 확인 방법 [1]
11099정성태11/7/201630751.NET Framework: 620. C#에서 C/C++ 함수로 콜백 함수를 전달하는 예제 코드파일 다운로드1
11098정성태11/7/201620093오류 유형: 368. 빌드 이벤트에서 robocopy 사용 시 $(TargetDir) 매크로를 지정하는 경우 오류 발생
11097정성태11/7/201623026오류 유형: 367. go install: no install location for directory [...경로...] outside GOPATH
11096정성태11/6/201626823디버깅 기술: 83. PDB 파일을 수동으로 다운로드하는 방법
11095정성태11/6/201623090.NET Framework: 619. C# - Cognitive Services 중의 하나인 Face API를 사용해 얼굴 인식 및 흐림(blur) 효과 적용 [1]파일 다운로드1
11094정성태11/5/201624717VC++: 105. Visual Studio 2013/2015 - Ceemple OpenCV 확장을 이용한 웹캠 영상 출력
11093정성태11/4/201624650웹: 34. Edge 브라우저도 지원하는 클립보드 복사를 위한 자바스크립트 코드
11092정성태11/3/201631598.NET Framework: 618. C# - NAudio를 이용한 MP3 파일 재생 [5]파일 다운로드1
11091정성태11/3/201626318VC++: 104. std::call_once를 이용해 thread-safe한 Singleton 객체 생성파일 다운로드1
11090정성태11/1/201627781VC++: 103. C++ CreateTimerQueue, CreateTimerQueueTimer 예제 코드 [9]파일 다운로드1
11089정성태11/1/201626705디버깅 기술: 82. Windows 10을 위한 Symbol(PDB) 파일 내려받는 방법 [2]
11088정성태11/1/201630779.NET Framework: 617. C# - AForge.NET을 이용한 MP4 동영상 파일 재생 [7]파일 다운로드1
11087정성태11/1/201625196.NET Framework: 616. AForge.Video.FFMPEG를 최신 버전의 ffmpeg 파일로 의존성을 변경하는 방법파일 다운로드1
11086정성태11/1/201619047오류 유형: 366. The Microsoft Passport Container service terminated with the following error: General access denied error
11085정성태10/27/201633445.NET Framework: 615. C# - AForge.NET을 이용한 웹캠 영상 출력 [2]파일 다운로드1
11084정성태10/26/201621408오류 유형: 365. The User Profile Service service failed to the sign-in.
11083정성태10/26/201627955Windows: 131. 윈도우 10에서 사라진 "Adapters and Bindings" 네트워크 우선 순위 조정 기능 [1]
11082정성태10/26/201629885.NET Framework: 614. C# - DateTime.Ticks의 정밀도 [4]파일 다운로드1
11081정성태10/26/201620385오류 유형: 364. You need to fix your Microsoft Account for apps on your other devices to be able to launch apps and continue experiences on this device.
11080정성태10/24/201623541Windows: 130. Windows Server 2016 Nano 서버 설치 방법
11079정성태10/21/201620674Windows: 129. Windows Server 2016 설치 CD에 있는 Convert-WindowsImage.ps1 사용 방법 정리
11078정성태10/21/201621983Windows: 128. Windows Server 2016 Nano 서버 VHD 이미지 만드는 방법 - TP5 기준
11077정성태10/21/201620477오류 유형: 363. Active Directory 서버의 NETLOGON 서비스가 멈췄을 때 발생하는 문제
11076정성태10/21/201620078오류 유형: 362. 윈도우 백업 시 오류 - 0x80780040
11075정성태10/20/201621002Windows: 127. Convert-WindowsImage.ps1 사용 방법 정리
... 106  107  108  109  110  111  112  [113]  114  115  116  117  118  119  120  ...