다음을 통해 공유


MySQL 온-프레미스에서 Azure Database for MySQL로 마이그레이션: 평가

온-프레미스 환경에서 Azure Database for MySQL로의 MySQL 데이터베이스 마이그레이션을 평가하는 것은 원활하고 성공적인 전환을 보장하는 중요한 첫 번째 단계입니다. 이 문서에서는 평가 단계와 관련된 주요 요소 및 고려 사항을 철저히 검토합니다. 현재 인프라를 평가하고, 잠재적인 문제를 식별하고, Azure의 관리되는 데이터베이스 서비스의 이점을 이해하여 조직의 목표에 부합하는 정보에 입각한 결정을 내릴 수 있습니다. 성능을 향상시키거나, 확장성을 향상시키거나, 운영 비용을 줄이는 것을 목표로 하든, 이 가이드에서는 마이그레이션 전략을 효과적으로 계획하고 실행하는 데 필요한 인사이트를 제공합니다.

필수 조건

MySQL 온-프레미스를 Azure Database for MySQL로 마이그레이션: 대표적인 사용 사례

개요

MySQL 워크로드를 마이그레이션하기 전에 수행해야 하는 많은 실사가 있습니다. 여기에는 데이터, 호스팅 환경 및 애플리케이션 워크로드를 분석하여 Azure 랜딩 존이 올바르게 구성되고 곧 마이그레이션될 워크로드를 호스트할 준비가 되었는지 확인하는 작업이 포함됩니다.

제한 사항

Azure Database for MySQL은 PaaS으로 실행되는 MySQL 커뮤니티 버전의 완전 지원되는 버전입니다. 그러나 초기 평가를 수행하는 경우 익숙해져야 하는 몇 가지 제한 사항이 있습니다.

가장 중요한 것은 다음과 같습니다.

  • InnoDBMemory 전용 스토리지 엔진 지원

  • 제한적 Privilege 지원(DBA, SUPER, DEFINER)

  • 사용하지 않도록 설정된 데이터 조직 문(SELECT ... INTO OUTFILE, LOAD DATA INFILE)

  • 중요한 데이터베이스 자동 마이그레이션(5.6에서 5.7로, 5.7에서 8.0으로)

  • MySQL Server UDF(사용자 정의 함수)를 사용하는 경우 so 또는 dll 구성 요소를 Azure Database for MySQL에 업로드할 수 있는 기능이 없으므로 실행 가능한 유일한 호스팅 옵션은 Azure Hosted VM입니다.

다른 많은 항목은 관리자가 작동 데이터 워크로드 수명 주기 관리의 일부로 숙지해야 하는 운영 측면입니다. 이 가이드의 마이그레이션 후 관리 섹션에서 이러한 여러 운영 측면을 살펴봅니다.

MySQL 버전

MySQL은 1995년부터 다채로운 역사를 갖습니다. 이때부터 널리 사용되는 데이터베이스 관리 시스템으로 발전했습니다. Azure Database for MySQL은 MySQL 버전 5.6부터 지원하기 시작했으며 5.7과 최근의 8.0까지 지원하고 있습니다. Azure Database for MySQL 버전 지원의 최신 버전은 지원되는 Azure Database for MySQL 서버 버전을 참조하세요. 마이그레이션 후 관리 섹션에서는 Azure에서 MySQL 인스턴스에 업그레이드(예: 5.7.20 ~ 5.7.21)가 적용되는 방법을 검토합니다.

참고 항목

버전이 5.x에서 8.0으로 대폭 업그레이드된 것은 Oracle에서 MySQL을 인수했기 때문입니다. MySQL 기록에 대한 자세한 내용은 MySQL wiki 페이지를 참조하세요.

원본 MySQL 버전을 알아야 합니다. 시스템을 사용하는 애플리케이션에서 해당 버전과 관련된 데이터베이스 개체와 기능을 사용할 수 있습니다. 데이터베이스를 더 낮은 버전으로 마이그레이션하면 호환성 문제와 기능 손실이 발생할 수 있습니다. 또한 도입된 기능이 애플리케이션을 중단시킬 수 있으므로 최신 버전으로 마이그레이션하기 전에 데이터와 애플리케이션 인스턴스를 철저하게 테스트하는 것이 좋습니다.

