빠른 시작
이 빠른 시작 가이드로 5-10분 안에 NetFUNNEL 4 CloudFront Agent를 시작하세요.
사전 요구사항
- NetFUNNEL 콘솔 액세스
- AWS 계정 및 Lambda@Edge 지원
- CloudFront Distribution 생성 및 관리 권한
- IAM 역할 생성 및 정책 첨부 권한
1단계: Client ID 가져오기
- NetFUNNEL 콘솔로 이동
- 우측 상단의 프로필 아이콘 클릭
통합 자격 증명(Integration Credentials) 메뉴 선택Client ID복사
2단계: IAM 역할 생성
- AWS IAM 콘솔 → [역할] 클릭
- [역할 생성] 클릭
- 신뢰할 수 있는 엔터티: AWS 서비스 선택
- 사용 사례: Lambda 선택
- [다음: 권한] 클릭
Trust Entity 설정
- 역할 생성 후 [Trust Entity] 탭 클릭
- Trust Entity 편집 후 아래 JSON 붙여넣기:
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Principal": {
"Service": [
"edgelambda.amazonaws.com",
"lambda.amazonaws.com"
]
},
"Action": "sts:AssumeRole"
}
]
}
정책 첨부
- [권한] 탭 클릭
- [권한 추가] → [인라인 정책 만들기] 클릭
- JSON 탭에 아래 정책 붙여넣기:
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"logs:CreateLogGroup",
"logs:CreateLogStream",
"logs:PutLogEvents"
],
"Resource": "*"
}
]
}
3단계: Lambda 함수 생성
Lambda 함수 생성
- us-east-1 리전의 Lambda 콘솔로 이동 (필수)
- [함수 생성] 클릭
- [처음부터 작성] 선택
- 함수 이름 입력 (예: "netfunnel-agent")
- 런타임: Node.js 선택
- 위에서 생성한 IAM 역할 선택
- [함수 생성] 클릭
Lambda 함수 설정
- https://agent-lib.stclab.com/agents/cdn/cloudfront/netfunnel-cloudfront-agent-latest.js 에서
netfunnel-cloudfront-agent.js파일 다운로드 - [코드] 탭에서 코드 소스에
netfunnel-cloudfront-agent.js파일 업로드 index.mjs파일 열고 아래 코드 작성:
import handleEvent from './netfunnel-cloudfront-agent.js';
const config = {
clientID: "{{CLIENT_ID}}",
}
export const handler = async (event) => {
return await handleEvent(event, config)
};
package.json파일 생성 후 아래 코드 붙여넣기:
{
"name": "cloudfront-agent",
"type": "module",
"dependencies": {}
}
- [Deploy] 버튼 클릭
- [버전] 탭 → [새 버전 발행] 클릭
4단계: CloudFront 설정
Lambda@Edge 연결
- Lambda@Edge를 적용할 CloudFront Distribution 선택
- [동작] 탭에서 항목 선택 후 [편집] 클릭
- 하단의 함수 연결에서:
- 뷰어 요청: 생성한 Lambda 함수 ARN 입력 (버전 포함, 예:
:1) - 뷰어 응답: 생성한 Lambda 함수 ARN 입력 (버전 포함, 예:
:1)
- 뷰어 요청: 생성한 Lambda 함수 ARN 입력 (버전 포함, 예:
- [변경 사항 저장] 클릭
CloudFront 무효화
- [무효화] 탭 클릭
- [무효화 생성] 클릭
- 객체 경로:
/*입력 - [무효화 생성] 클릭
- 무효화 완료 후 Lambda@Edge 연결 적용