집 >
웹 프론트엔드 >
JS 튜토리얼 >
Node.js, AWS Lambda 및 Mongodb Atlas를 통한 서버리스 개발
Node.js, AWS Lambda 및 Mongodb Atlas를 통한 서버리스 개발
Joseph Gordon-Levitt
풀어 주다: 2025-02-15 12:11:12
원래의
334명이 탐색했습니다.
키 포인트
AWS Lambda, Node.js 및 MongoDB Atlas를 사용하는 서버리스 아키텍처를 사용하면 개발자가 서버를 관리하지 않고 코드를 실행하고 인코딩에 중점을 둔 반면 AWS는 인프라를 관리합니다. AWS Lambda는 MongoDB Atlas와 완벽하게 통합되어 데이터베이스 이벤트를 기반으로 기능을 트리거하여 강력한 실시간 응용 프로그램을 가능하게합니다.
보안 설정에는 권한이 제한된 MongoDB Atlas 데이터베이스 사용자 생성과 AWS 키 관리 서비스 (KMS)를 사용하여 민감한 환경 변수를 암호화하는 것이 포함됩니다.
Lambda 기능의 로컬 테스트는 AWS Lambda 환경을 로컬에서 시뮬레이션 할 수있는
와 같은 도구 덕분에 개발 및 디버깅 속도를 높일 수 있습니다.
Lambda 기능의 데이터베이스 연결 재사용 성능을 최적화하여 실행 시간 및 리소스 소비를 줄입니다.
프로덕션 환경에 배포하기 전에 올바른 사용자 역할과 화이트리스트 IP 주소를 설정하여 MongoDB Atlas 클러스터를 보호하여 덜 안전한 0.0.0.0/0 CIDR 블록을 피하십시오.
이 기사는 원래 MongoDB에 출판되었습니다. Sitepoint를 가능하게 한 파트너를 지원해 주셔서 감사합니다.
최근 몇 년 동안 개발자 환경은 엄청난 변화를 겪었습니다. 과거에는 개발자가 일반적으로 자체 기계에서 모든 도구 (데이터베이스, 웹 서버, 개발 ID…)를 실행하지만 Github, MongoDB Atlas 및 AWS Lambda와 같은 클라우드 서비스가이를 혁신하고 있습니다. 그들은 개발자가 의존성없이 (또는 적은 수의) 어디서나 코드를 작성하고 실행하는 것을 점점 더 쉽게 만듭니다.
몇 년 전, 당신이 충돌하거나, 기계를 잃어 버리거나, 방금 힘을 잃었다면, 새 기계를 다시 설정하고 이전에 다시 가져 오기 위해 모든 것을 올바르게 설정하고 구성하는 데 며칠이 걸릴 수 있습니다. 하나의 상태. lambda-local 클라우드 개발자 도구를 사용하면 이제 너무 많은 혼란을 일으키지 않고 한 랩탑에서 다른 랩탑으로 전환 할 수 있습니다. 그러나 이것이 모든 것이 잘되는 것을 의미하지는 않습니다. 클라우드에 코드를 쓰고 디버깅하는 것은 여전히 개발자로서 여전히 어려운 일이라는 것을 알고 있습니다.
이것은 내가이 블로그 게시물에서 당신에게 보여 주려고하는 것입니다 : AWS lambda node.js 기능을 MongoDB Atlas (MongoDB 용 DBAAS (데이터베이스))에서 호스팅하는 MongoDB 데이터베이스와 쉽게 통합하는 방법입니다. 보다 구체적으로, 우리는 MongoDB Atlas 데이터베이스에 저장된 컬렉션에 단일 문서를 작성하는 간단한 Lambda 기능을 작성합니다. 이 튜토리얼을 단계별로 안내하겠습니다. 한 시간 안에 마무리해야합니다.
필요한 요구 사항부터 시작하여 시작하겠습니다.
iAM 및 Lambda 서비스에 대한 관리에 액세스 할 수있는 사용자와 함께 사용 가능한 Amazon Web Services 계정. 아직 계정이없는 경우 무료 AWS 계정에 가입하십시오.
node.js가있는 로컬 기계 (나는 우리가 지역 개발 환경을 쉽게 제거하지 않을 것이라고 말 했어요 ...). 아래 튜토리얼에서 Mac OS X를 사용하지만 Windows 또는 Linux에서 동일한 작업을 수행하는 것은 비교적 쉽습니다.
실행중인 MongoDB Atlas 클러스터. 아직없는 경우 무료 MongoDB Atlas 계정에 가입하고 몇 번의 클릭만으로 클러스터를 만듭니다. 소규모 개발 프로젝트에 적합한 M0 무료 클러스터 계층을 시도 할 수도 있습니다! ).
이제 요구 사항을 이해 했으므로 Lambda 기능을 작성, 테스트 및 배포하기 위해 수행 할 특정 단계에 대해 논의 해 봅시다 :
MongoDB Atlas는 기본적으로 안전하지만 애플리케이션 개발자로서 응용 프로그램이 최소한의 권한 액세스에 대한 모범 사례를 준수하도록하기위한 몇 가지 조치를 취해야합니다. 즉, 응용 프로그램 데이터베이스에만 읽기/쓰기 액세스가있는 MongoDB Atlas 데이터베이스 사용자를 만들어 권한을 미세 조정합니다.
우리는 로컬 컴퓨터에 node.js 프로젝트를 설정하고 Amazon Web Services에 배포하기 전에 Lambda 코드 엔드 투 엔드를 로컬로 테스트해야합니다.
그런 다음 AWS Lambda 함수를 만들고 Node.js 프로젝트를 업로드하여 초기화합니다.
마지막으로, 우리는 Lambda 함수를 일부 수정하여 일부 민감한 데이터 (예 : MongoDB Atlas Connection String)를 암호화하고 기능 코드에서 해독 할 것입니다.
vpc 피어링에 대한 간단한 설명
나는 두 가지 이유로 MongoDB Atlas 클러스터와 AWS Lambda 사이에 VPC 피어링을 설정하는 세부 사항에 들어 가지 않았습니다. 1) 이미 VPC 피어링 설정에 대한 자세한 문서 페이지가 있습니다. Atlas의 VPC 피어링;
VPC 피어링을 설정하지 않으면 다음이 발생합니다.
당신은 MongoDB Atlas 클러스터 IP 화이트리스트에 악명 높은 0.0.0.0/0 CIDR 블록을 추가해야합니다. ATLAS 데이터베이스를 호출하는 데 어떤 IP 주소 AWS가 사용하는지 알지 못하기 때문입니다.
당신은 Lambda 함수와 Atlas 클러스터 사이의 대역폭 사용 비용을 지불합니다.
이 데모 코드를 작성하려는 경우이 두 가지 경고는 괜찮을 수 있지만 생산 환경에서 사용할 수있는 Lambda-Atlas 통합을 배포하려는 경우 VPC 피어링을 설정하는 것입니다. 안전 모범 사례를 적극 권장하는 것이 좋습니다. M0은 현재 무료 제품입니다.
개발 환경과 트래픽 웹 사이트가 낮은 경우 M0, M10 및 M20 인스턴스 크기는 정상이어야합니다. 그러나 교통량이 많은 응용 프로그램 또는 대규모 데이터 세트를 지원하는 생산 환경의 경우 M30 이상의 인스턴스 크기를 사용하는 것이 좋습니다.
MongoDB Atlas 클러스터에서 보안을 설정하십시오
애플리케이션이 최소 권한 액세스 정책을 준수하는지 확인하십시오. 데이터를 악의적 인 위협으로부터 보호하는 데 중요합니다. 그렇기 때문에 여행 데이터베이스에 대한 읽기/쓰기 만 액세스 할 수있는 특정 데이터베이스 사용자를 설정합니다. Mongodb Atlas에서 이것을 구현하는 방법을 봅시다 :
클러스터 페이지에서 보안 탭을 선택하고 새 사용자 추가 버튼을 누르십시오.
사용자 권한 섹션에서
그런 다음 더 미세한 세분화 액세스 제어 권한을 할당하도록 선택할 수 있습니다.
선택한 역할 드롭 다운 목록에서 readWrite를 선택하고 문서를 저장하는 데 사용할 데이터베이스 이름으로 데이터베이스 필드를 작성하십시오. 나는 여행의 이름을 선택했습니다.
비밀번호 섹션에서 자동으로 보안 비밀번호를 생성하고 생성 된 비밀번호를 기록하거나 좋아하는 암호를 설정하십시오. 그런 다음 "사용자 추가"버튼을 눌러이 사용자가 생성되었는지 확인하십시오.
MongoDB Atlas 데이터베이스에 연결하려면 Lambda 코드에 필요하기 때문에 클러스터 연결 문자열을 가져 오겠습니다.
MongoDB Atlas 클러스터를 생성했다고 가정하고 클러스터 옆의 "Connect"버튼을 누릅니다.
URI Connection String 값을 복사하여 텍스트 문서에 안전하게 저장하십시오. 방금 설정 한 암호뿐만 아니라 나중에 코드에 필요합니다.
또한 VPC 피어링을 사용하지 않는 경우 IP 화이트리스트 탭으로 이동하여 0.0.0.0/0 CIDR 블록을 추가하거나 어디서나 액세스 허용 버튼을 누릅니다. 알림으로,이 설정은 제작 환경에서 사용하지 않는 것이 좋습니다. MongoDB Atlas 클러스터를 악의적 인 공격에 취약하게 만들 수 있습니다.
로컬 node.js 프로젝트를 만듭니다
Lambda 함수는 여러 언어를 지원하는 반면, 다기능 프로그래밍 언어로 JavaScript의 인기가 높아지고 Mean and Mern Stacks (Mongodb, Express.js, Angular /React , node.js 약어 -이 주제에 대한 Andrew Morgan의 훌륭한 개발자 블로그 시리즈를 확인하십시오). 또한 솔직히 말해서, 나는 무거운 개발 도구와 컴파일러가 필요하지 않은 해석 된 가벼운 언어라는 것을 좋아합니다.
위 내용은 Node.js, AWS Lambda 및 Mongodb Atlas를 통한 서버리스 개발의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!