마이그레이션 경로 및 버전에 영향을 미칠 수 있는 예:

  • 5.6: 올바른 스토리지에 대한 TIMESTAMP 열(밀리초) 및 전체 텍스트 검색

  • 5.7: 네이티브 JSON 데이터 형식 지원

  • 8.0: NoSQL 문서 저장소, 원자성 및 크래시 안전 DDL 및 JSON 테이블 함수 지원

    참고 항목

    MySQL 5.6 일반 지원은 2021년 2월에 중단됩니다. MySQL 워크로드를 MySQL 버전 5.7 이상으로 마이그레이션해야 합니다.

MySQL 서버 버전을 확인하려면 다음을 수행합니다.

SHOW VARIABLES LIKE "%version%";

데이터베이스 스토리지 엔진

Azure Database for MySQL에서는 InnoDBMemory 데이터베이스 스토리지 엔진만 지원합니다. MyISAM과 같은 다른 스토리지 엔진을 지원되는 스토리지 엔진으로 마이그레이션해야 합니다. MyISAM과 InnoDB 간의 차이점은 작동 기능과 성능 결과입니다. 상위 수준 테이블과 스키마 구조는 일반적으로 엔진 간에 변경되지 않지만 스토리지 및 성능상의 이유로 인덱스와 테이블 열 유형이 변경될 수 있습니다. InnoDB는 대용량 데이터 파일이 포함된 것으로 알려져 있지만 이러한 스토리지 세부 정보는 Azure Database for MySQL 서비스에서 관리됩니다.

MyISAM에서 InnoDB로 마이그레이션

MyISAM 데이터베이스 및 테이블을 InnoDB 테이블로 변환해야 합니다. 변환한 후에 애플리케이션의 호환성과 성능을 테스트해야 합니다. 대부분의 경우 테스트를 수행하려면 테이블을 다시 만들고 DDL 문을 통해 대상 스토리지 엔진을 변경해야 합니다. 이러한 변경 사항은 Azure 대상에서 스키마를 만드는 동안에 발생하므로 마이그레이션 중에 수행해야 할 필요는 거의 없습니다. 자세한 내용은 MySQL 웹 사이트에서 테이블 변환 개발자 문서를 검토하세요.

