세션 유형
Break out
세션명
AWS Amplify: Scale your web and mobile app development and delivery (FWM205) (웹 및 모바일 앱 개발 및 제공 확장)
강연자
- Abdallah Shaban
- Mohit Srivastava
핵심내용 요약
- AWS Amplify는 Frontend web, mobile 개발자에게 확장 가능하고 유지 관리가 유용한 Application 구축 도구를 제공
- Amplify의 기능과 기존 배포 도구 및 데이터베이스와 통합하는 방법 소개
- 시나리오를 통해 안전하고 확장 가능한 Application 구축, 배포 및 호스팅 할 수 있게 해주는 새로운 엔터프라이즈 기능 소개
키워드
- AWS Amplify을 활용한 웹 및 모바일 앱 개발
- 앱 개발의 가속화 및 배포
세션 요약자
베스핀글로벌 MSP 본부 DevOps실 강현욱 님
App development는 full-stack development
data:image/s3,"s3://crabby-images/c1aef/c1aef507226ed3ccfcddeb0151f804540a851c2a" alt=""
Frontend 팀은 Backend에서 다양한 작업을 모두 처리할 필요 없이 하나의 인터페이스 세트로만 작업을 수행하면 된다.
AWS Amplify 란?
data:image/s3,"s3://crabby-images/2d46f/2d46fecb6cac89769b50e1d3d1c96def5c7088ea" alt=""
앱 개발에 필요한 UI, Backend구축, Application 호스팅, 규모확장
즉, AWS Amplify는 Frontend와 Backend 개발을 더 쉽게 통합할 수 있도록 해준다.
앱 백엔드 구축을 위한 AWS Amplify
data:image/s3,"s3://crabby-images/fd979/fd9792adf614c0b53896f87d7f5160b209e259bc" alt=""
- Accelerate Development : 인프라가 아닌 애플리케이션 코드에 집중
- Integrate : 기존 ID 및 데이터 리소스 사용
- Extend without limits : CDK를 사용하여 AWS 서비스 추가
- Ship with confidence : 모든 Git 푸시 수행 > 전역적으로 프런트엔드 및 백엔드 배포 (다중 교차지역도 포함)
앱 개발 잠금 해제
data:image/s3,"s3://crabby-images/ba86a/ba86abcda4696564516b469e0427bb85539a5f57" alt=""
- Code first :
- CDK L3 구성 또는 파일 기반 규칙을 사용하여 백엔드를 정의
- TypeScript 또는 자연어(Amazon CodeWhisperer) 사용
- Integration :
- 기존 ID 공급자 및 MySQL/PostgreSQL 사용
- 비즈니스 로직, 실시간 액세스, 액세스 제어 추가
- Extensibility :
- Amplify CDK를 다른 CDK L2 및 L1과 결합
- Amplify는 App Backend 개발기능을 제공하고, Amplify 웹 호스팅 솔루션도 제공
Amplify 기능을 활용한 App 구축
data:image/s3,"s3://crabby-images/b668e/b668ee6006d9162abf13bafbb0d5059c464ea079" alt=""
- L3 기반 CDK 구성
- Amazon Cognito :
- 사용자 풀에 사용자의 정보를 저장
- Octa(SSO)를 사용하는 경우 통합 가능
- JWT 토큰은 Amazone Cognito가 관리
- AWS AppSync :
- 관리형 Serverless 그래픽 서비스
CDK L3 구성을 활용한 구축
data:image/s3,"s3://crabby-images/94ca6/94ca6a4779af20b2d2e3e9bb21a6279212afcf38" alt=""
- End user를 위한 등록/인증 기능구현
- Employees를 위한 OIDC/SAML과 Admin 관리 기능구현
OIDC 구현을 위한 설정
data:image/s3,"s3://crabby-images/ac29d/ac29d81b965ff5d0c86e79f76cf95c49ca647033" alt=""
data:image/s3,"s3://crabby-images/08f20/08f20aacb9fe12c0444f0bd9e181e3fce8b4fe0b" alt=""
data:image/s3,"s3://crabby-images/d74de/d74de6a1a83b9521455128899fd913c9397aece5" alt=""
- 위의 Typescript 예제와 같이 10줄의 코드작성으로 OIDC provider 설정이 가능
- CDK를 실행하고 배포하면 Cognito에 의해 필요한 리소스가 배포된다
각기 다른 Data source를 활용하여 Application을 구축하는 방법
data:image/s3,"s3://crabby-images/a6d73/a6d73fdcfda050da4558420f3579c601f16a020c" alt=""
data:image/s3,"s3://crabby-images/65113/65113fd2a634b05d0114dd4097f9af77596d3a45" alt=""
- 첫번째 단계
- GraphQL을 활용하여 Schema API를 작성
data:image/s3,"s3://crabby-images/e3c84/e3c844d8136f69bdef2f72a19ab550b7e180c2ef" alt=""
- 2a 단계
- 환자 및 청구 스키마를 생성 (GraphQL을 활용)
data:image/s3,"s3://crabby-images/0e5d3/0e5d3a6981158fc2a2442f2e6cb8769fe91c6281" alt=""
data:image/s3,"s3://crabby-images/6307b/6307bb66d1276df3059f30ca3d8b1c968fe7c3ab" alt=""
- 2b 단계
- 2a 단계의 명령을 통해 자동으로 생성
- billing 유형은 DB의 청구 테이블을 참조
- 청구 데이터의 소유자가 읽을 수 있도록 허용 필요
- 환자에게도 이름, 성, 주소 필드가 존재
- DB 연결 매개변수를 지정할 수 있음
data:image/s3,"s3://crabby-images/5088e/5088e2272edd0e6358da6ce2e68c1881a8b1c2d0" alt=""
- 3 단계
- Source API A : Appointment 및 의료 직원 데이터 관리
- Source API B : 환자 및 청구 데이터 관리
- A, B 모두 AppSync GraphQL을 제공
- 이렇게 A, B 독립적으로 동작하는 API를 하나의 API로 병합/결합 하여 활용이 가능
- 즉, 다양한 Backend와 Sources 테이터들을 단일 Endpoint로 갖고오기 위해 Appsync를 활용
Appsync를 활용하여 Amazon Bedrock과 연동 방법
data:image/s3,"s3://crabby-images/0ab8f/0ab8f991622cd92c8769ef9e6b2fa3c13bdbe0db" alt=""
data:image/s3,"s3://crabby-images/3b97a/3b97aa5fdc2725289e7a31ffe323da0372c9b1fd" alt=""
- 위와 같이 단 10줄의 코드로 Amazon Bedrock과 Appsync가 가능
- Amazon Bedrock을 http 소스로 추가
- 기본 모델을 호출 할 수 있는 권한을 제공
Demo 시연
data:image/s3,"s3://crabby-images/2b1ca/2b1cadbc1129372f26618e44f68b2504b9e00a6d" alt=""
- CDK AWS Amplify를 활용한 Application을 시연
- 시나리오
- Appointment를 요청
- Appointment 기록을 확인
- 다른 사용자가 만든 Appointment를 관리
data:image/s3,"s3://crabby-images/ff20d/ff20d4bd5d4ab11828c220636efae5de4d73542c" alt=""
- 환자 계정으로 로그인
data:image/s3,"s3://crabby-images/3d849/3d8498a7d531373095b4761d03d05c96c1d544f4" alt=""
- 로그인 완료
- 두개의 Appointment를 확인
- 각각의 Appointment에 대한 청구 금액을 확인
- 핵심 사항 : 각기 별도의 4개의 Data source에서 데이터 통합을 통해 병합된 API로 호출하여 획득한 정보
- 공급자 Data source
- 사용자 Data source
- 청구 Data source
- Appointment Data source
data:image/s3,"s3://crabby-images/cec58/cec582ce9fce4495b12b59cf1abce340c1775788" alt=""
data:image/s3,"s3://crabby-images/6b10a/6b10a934c2dfe89e6f65eeae0871cc62d5ba262a" alt=""
- 신규 Appointment 등록 > 목록에서 확인
data:image/s3,"s3://crabby-images/f176c/f176c396015352f8aff0084056cd1b605895efda" alt=""
data:image/s3,"s3://crabby-images/3c8f9/3c8f965ac07c9af23234aaf3810996e6024f73b5" alt=""
- 공급자 (Provider)으로 로그인
- 공급자 로그인은 AWS Amplify를 사용하면 브라우저에 OCTA 세션(OIDC Provider를 활용)이 있다는 것을 인지하고 자동으로 로그인이 가능함.
- 공급자로 로그인하면 전체 Appointment 목록을 확인할 수 있음
CI/CD 구성, 시연
data:image/s3,"s3://crabby-images/03f90/03f9055e76644dd485f6fbb81f4279ec71dd0ab2" alt=""
data:image/s3,"s3://crabby-images/69338/6933820c49ad56c805dabb29d51b26d1ac41805d" alt=""
- 필드를 추가하면 Appsync를 통해 DynamoDB에 자동으로 필드가 추가 되는것을 확인할 수 있다.
Bespin’s Comment
data:image/s3,"s3://crabby-images/b48d3/b48d3333c8810d6501c9294ff421a7471e9c3f5b" alt=""
- 다양한 Backend와 Sources 테이터들을 단일 Endpoint로 갖고 오기 위해 Appsync를 활용
- CDK를 통해 모든 AWS 서비스를 쉽게 확장하고 사용할 수 있음
- CI/CD구성을 위한 개발자 샌드박스를 활