효율적 모바일 서비스를 위한 AWS 빌딩블럭 - API Gateway 및 Device Farm을 중심으로 (윤석찬, AWS 테크에반젤리스트)Amazon Web Services Korea
AWS 월간 웨비나 8월 녹화 동영상은 아래 링크를 참고하십시오.
https://aws.amazon.com/ko/blogs/korea/category/webinar/
---
모바일 시장이 확대됨에 따라 적은 비용으로 더 빠르게 모바일 사용자를 대상으로 한 모바일 앱 및 웹 서비스를 개발하는 것이 점차 더 중요해지고 있습니다.
이 강연에서는 AWS가 제공하는 Amazon Cognito, Mobile Analytics 및 SNS 등 모바일 서비스들과 SDK를 통해 더 빠르게 모바일 서비스를 개발해 사용자의 요구 사항에 대응하고 확장성을 갖춘 모바일 앱을 만드는 방법에 대해알아봅니다.
또한, AWS Lambda라는 클라우드 함수를 이용한 손쉬운 비지니스 로직 구현, 새로 나온 Amazon DeviceFarm을 통한 자동화된 앱 테스트 및 Amazon API Gateway를 통한 모바일 백엔드 구축 방법 등 서버 없이도 효율적인 모바일 서비스 아키텍처를 구성하는 방법을 알려드립니다
최근 입문용 혹은 개발 및 데이터 분석 용도로 파이썬을 사용하는 개발자들이 많이 늘고 있습니다. 본 세션에서는 파이썬을 활용하여 AWS에서 해 볼 수 있는 다양한 서비스와 기능을 소개하고자 합니다. 그 중에서도 Django 및 Flask 같은 웹 프레임워크를 AWS Elastic Beanstalk으로 손쉽게 배포하고 운영하는 방법, AWS Lambda를 통해 Python 기반 서버리스 애플리케이션을 제작하는 방법 그리고, Boto3와 AWS Python SDK를 통해 AWS의 다양한 서비스 API를 다루는 방법을 살펴 봅니다. Python으로 구성된 AWS 기반 인기 오픈 소스 프로젝트를 소개하여 직접 참여하는 방법을 안내합니다. 특히, 가상 서버 호스팅인 AWS re:Invent에서 새로 소개된 Amazon Lightsail 등도 함께 소개합니다.
연사: 모두싸인 CTO 정승현
행사 제목: 아마존-부산클라우드혁신센터 Startup Member Day
내용 요약: '모두싸인'이라는 전자계약 서비스를 만드는 로아팩토리가 MVP(최소기능제품)부터 12만 명의 회원 서비스가 되기까지의 경험으로 보는 스타트업의 성장 단계 별 AWS 아키텍처 진화와 비용절감 과정
클라우드 기반의 실시간 비딩 시스템 아키텍처를 구축하는 방법에 대해 설명하는 백서 [Building a Real-Time Bidding Platform on AWS]의 내용을 AWS 코리아의 김필중 솔루션즈 아키텍트가 한글로 요약한 슬라이드입니다. 어떻게 클라우드가 RTB의 필수 요소인 낮은 지연시간과 확장성을 확보하는 데 도움이 될 수 있는지 설명하고, 실제 고객 사례를 통해 이러한 아키텍처를 구성하는 법을 살펴보실 수 있습니다.
자바개발자가 최대한 빠르게 서비스를 오픈하는 방법 - 최진환 (드라마앤컴퍼니) :: AWS Community Day Online 2021AWSKRUG - AWS한국사용자모임
사이드프로젝트를 진행하면서 겪은 다양한 인프라 구축 노하우를 소개합니다.왜 EKS가 아닌 Elastic Beanstalk를 사용했는지, Codepipeline을 이용한 깃헙에서 배포까지의 플로우, AWS ChatBot을 사용한 모니터링과 CodeBuild로 빌드하기 등을 소개합니다.
효율적 모바일 서비스를 위한 AWS 빌딩블럭 - API Gateway 및 Device Farm을 중심으로 (윤석찬, AWS 테크에반젤리스트)Amazon Web Services Korea
AWS 월간 웨비나 8월 녹화 동영상은 아래 링크를 참고하십시오.
https://aws.amazon.com/ko/blogs/korea/category/webinar/
---
모바일 시장이 확대됨에 따라 적은 비용으로 더 빠르게 모바일 사용자를 대상으로 한 모바일 앱 및 웹 서비스를 개발하는 것이 점차 더 중요해지고 있습니다.
이 강연에서는 AWS가 제공하는 Amazon Cognito, Mobile Analytics 및 SNS 등 모바일 서비스들과 SDK를 통해 더 빠르게 모바일 서비스를 개발해 사용자의 요구 사항에 대응하고 확장성을 갖춘 모바일 앱을 만드는 방법에 대해알아봅니다.
또한, AWS Lambda라는 클라우드 함수를 이용한 손쉬운 비지니스 로직 구현, 새로 나온 Amazon DeviceFarm을 통한 자동화된 앱 테스트 및 Amazon API Gateway를 통한 모바일 백엔드 구축 방법 등 서버 없이도 효율적인 모바일 서비스 아키텍처를 구성하는 방법을 알려드립니다
최근 입문용 혹은 개발 및 데이터 분석 용도로 파이썬을 사용하는 개발자들이 많이 늘고 있습니다. 본 세션에서는 파이썬을 활용하여 AWS에서 해 볼 수 있는 다양한 서비스와 기능을 소개하고자 합니다. 그 중에서도 Django 및 Flask 같은 웹 프레임워크를 AWS Elastic Beanstalk으로 손쉽게 배포하고 운영하는 방법, AWS Lambda를 통해 Python 기반 서버리스 애플리케이션을 제작하는 방법 그리고, Boto3와 AWS Python SDK를 통해 AWS의 다양한 서비스 API를 다루는 방법을 살펴 봅니다. Python으로 구성된 AWS 기반 인기 오픈 소스 프로젝트를 소개하여 직접 참여하는 방법을 안내합니다. 특히, 가상 서버 호스팅인 AWS re:Invent에서 새로 소개된 Amazon Lightsail 등도 함께 소개합니다.
연사: 모두싸인 CTO 정승현
행사 제목: 아마존-부산클라우드혁신센터 Startup Member Day
내용 요약: '모두싸인'이라는 전자계약 서비스를 만드는 로아팩토리가 MVP(최소기능제품)부터 12만 명의 회원 서비스가 되기까지의 경험으로 보는 스타트업의 성장 단계 별 AWS 아키텍처 진화와 비용절감 과정
클라우드 기반의 실시간 비딩 시스템 아키텍처를 구축하는 방법에 대해 설명하는 백서 [Building a Real-Time Bidding Platform on AWS]의 내용을 AWS 코리아의 김필중 솔루션즈 아키텍트가 한글로 요약한 슬라이드입니다. 어떻게 클라우드가 RTB의 필수 요소인 낮은 지연시간과 확장성을 확보하는 데 도움이 될 수 있는지 설명하고, 실제 고객 사례를 통해 이러한 아키텍처를 구성하는 법을 살펴보실 수 있습니다.
자바개발자가 최대한 빠르게 서비스를 오픈하는 방법 - 최진환 (드라마앤컴퍼니) :: AWS Community Day Online 2021AWSKRUG - AWS한국사용자모임
사이드프로젝트를 진행하면서 겪은 다양한 인프라 구축 노하우를 소개합니다.왜 EKS가 아닌 Elastic Beanstalk를 사용했는지, Codepipeline을 이용한 깃헙에서 배포까지의 플로우, AWS ChatBot을 사용한 모니터링과 CodeBuild로 빌드하기 등을 소개합니다.
더 많은 기업들이 디지털 전환을 앞당기며 뉴노멀 비즈니스를 위한 마이크로 서비스 전략을 세우고 더 빠른 앱 개발을 위해 노력을 기울이고 있습니다. 본 강연에서는 AWS re:Invent를 통해 발표된 Amazon EKS 및 AWS Proton의 신규 업데이트와 새롭게 출시된 Karpenter 프로젝트 등에 대해서 살펴봅니다. Graviton2 지원 및 Event Filtering, 그리고 AWS StepFunction Workflow Studio와 같은 서버리스 분야의 업데이트들과 함께 클라우드 운영 개선에 많은 도움을 줄 수 있는 관리 도구들에 대한 업데이트들도 소개합니다.
발표자료 다시보기: https://youtu.be/wt4Ue-1eYW8
서버리스는 운영상의 책임을 AWS로 전환하여 민첩성과 혁신을 높일 수 있도록 하는 클라우드의 네이티브 아키텍처입니다. 서버리스를 사용하면 서버를 고려하지 않고 애플리케이션과 서비스를 구축하고 실행할 수 있습니다 AWS의 Lambda, API Gateway 및 다양한 관리형 서비스를 활용한Serverless 컴퓨팅 아키텍처의 모범 사례를 배웁니다.
아마존 웹 서비스의 경우, 스타트업 부터 엔터프라이지까지 개발자 및 인프라 운영 엔지니어들이 주로 사용하는 것으로 알려져 있습니다. 하지만, 블로거로서 일반인들도 AWS 서비스를 유용하게 사용할 수 있습니다. 본 자료는 4주 완성으로 알파 사용자들이 아마존 웹 서비스를 활용하는 방법을 스터디 길잡이 입니다.
대상: 워드 프레스를 자체 서버로 블로그를 운영하려는 블로거, 포트폴리오 사이트를 운영하는 웹 디자이너, 클라우드를 통한 안정적인 소규모 워드프레스를 운영하려는 스타트업 등
얻을 수 있는 것:
1. 클라우드 컴퓨팅의 개념과 AWS 서비스에 대한 이해
2. AWS의 도메인 관리, 스토리지 및 동영상 인코등, 이메일 전송 서비스 활용 지식 습득
3. 복잡한 서버 운영 (콘솔 및 커맨드)과 DB 관리 없이도 안정적인 워드 프레스 운영 노하우 습득
주차별 스터디 내용:
<1주> 클라우드 컴퓨팅 및 AWS 소개
1. 클라우드 컴퓨팅 및 AWS 서비스 소개
2. AWS 가입 및 빌링 알람 설정(CloudWatch)
3. AWS Activate 프로그램 가입 및 사용 방법
<2주> 서버 없이 웹 사이트 호스팅하기
1. S3에 파일 서버 구축하기(S3 지원 FTP 클라이언트 사용법)
2. AWS 사용자 및 크리덴셜 만들기(IAM)
3. S3에 정적 웹 사이트 운영하기
4. CloudFront로 콘텐츠 배포하기
5. 도메인 네임 관리 및 설정하기(Route53)
<3주> CloudFormation으로 워드프레스 운영하기
1. AWS 아키텍쳐 이해하기 (EC2/ELB/RDS/AutoScaling)
2. 5분만에 확장 가능한 워드프레스 구성하기(CloudFormation)
3. 마켓플레이스에서 Bitnami를 활용한 웹 서비스 운영하기
4. WordPress 로컬 서버 및 GIT 레포지터리 설치하기
<4주> Elastic Beanstalk으로 워드프레스 운영하기
1. Elastic Beanstalk 설정 및 배포하기
2. Elastic Transcoder를 통한 자동 동영상 인코딩 하기
3. SES를 통해 대용량 이메일 보내기
4. S3에서 동적 블로그 웹 사이트 운영하기(Lambda with Metalsmith)
발표자료 다시보기: https://youtu.be/Uj4Ivi3h-U4
오늘날 엔터프라이즈 기업들은 시장 속도 및 고객 변화에 민감하게 응대하기 위해 더 빠르고 빈번하게 애플리케이션을 개발 및 배포할 수 있는 아키텍처와 개발 조직 및 문화를 요구받고 있습니다. 여러분 회사의 서비스 구조가 변화에 빠르게 대응하지 못하고 있거나 국내외 디지털 전환을 성공적으로 이끈 사례를 알고 싶은 기업 임원, 기술 전략 및 개발 PM 분들께 이 세션을 추천합니다. 본 세션에서는 이러한 현대적 애플리케이션의 요구 사항을 충족하기 위해 모놀리스 아키텍처에서 마이크로서비스로의 분화 방법, 클라우드 기반 컨테이너 및 서버리스 같은 배포 방식을 활용해 빠르게 배포하는 이벤트 중심 시스템을 구축하는 방법에 대해 설명합니다. 이러한 전환을 성공적으로 수행하기 위해 조직 문화 및 운영상의 변화와 대표적인 국내외 사례를 함께 살펴봅니다.
본 워크샵에서는 사용자가 Wild Rydes 서비스를 통해 현재 있는 위치에서 유니콘 호출 및 탑승을 할 수 있는 스타트업 아이디어를 구현한다는 시나리오로 함께 웹 애플리케이션을 만들어 배포해 봅니다. 이 서비스는 사용자에게 HTML 기반 사용자 인터페이스를 제공하여, 사용자가 원하는 위치를 표시하고 유니콘 요청을 하면, 가까운 유니콘을 보내기기 위해 RESTful 웹 서비스로 백엔드를 제공합니다. 또한, 사용자가 유니콘 타기를 요청하기 전에 기본적으로 회원 가입을 하고 로그인 할 수있는 기능을 제공합니다. 이를 위해 AWS Lambda, Amazon API Gateway, Amazon S3, Amazon DynamoDB, Amazon Cognito를 활용합니다.
Similar to 개인 지출 관리 - AWS로 시작하기 - 김영헌 (구로디지털 모임) :: AWS Community Day 2017 (20)
자연어 처리 ML모델을 활용한 이커머스 문제 해결하기 - 진현두 (카카오스타일) :: AWS Community Day Online 2021AWSKRUG - AWS한국사용자모임
이커머스에서 가장 중요한 사용자 리뷰! 사용자 리뷰 내 특정 키워드 관련 표현을 스마트하게 찾고, 하이라이팅 정보를 제공하는 ML모델 개발하여 서비스에 반영하였습니다. 복잡한 전처리와 모델링전반의 프로세스를 Amazon SageMaker + Custom Docker 로 구현 방법을 소개합니다.
EKS에서 Opentelemetry로 코드실행 모니터링하기 - 신재현 (인덴트코퍼레이션) :: AWS Community Day Online...AWSKRUG - AWS한국사용자모임
EKS환경에서 Opentelemetry와 Jaeger를 활용하여 서버의 코드가 잘 동작하는지 어떤로직에서 문제가 발생했는지 모니터링 하는 방법을 알아봅니다. 마지막으로 Grafana를 이용해 쉽게 원하는 코드를 조회 하는 방법도 실습해볼 예정입니다. K8S를 모르셔도 참석할 수 있습니다.
3. 지금은…?
• 하고 싶은 일 하기
• 여행 - 중국&제주
• 내가 사용할 프로그램 및 대용량 서비스 개발
• 얼마나 버틸 수(놀 수) 있을까?
• 현재 가지고 있는 돈으로 얼마나 버틸 수(놀 수) 있을까 고민 함
• 2017년 새해 목표로 (수기로) 지출 기록 시작
9. 본론 시작
• 만들어 갔던 과정을 시간 순서로 풀어 갑니다
• 과정에서 알게된 점(삽질)과 팁을 설명합니다
• 단계별 설정과 수행 방법은 제외하였습니다
• 템플릿, 소스코드 & 단계별 설명을 별도로 추후 공
개하겠습니다
10. Lambda
Google Spreadsheet
Gmail
결제 내역 이메
일
결제 내역 추
가
filter: forward to somewhere?
처음 그린 그림
1. Gmail에서 받은 이메일을 Lambda로 전달
2. ‘Google API 서비스 계정’ 생성
3. Lambda에 ‘이메일 파싱 함수’ 등록
4. 끝
12. ● Python 및 Python 라이브러리 준비
○ Python 2.7
○ gspread - Google spreadsheet 3rd party library
○ oauth2client - OAuth2 인증 라이브러리
● 절차
○ 1. Google API 서비스 계정 생성
○ 2. Spreadsheet 생성
○ 3. Spreadsheet를 '서비스 계정'에 ' 공유
○ 4. Python 라이브러리로 동작 테스트
Google API 및 python 연동
14. 삽질 노트 - Google API
1. Spreadsheet를 찾을 수 없다는 에러 발생
- 공유한 사용자가 생성한 서비스 계정이 맞는지 확인
- Spreadsheet의 id 값이 정확히 저장되었는지 확인
2. append_row()가 성공했함. 그러나, 입력된 값이 없음
- 빈 셀이 아닌, 시트 최하단에 추가 됨
- 새로운 시트를 생성시, 사용하지 않는 행을 삭제 할 것
16. SES = Simple Email Service
SNS = Simple Notification Service
1. SES에서 이메일 수신 이벤트로 Lambda 실행
- 본문은 이벤트로 전달 되지 않음
- 본문은 S3에 저장하고 이벤트에 객체키값 전달
2. SES -> SNS -> Lambda 실행
- 본문은 이벤트로 전달
- 본문의 크기가 150KB 제한
어떻게 이메일로 Lambda 함수를 실행하지?
23. Lambda 함수 구현 및 SES 연결
구현 기능
1. 이벤트가 입력되면, S3에서 이메일 본문을 읽음
2. 이메일 본문을 파싱하여 ‘지출 상세 내역’을 추출
3. 결과를 gspread를 이용하여 Spreadsheet에 새로운
행으로 추가
환경 변수
1. Spreadsheet ID
2. Worksheet 이름
3. Google API 서비스 계정 비공개 키
4. S3 Bucket
24. Lambda 함수 등록
1. python 함수를 zip 파일로 압축하고 upload
2. 환경변수 설정
1) Spreadsheet ID 2) Sheet 이름 3)s3 버킷 4) Google API 비밀키
1. Lambda 함수에 대한 Role 생성
2. DLQ(Dead Letter Queue) 설정
a. SNS 토픽 설정 - 메일 수신
3. 환경 변수 암호화를 위한 KMS키
32. 삽질 노트 - Lambda
1. ‘Bluteprint’에서 ‘Hellow World’로 시작
2. 연동 서비스의 테스트는 로컬에서의 수행이 번거로움
1. 서비스 상태에서의 동작 실패는 어떻게 확인하지?
1. Cold Start한 경우 처음 실행 시, 몇 초의 추가 시간 소요
33. 삽질 노트 - Lambda
1. ‘Bluteprint’에서 ‘Hellow World’로 시작
2. 연동 서비스의 테스트는 로컬에서의 수행이 번거로움
a. 로직 테스트는 로컬에서 수행
b. 통합 테스트는 콘솔의 "Test" 항목을 이용하여 수행한다.
3. 서비스 상태에서의 동작 실패는 어떻게 확인하지?
a. Cloudwatch의 이벤트로 알람 설정
b. SNS(DLQ)를 등록함 에러 발생시 Email로 포워딩하게 함
4. Cold Start한 경우 처음 실행 시, 몇 초의 추가 시간 소요
a. warming up을 위한 로직 추가 & Cloudwatch 이벤트로 주기적
(<15min) 호출
b. 참고: https://serverless.com/blog/keep-your-lambdas-warm/
36. 현금? 스타벅스? 교통비?
• 카드 지출은 자동으로 됐다
• 현금/스벅카드/교통비 등의 수동 기록 방법이 필요하다.
• Web으로 입력 폼을 만들자!
37. 수기로 지출 기록을
1. HTML 입력 폼 작성하자
2. Lambda 함수 로직은 이전보다 더 간단
a. Form 값 -> Spreadsheet에 저장
3. Lambda를 RESTful API로 공개하자
a. Amazon Gateway API 이용
4. API는 나만 사용할 수 있도록 인증 기능도 추가하자
a. Amazon Cognito 또는 AWS IAM
39. HTML 입력 폼 작성하자
1. S3에서 정적 웹사이트 호스팅 수행
2. ‘제출’ 누르면, ajax로 입력값을 API로
전달
3. Javascript
a. jQuery
b. Bootstrap
c. Amazon SDK
d. Amazon Cognito SDK
e. Amazon Cognito Identity
40. Lambda를 RESTful API로 공개하자
API 작성 절차
1. ‘리소스’ 생성
ex) https://hostname/receipt/
1. ‘메소드’ 생성
ex) GET/POST …
a. 각 메소드에 인증 적용
2. API 배포 (Deploy)
41. Lambda를 RESTful API로 공개하자
처음 생성한 API에 Lambda 함수 및 인증을 한번에 설정하면 에러
발생 위치 및 이유를 확인하기 어려움
1. Mock API 작성 -> ‘배포’ -> ‘테스트’
2. 항상 성공하는 Lambda 함수 연결 -> ‘배포’ -> ‘테스트’
3. 로직이 포함된 Lambda 함수 연결 -> ‘배포’ -> ‘테스트’
a. Lambda에서 실패한 경우, ‘500 internal error’ 반환 됨
b. Cloudwatch에서 로그 확인
4. 그리고, 인증 붙여봄 ... 여기 부터 삽질의 연속
42. API는 나만 사용할 수 있도록 인증 기능도 추
가하자
2가지 인증 방법
• AWS IAM
• IAM User의 Credential(Access key, Secret Key)로 API 호출
• 서버간 통신에 이용
• Web에서 이용하기에 적합하지 않음
• Cognito User Pool
• Cognito에서 사용자 아이디/비밀번호 관리
• 로그인 하면, ID Token 반환
• ID Token으로 API 호출
43. Cognito User Pool 이용 방법
1. User Pool 생성
a. User Pool ID
2. App Client 추가
a. Client ID
3. 관리자 만 User를 추가 하도록 설정
4. User 생성
a. 관리자가 생성한 User는 처음 로그인 할 때, 암호 변경을 해
야 됨
5. ID/Password로 User 로그인
a. ID Token 반환
6. (ID Token으로 API 호출)
45. • AWS IAM? Cognito User Pool 중에 어떤 것을 써야 할까?
• 관리자가 생성한 User는 처음 로그인 할 때, 비밀번호 변경을 위한 callback function 필
요
• http://docs.aws.amazon.com/cognito/latest/developerguide/using-amazon-cognito-identity-user-pools-javascript-
example-authenticating-admin-created-user.html
• 참고 자료
• https://github.com/aws/amazon-cognito-identity-js
• http://docs.aws.amazon.com/cognito/latest/developerguide/setting-up-the-javascript-sdk.html
삽질 노트 - Cognito
48. 마무리
• AWS/AWS Console은 감동
• 편리함, 서비스간 연결시 필요한 권한 자동으로 추가
• 개발/업로드/테스트 편리 (당연히…)
• 개인용으로 거의 비용 X
• 도메인, Route 53, S3
• Lambda & Gateway API 이용, 연동 서비스를 빠르게 만들 수 있음
• Lambda, Cognito, API Gateway, Route 53, SES, KMS, Logs, S3,
IAM(Role)를 함께 익힘
• ‘토이 프로젝트’ = 재미, 재미 = 학습의 원동력
49. 다음에 할 일
• 템플릿, 소스코드 & 단계별 설명을 곧 업데이트 할께요
• 관심 있는 분, 같이 해요!
• me@younghun.kim
• 지출 내역들의 분류에 Machine Learning 이용해보아요
50. ‘발표 요약’ 내용 기억나시나요?
AWS Lambda, API Gateway 등 AWS 서비스와 Google
Spreadsheet를 이용하여 지출 관리 서비스를 만들어 봅니다. 지
출 관리를 잘 할고 소비를 줄일 수 있었을까요? 오셔서
직접 확인해 보세요. 한가지, AWS는 알차게 학습할 수 있었습니다
51. 공개 (예정) 자료 모음
1. 지출 내역 Spreadsheet
a. https://bit.ly/myexpense2017
2. Google API ‘서비스 계정’ 생성 방법
a. 준비 중...
3. Python 코드
a. 준비 중...
4. Lambda / API Gateway / Cognito 설정 방법
a. 준비 중...
52. 감사합니다
2017/06/25
코드, 설정 방법 및 자세한 내용은 현재 준비 중에 있습니다. 준비되는
대로 업데이트 할 예정입니다.
1) 바로 서비스를 돌려보고 싶은 분
2) 기타 궁금한 내용이 있는 분은
편하게 여기(me@younghun.kim)로 이메일 주세요! :) 도와드릴께요.
같이 만들어봅시다!
53.
54. AWS IAM 이용 방법
1. IAM User 생성
2. Permission 추가
• AmazonAPIGatewayInvokeFullAccess
• AmazonAPIGatewayPushToCloudWatchLogs
3. API Gateway
• ‘Method Request(메서드 요청)’ - ‘Authorization(승인)’
• ‘AWS_IAM’ 선택
4. Postman에서 API 테스트
• Postman을 사용하여 API 호출 -
http://docs.aws.amazon.com/ko_kr/apigateway/latest/developerguide/how-to-
use-postman-to-call-api.html