유용한 테이블 정보를 찾으려면 다음 쿼리를 사용합니다.

    SELECT
        tab.table_schema,
        tab.table_name,
        tab.engine as engine_type,
        tab.auto_increment,
        tab.table_rows,
        tab.create_time,
        tab.update_time,
        tco.constraint_type
    FROM information_schema.tables tab
    LEFT JOIN information_schema.table_constraints tco
        ON (tab.table_schema = tco.table_schema
            AND tab.table_name = tco.table_name
            )
    WHERE
        tab.table_schema NOT IN ('mysql', 'information_schema', 'performance_
schema', 'sys')
        AND tab.table_type = 'BASE TABLE';

참고 항목

여러 데이터베이스에서 INFORMATION_SCHEMA에 대해 쿼리를 실행하면 성능에 영향을 줄 수 있습니다. 사용량이 낮은 기간 동안 실행합니다.

테이블을 MyISAM에서 InnoDB로 변환하려면 다음을 실행합니다.

ALTER TABLE {table\_name} ENGINE=InnoDB;

참고 항목

이 변환 방식을 사용하면 테이블이 잠기게 되며 모든 애플리케이션은 작업이 완료될 때까지 대기합니다. 테이블 잠금으로 인해 데이터베이스가 짧은 기간 동안 오프라인으로 표시됩니다.

대신 구조는 같지만 스토리지 엔진이 다른 테이블을 만들 수 있습니다. 만든 후에 행을 새 테이블에 복사합니다.

INSERT INTO {table\_name} SELECT * FROM {myisam\_table} ORDER BY {primary\_key\_columns}

참고 항목

이 방식이 성공하려면 원래 테이블을 삭제한 다음, 새 테이블 이름을 바꿔야 합니다. 이 작업으로 인해 짧은 가동 중지 시간이 발생합니다.

데이터베이스 데이터 및 개체

데이터는 데이터베이스 마이그레이션의 한 가지 구성 요소입니다. 애플리케이션이 계속 안정적으로 실행되도록 데이터베이스 지원 개체를 마이그레이션하고 유효성을 검사해야 합니다.

다음은 마이그레이션 전후에 인벤토리해야 하는 항목 목록입니다.

  • 테이블(스키마)

  • 기본 키, 외래 키

  • 인덱스

  • 함수

  • 수립

  • 트리거

사용자 정의 함수

MySQL을 사용하면 외부 코드를 호출하는 함수를 사용할 수 있습니다. 아쉽게도 외부 코드와 함께 UDF(사용자 정의 함수)를 사용하는 데이터 워크로드는 Azure Database for MySQL로 마이그레이션할 수 없습니다. 이는 필요한 MySQL 함수의 백업 또는 dll 코드를 Azure 서버에 업로드할 수 없기 때문입니다.

다음 쿼리를 실행하여 설치될 수 있는 UDF를 찾습니다.

SELECT * FROM mysql.func;

원본 시스템

마이그레이션 준비에 필요한 작업의 양은 원본 시스템과 해당 위치에 따라 달라질 수 있습니다. 데이터베이스 개체 외에도 데이터를 원본 시스템에서 대상 시스템으로 가져오는 방법을 고려합니다. 방화벽과 기타 네트워킹 구성 요소가 원본과 대상 사이에 있는 경우 데이터 마이그레이션이 어려울 수 있습니다.

또한 인터넷을 통해 데이터를 이동하는 것이 Azure 전용 회로를 사용하는 것보다 더 느릴 수 있습니다. 따라서 기가바이트, 테라바이트 및 페타바이트 단위의 많은 데이터를 이동할 때는 원본 네트워크와 Azure 네트워크 간에 ExpressRoute 연결을 설정하는 것이 좋습니다.

ExpressRoute가 이미 있는 경우 다른 애플리케이션에서 연결을 사용하고 있을 가능성이 높습니다. 기존 경로를 통해 마이그레이션을 수행하면 네트워크 처리량에 부담을 줄 수 있으며 네트워크를 사용하는 마이그레이션과 다른 애플리케이션에서 상당한 성능 저하가 발생할 수 있습니다.

마지막으로 디스크 공간을 평가해야 합니다. 큰 데이터베이스를 내보낼 때 데이터 크기를 고려합니다. 도구가 실행되고 있는 시스템을 확인하고, 궁극적으로 내보내기 위치에 내보내기 작업을 수행할 수 있는 충분한 디스크 공간이 있는지 확인합니다.

클라우드 공급자

AWS(Amazon Web Services)와 같은 클라우드 서비스 공급자에서 데이터베이스를 마이그레이션하려면 클라우드 호스팅 MySQL 인스턴스에 액세스하기 위해 추가 네트워킹 구성 단계가 필요할 수 있습니다. Data Migration Services와 같은 마이그레이션 도구는 외부 IP 범위에서 액세스해야 하며, 그렇지 않으면 차단될 수 있습니다.

온-프레미스

클라우드 공급자와 마찬가지로 MySQL 데이터 워크로드가 방화벽이나 기타 네트워크 보안 계층 뒤에 있는 경우 온-프레미스 인스턴스와 Azure Database for MySQL 간에 경로를 만들어야 합니다.

도구

다양한 도구와 메서드를 사용하여 MySQL 데이터 워크로드 및 환경을 평가할 수 있습니다. 각 도구는 다양한 평가 및 마이그레이션 기능 세트를 제공합니다. 이 가이드의 일부로 MySQL 데이터 워크로드를 평가하는 데 가장 일반적으로 사용되는 도구를 검토합니다.

Azure 마이그레이션

Azure Migrate에서는 MySQL 데이터베이스 워크로드를 직접 마이그레이션할 수 없습니다. 하지만 가상 머신에 또는 하드웨어 기반 머신에 호스트되는지에 관계없이 관리자가 어떤 사용자와 어떤 애플리케이션에서 데이터를 사용하는지 잘 모를 때 사용할 수 있습니다. MySQL 워크로드를 호스트하는 머신에서 모니터링 에이전트를 설치하고 실행하면 종속성 분석을 수행할 수 있습니다. 에이전트는 월과 같은 설정된 기간 동안 정보를 수집합니다. 종속성 데이터를 분석하여 데이터베이스에 대한 알 수 없는 연결을 찾을 수 있습니다. 연결 데이터는 보류 중인 마이그레이션에 대한 알림을 받아야 하는 애플리케이션 소유자를 식별하는 데 도움이 될 수 있습니다.

애플리케이션과 사용자 연결 데이터의 종속성 분석 외에도 Azure Migrate는 Hyper-V, VMware 또는 물리적 서버를 분석하여 적절한 대상 환경을 제안하는 데 도움이 되는 데이터베이스 워크로드의 사용 패턴을 제공하는 데 사용될 수 있습니다.

Linux용 Telgraf

Linux 워크로드는 MMA(Microsoft Monitoring Agent)를 활용하여 가상 및 물리적 컴퓨터에서 데이터를 수집할 수 있습니다. 또한 Telegraf 에이전트 및 광범위한 플러그 인 배열을 사용하여 성능 메트릭을 수집하는 것이 좋습니다.

서비스 계층

평가 정보(CPU, 메모리, 스토리지 등)를 확보한 경우 마이그레이션 사용자는 다음으로 사용할 Azure Database for MySQL 가격 책정 계층을 결정합니다.

현재 다음과 같은 3가지 계층이 있습니다.

  • 기본: 가벼운 컴퓨팅 및 I/O 성능이 필요한 워크로드

  • 범용: 스케일링 가능한 I/O 처리량과 함께 컴퓨팅과 메모리 간의 균형이 필요한 대부분의 비즈니스 워크로드

  • 메모리 최적화: 보다 빠른 트랜잭션 처리와 우수한 동시성을 위해 메모리 내 성능이 필요한 고성능 데이터베이스 워크로드

계층 결정은 데이터 워크로드의 RTO 및 RPO 요구 사항에 의해 영향을 받을 수 있습니다. 데이터 워크로드에 스토리지가 4TB 이상 필요한 경우 추가 단계가 필요합니다. 스토리지를 최대 16TB까지 지원하는 지역을 검토하고 선택합니다.

일반적으로 의사 결정은 스토리지와 IOPS 또는 초당 입출력 작업, 요구 사항에 중점을 둡니다. 따라서 대상 시스템 크기는 항상 최소한 원본 시스템의 스토리지 크기 만큼이어야 합니다. 또한 IOPS는 3/GB로 할당되므로 IOP 필요량을 최종 스토리지 크기에 일치시켜야 합니다.

요소 계층
기본 개발 머신은 1TB 미만의 스토리지를 사용하여 고성능을 필요로 하지 않습니다.
범용 기본 계층이 제공할 수 있는 것보다 더 많은 IOPS가 필요하지만 16TB 미만 스토리지, 4GB 미만 메모리가 필요합니다.
메모리 최적화 높은 동시성 innodb_buffer_pool_instances, 큰 BLOB 크기, 복제 복사본이 많은 시스템 등, 높은 메모리나 높은 캐시, 버퍼 관련 서버 구성을 활용하는 데이터 워크로드

비용

WWI는 전체 WWI MySQL 데이터 워크로드를 평가한 후 최소 vCore 4개 이상, 메모리 20GB, IOP 용량이 450 IOPS인 스토리지 공간 최소 100GB 이상이 필요하다고 결정했습니다. 450 IOPS 요구 사항때문에 Azure Database for MySQL IOPS 할당 방법으로 인해 150GB 이상의 스토리지를 할당해야 합니다. 또한 백업 스토리지 및 하나의 읽기 복제본으로 프로비전된 서버 스토리지의 최대 100% 이상이 필요합니다. 아웃바운드 송신이 5GB를 초과할 것으로 예상하지는 않습니다.

WWI는 Azure Database for MySQL 가격 계산기를 사용하여 Azure Database for MySQL 인스턴스에 대한 비용을 결정할 수 있었습니다. 2020년 9월부터 TCO(총 소유 비용)는 WWI Conference 데이터베이스의 다음 테이블에 표시됩니다.

리소스 설명 수량 비용
컴퓨팅(범용) vCore 4개, 20GB 1 @ $0.351/시간 3074.76달러/년
스토리지 5GB 12 x 150 @ $0.115 207달러/년
Backup 프로비전된 스토리지의 최대 100% 프로비전된 서버 스토리지의 최대 100%까지 추가 비용 없음 0.00달러/년
읽기 복제본 1초 지역 복제본 컴퓨팅 + 스토리지 3281.76달러/년
네트워크 < 5GB/월 송신 Free
합계 6563.52달러/년

초기 비용을 검토한 후 WWI의 CIO는 3년보다 훨씬 긴 기간 동안 Azure에 있음을 확인했습니다. 연간 4,000달러를 추가로 절약할 수 있도록 3년 예약 인스턴스를 사용하기로 결정했습니다.

리소스 설명 수량 비용
컴퓨팅(범용) vCore 4개 1 @ $0.1375/시 1204.5달러/년
스토리지 5GB 12 x 150 @ $0.115 207달러/년
Backup 프로비전된 스토리지의 최대 100% 프로비전된 서버 스토리지의 최대 100%까지 추가 비용 없음 0.00달러/년
네트워크 < 5GB/월 송신 Free
읽기 복제본 1초 지역 복제본 컴퓨팅 + 스토리지 1411.5달러/년
합계 $2,823 / yr

위 표와 같이 TCO(총 소유 비용)에서 백업, 네트워크 송신 및 모든 읽기 복제본을 고려해야 합니다. 더 많은 데이터베이스가 추가됨에 따라 생성된 스토리지와 네트워크 트래픽을 추가적인 비용 기반 요소로 고려해야 합니다.

참고 항목

위 예상치에 애플리케이션 계층에 대한 ExpressRoute, Azure App Gateway, Azure Load Balancer 또는 App Service 비용은 포함되지 않습니다.

위 가격은 언제든지 변경될 수 있으며 지역에 따라 달라질 수 있습니다.

애플리케이션 영향

Azure Database for MySQL로 전환할 때 SSL(Secure Sockets Layer) 기반 통신으로의 전환이 애플리케이션에 가장 중요한 변경 중 하나일 가능성이 높습니다. SSL은 Azure Database for MySQL에서 기본적으로 사용하도록 설정되며, 온-프레미스 애플리케이션 및 데이터 워크로드가 SSL을 사용하여 MySQL에 연결하도록 설정되지 않은 것 같습니다. 사용하면 SSL 사용으로 인해 처리 오버헤드가 추가되므로 모니터링이 필요합니다.

참고 항목

SSL은 기본적으로 사용되지만 사용하지 않도록 설정하는 옵션이 제공됩니다.

Azure Database for MySQL에 안전하게 연결하기 위한 사용자 애플리케이션의 SSL 연결 구성의 활동을 수행하여 이러한 강력한 인증 경로를 지원하도록 애플리케이션을 다시 구성합니다.

마지막으로 애플리케이션 연결 문자열에서 서버 이름을 수정하거나 새 Azure Database for MySQL 서버를 가리키도록 DNS를 전환합니다.

WWI 시나리오

WWI는 다음 표와 같이 MySQL 데이터 자산에 관한 정보를 수집하여 평가를 시작했습니다.

이름 원본 Db 엔진 크기 IOPS 버전 담당자 가동 중지 시간
WwwDB AWS(PaaS) InnoDB 1GB 150 5.7 마케팅 부서 1시간
BlogDB AWS(PaaS) InnoDB 1GB 100 5.7 마케팅 부서 4시간
ConferenceDB 온-프레미스 InnoDB 5GB 50 5.5 영업 부서 4시간
CustomerDB 온-프레미스 InnoDB 10 GB 75 5.5 영업 부서 2시간
SalesDB 온-프레미스 InnoDB 20GB 75 5.5 영업 부서 1시간

허용 가능한 가동 중지 시간을 결정하기 위해 각 데이터베이스 소유자에게 연락했습니다. 허용 가능한 데이터베이스 가동 중지 시간을 기준으로 계획 및 마이그레이션 방법을 선택했습니다.

첫 번째 단계에서 WWI는 ConferenceDB 데이터베이스에만 중점을 두었습니다. 팀은 데이터 워크로드 마이그레이션을 진행하는 데 도움이 되는 마이그레이션 환경이 필요했습니다. 간단한 데이터베이스 구조와 허용 가능한 대규모 가동 중지 시간으로 인해 ConferenceDB 데이터베이스를 선택했습니다. 데이터베이스가 마이그레이션되면 팀은 애플리케이션을 안전한 Azure 랜딩 존으로 마이그레이션하는 데 주력했습니다.

평가 검사 목록

  • 워크로드가 대상 시스템에서 성공적으로 실행되는지 테스트합니다.

  • 마이그레이션에 적합한 네트워킹 구성 요소가 준비되어 있는지 확인합니다.

  • 데이터 워크로드 리소스 요구 사항을 이해합니다.

  • 총 비용을 예측합니다.

  • 가동 중지 시간 요구 사항을 이해합니다.

  • 애플리케이션을 변경할 준비를 수행합니다.

다음 단계