Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
DevOps On AWS - Farouq Mousa
Search
AWS MENA Community
September 25, 2020
Technology
140
1
Share
DevOps On AWS - Farouq Mousa
DevOps On AWS - By Farouq Mousa.pdf
AWS MENA Community
September 25, 2020
More Decks by AWS MENA Community
See All by AWS MENA Community
AWS UG DXB 2021 container series- IV
awsmena
1
110
Building Modern Applications on AWS with Persistent Storage
awsmena
0
76
Getting started with AWS Device Farm and Selenium WebDriver
awsmena
3
1.2k
Terraform CICD Best Practices
awsmena
2
110
How to select the righ EBS?
awsmena
1
100
AWS MENA Community Day - GitOps on AWS_ Codifying multi-cloud operations
awsmena
0
160
Serverless SaaS By Ali El Kontar
awsmena
1
100
Continuous verification for serverless applications By Gunnar Grosch
awsmena
1
55
AI/ML on AWS By Ahmed Raafat
awsmena
1
130
Other Decks in Technology
See All in Technology
20260515 OpenIDファウンデーション・ジャパンご紹介
oidfj
0
130
ECSのTerraformモジュールにコントリビュートした話
harukasakihara
0
230
いつの間にかデータエンジニア以外の業務も増えていたけど、意外と経験が役に立ってる
zozotech
PRO
0
650
Redmine次期バージョン7.0の注目新機能解説 — UI/UX強化と連携強化を中心に
vividtone
1
160
Fラン学生が考える、AI時代のデザインに執着した突破口
husengs7
1
200
Terragrunt x Snowflake + dbt で作るマルチテナントなデータ基盤構築プラットフォーム
gak_t12
0
270
Claude Code で使える DuckDB Skills を試してみた / DuckDB Skills and Claude Code
masahirokawahara
1
650
SLI/SLO、「完全に理解した」から「チョットデキル」へ
maruloop
5
560
AWSアップデートから考える継続的な運用改善
toru_kubota
2
300
分断された OT と IT を繋ぐ架け橋 -Kubernetes が切り拓く 産業用組み込み製品の現在地 -
yudaiono
1
120
How to learn AWS Well-Architected with AWS BuilderCards: Security Edition
coosuke
PRO
0
150
CARTA HOLDINGS エンジニア向け 採用ピッチ資料 / CARTA-GUIDE-for-Engineers
carta_engineering
0
47k
Featured
See All Featured
SEO Brein meetup: CTRL+C is not how to scale international SEO
lindahogenes
1
2.6k
Agile that works and the tools we love
rasmusluckow
331
21k
Thoughts on Productivity
jonyablonski
76
5.2k
Facilitating Awesome Meetings
lara
57
6.8k
Stewardship and Sustainability of Urban and Community Forests
pwiseman
0
200
Design and Strategy: How to Deal with People Who Don’t "Get" Design
morganepeng
133
19k
Building Better People: How to give real-time feedback that sticks.
wjessup
370
20k
Leveraging LLMs for student feedback in introductory data science courses - posit::conf(2025)
minecr
1
250
The Illustrated Children's Guide to Kubernetes
chrisshort
51
52k
We Have a Design System, Now What?
morganepeng
55
8.1k
Public Speaking Without Barfing On Your Shoes - THAT 2023
reverentgeek
1
390
Max Prin - Stacking Signals: How International SEO Comes Together (And Falls Apart)
techseoconnect
PRO
0
160
Transcript
COMMUNITY DAY MENA DevOps on AWS, Getting Started
Farouq Mousa AWS Solutions Architect | DevOps Engineer | Genesys
Consultant | AWS UG Leader at Palestine @farouqmousa @farouqmousa
Agenda ▪ AWS CodeDeploy ▪ AWS CodeBuild ▪ AWS CodePipeline
CodeDeploy AWS Native Continuous Delivery Tools CodeBuild CodePipeline
DevOps and Continuous Delivery • Automated deployments • Repeatable and
safer • Smaller change sizes • Deploy morefrequently • Faster feedback loops • Learn and reactquicker • Deliver more value
CodeDeploy DEPLOYING APPS W I T H
Benefits of CodeDeploy • Automate yourdeployments • Fully managed serverlessservice
• Free withinAWS • $0.02 per on-premises instanceupdate • Centralize control • Versatile
Application The core component CodeDeploy Components Deployment Group A target
for your deployment Deployment Roll out anapp revision
Compute platform EC2/On-premises, AWS Lambda, Amazon ECS A uniquename An
identifier that isunique inside its AWS account A CodeDeploy Application
ECS An ECS cluster + An ECS service + A
load balancer + Target Group 1 + Target Group 2 Lambda Lambda function name EC2/On-premises Autoscaling groups EC2 instance tags On-premises hosts Deployment Groups
Deployment group Targets for the deployment A CodeDeploy Deployment Deployment
configuration Such as “One At A Time” Revision An application version Deployment type “In Place” or “Blue-Green”
ECS AppSpec file Task Definition version Container name Container port
Lambda AppSpec file Function name Function alias Version info EC2/On-premises GitHub commit ID or Zip file in S3 Revisions
version: 0.0 os: linux files: - source: /src destination: /var/www/html
hooks: BeforeInstall: - location: scripts/before_install.sh timeout: 300 runas: root AppSpec File: appspec.yml
EC2 or on-premisesinstance Installing the CodeDeploy Agent codedeploy-agent EC2 User
Data
#!/bin/bash -xe yum install -y ruby cd /opt curl -O
https://aws-codedeploy-us-east- 1.s3.amazonaws.com/latest/install chmod +x ./install ./install auto Install CodeDeploy - Red Hat
CodeDeploy ELB EC2 Connecting All CodeDeploy Pieces IAM GitHub or
S3 Revisions agent IAM
CodeBuild CONTINUOUS INTEGRATION W I T H
• Software licensing • CI software upgrades • Underlying host
management • Agent configurations • Hand crafted build projects • Queued builds Traditional CI
Continuous Integration • DevOps and agile processes • Helps prevent
merge conflicts • Triggers off code commits • Static code analysis • Compiles code • Runs tests • Packages and publishes artifacts • Catch and fix problems quicker
Continuous Integration Systems Managed services Master/agent Open Source andfree
Teamcity Bamboo Jenkins GitLab Travis CircleCI Alternatives to CodeBuild
Benefits of CodeBuild • Fully managed build service • Elastic
scaling • Pay only for build time used • CLI and API driven • Define builds as code • Tightly knit AWS integrations • Extensible
Sends notifications Runs tests Static code analysis Compiles code Runs
builds How Is CodeBuild Used in a CI/CD pipeline? 1 2 3 4 6 Publishes Artifacts 5
Build project The definition ofyour project Build or Build run
An execution of your Build project CodeBuild Components
Metrics Build triggers Build details Build history Build Project
Environment Artifacts Project configuration Source Build Spec Logs CodeBuild Project
Build Details
Build details Environment variables Phase details Build logs Build status
Builds or Build Runs
CodeBuild Connecting All the Pieces Git repo orS3 Source Artifact
store Projects Builds
version: 0.2 env: variables: key: “value” parameter-store: key: “value” phases:
build: commands: - compile commands - test commands artifacts: files: - target/messageUtil-1.0.jar Build Spec File:buildspec.yml
Ruby Golang Python Java .NET PHP Testing Tools
CodePipeline AUTOMATING SOFTWARE RELEASES WITH
Continuous Delivery Pipelines • A Continuous Delivery tool • Define
your entire release process • Ties together disparate systems • Flows Code out to production
Prerequisites for CodePipeline AW S account IAM credentials
Prerequisites for CodePipeline Source code Build process D eployment or
Benefits of CodePipeline • Fully managed pipeline service • Pay
only for active pipelines • Tightly tightly AWS integrations • Third party developer tool actions • Extensible via Lambda and custom actions
Artifacts Bundles of code produced by astage and ingested by
another stage Transitions The connections between stages Stages A collection of action groups that contain actions Pipeline Components
A CodePipeline Stage Action Group Actions Pipeline Stage Action Group
Actions runOrder: 1 runOrder: 1 runOrder: 2 runOrder: 2
Visualizing CodePipeline Transition Source Stage Action Group G itHub action
Build Stage Action Group C o deB uild action Deploy Stage Action Group C o deD eploy action Transition Pipeline
Test Action Approval Action Source Action Build Action Deploy Action
Invoke Action Action Types
CloudWatch Events A configured rule can route CodePipeline event info
to one or more targets CodeDeploy Triggers Publish to an S N S topic when deployment events occur for a deployment group Pipeline Execution Monitoring
Thank You ☺ @farouqmousa @farouqmousa