이 시나리오에서 마이크로 EC2 인스턴스의 MySQL 서버는 "InnoDB: mmap (x bytes) failed; errno 12" 오류와 함께 반복적으로 충돌이 발생합니다. 서버를 다시 시작해도 문제가 지속됩니다. MySQL 로그를 살펴보면 메모리 할당 부족으로 인해 InnoDB 버퍼 풀 초기화에 실패하고 있음이 분명해졌습니다.
InnoDB 버퍼 풀은 자주 액세스하는 데이터를 메모리에 저장하여 최적화합니다. 데이터베이스 작업의 성능. 그러나 이 경우 마이크로 인스턴스의 제한된 메모리 용량으로 인해 버퍼 풀에 충분한 공간을 할당할 수 없습니다. 결과적으로 InnoDB가 초기화에 실패하고 MySQL 서버가 오류 메시지와 함께 종료됩니다.
이 문제를 해결하려면 기본적으로 추가 역할을 하는 스왑 공간을 생성하는 것이 좋습니다. 가상 메모리. 이를 통해 운영 체제는 사용되지 않는 디스크 공간을 RAM으로 활용하여 InnoDB와 같은 중요한 작업에 사용 가능한 메모리를 늘릴 수 있습니다.
스왑 공간 생성에는 다음 단계가 포함됩니다.
dd if=/dev/zero of=/swapfile bs=1M count=1024
mkswap /swapfile
swapon /swapfile
/swapfile swap swap defaults 0 0
스왑 공간을 생성해도 문제가 해결되지 않으면 대안 해결책은 Amazon RDS(관계형 데이터베이스 서비스)를 사용하는 것입니다. RDS는 메모리와 스토리지 리소스가 보장된 전용 데이터베이스 인스턴스를 제공하는 AWS의 관리형 데이터베이스 서비스입니다. 데이터베이스를 RDS 인스턴스로 마이그레이션하면 마이크로 인스턴스의 제한된 메모리 할당 문제를 피할 수 있습니다.
위 내용은 마이크로 EC2 인스턴스의 MySQL 서버가 \'InnoDB: mmap (x bytes) failed; errno 12\' 메시지와 함께 충돌하는 이유는 무엇이며 어떻게 해결할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!