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]

... 181  182  183  184  185  186  187  188  [189]  190  191  192  193  194  195  ...
NoWriterDateCnt.TitleFile(s)
227정성태4/13/200617379Team Foundation Server: 2. TFS 빌드 오류 유형 - MSBUILD: warning : Specified cast is not valid
226정성태4/13/200615345Team Foundation Server: 1. TFS 오류 유형 - TF50608: Unable to retrieve information for security object
225정성태10/17/200614901.NET Framework: 67. VS.NET 2005 도구 상자에 있는 Workflow Activity 항목의 아이콘 변경
223정성태4/13/200626171.NET Framework: 66. Microsoft .NET Framework 2.0 Configuration 수동 설치파일 다운로드1
224정성태4/13/200619727    답변글 .NET Framework: 66.1. "Microsoft .NET Framework 2.0 Configuration" MSI 설치 파일 버전파일 다운로드1
222정성태4/13/200618732.NET Framework: 65. VS.NET 2005: 파일 기반 웹 프로젝트의 "Virtual Path" 제거
220정성태4/13/200616469.NET Framework: 64. ClickOnce - 배포 시 오류 : "Error: An unexpected error occurred -- The parameter is incorrect."
219정성태4/13/200631269.NET Framework: 63. ClickOnce - 최초 실행 시 보안 경고창 없애는 방법 [1]
216정성태4/13/200618327스크립트: 8. 3월 1일 ActiveX Patch 적용 후, JS 로 수정한 임베딩 컨트롤이 여전히 비활성화 되는 문제 [2]
215정성태4/13/200619666.NET Framework: 62. ASP.NET 웹 컨트롤 렌더링 가로채기
214정성태4/13/200619010.NET Framework: 61. DateTime - DateTime = 사이의 "Month" 수 계산 [2]
213정성태4/13/200621274.NET Framework: 60. localhost 이외의 컴퓨터에서 asmx 테스트 페이지 호출 [1]
218정성태4/13/200619640    답변글 .NET Framework: 60.1. asmx 테스트 페이지를 보여주고 싶지 않을 때
211정성태4/13/200617513VS.NET IDE: 38. VS.NET 2005 - "Export Template" 메뉴
210정성태4/13/200616986.NET Framework: 59. EXE 참조 가능 - VS.NET 2005 [2]
209정성태4/13/200616482스크립트: 7. 4월 12일 ActiveX 패치 문제를 해결할 수 있는 가장 간단한 방법 [6]파일 다운로드1
208정성태10/21/200616210Windows: 1. 성태도 ^^ Vista 설치 해봤습니다.
212정성태10/20/200615748    답변글 Windows: 1.1. Vista 에서 WinFX 런타임 구동
207정성태4/13/200624732VC++: 23. VC++ RGS 파일에 사용자 정의 파라미터 추가
205정성태4/13/200621792VS.NET IDE: 37. devenv.exe를 이용한 Command Line 컴파일 [1]
204정성태5/8/200617012웹: 2. Server Unavailable - Server Application Unavailable
203정성태4/13/200615875웹: 1. IIS 설정 옵션: Verify(Check) that file exists
202정성태4/13/200615581VS.NET IDE: 36. Automatically synchronize with an Internet time server
201정성태4/13/200618631기타: 12. XMLHTTP Failure and SUS Admin
200정성태4/13/200618013.NET Framework: 58. 웹 서비스 메서드 호출 오류 유형 - text/html; charset=xxx, but expected 'text/xml'
199정성태4/13/200619362스크립트: 6. XHTML or HTML 4.01 표준 준수
... 181  182  183  184  185  186  187  188  [189]  190  191  192  193  194  195  ...