Upgrade to Pro — share decks privately, control downloads, hide ads and more …

Amazon OpsWorks. Deployment with ease

Sponsored · Ship Features Fearlessly Turn features on and off without deploys. Used by thousands of Ruby developers.

Amazon OpsWorks. Deployment with ease

Introductory presentation about Amazon OpsWorks form Softserve Pacemaker: LAMP 2013.
Please note that PDF version doesn't have issue with fonts.

Avatar for Petro Sasnyk

Petro Sasnyk

July 06, 2013
Tweet

More Decks by Petro Sasnyk

Other Decks in Programming

Transcript

  1. AMAZON OPSWORKS. DEPLOYMENT WITH EASE. BY PETRO SASNYK, TECH LEAD

    SOFTSERVE INC. @STOUNE, STOUNE Pacemaker: LAMP
  2. AGENDA • WHY DO I NEED AUTOMATED DEPLOYMENT • WHY

    SHOULD I USE AMAZON OPSWORKS • HOW TO USE AMAZON OPSWORKS REAL-WORLD SCENARIO
  3. WHY DO I NEED TO AVOID MANUAL DEPLOYMENT? 1. BECAUSE

    IT IS BORING 2. BECAUSE IT IS CUMBERSOME 3. BECAUSE IT ERROR-PRONE 4. BECAUSE IT TAKES A LOT OF TIME 5. BECAUSE IT IS NOT REPETITIVE 6. BECAUSE IT IS NOT SCALABLE 7. BECAUSE … Or Continue doing monkey job
  4. THE TWELVE-FACTOR APP BY HEROKU • I. CODEBASE - ONE

    CODEBASE TRACKED IN REVISION CONTROL, MANY DEPLOYS • II. DEPENDENCIES - EXPLICITLY DECLARE AND ISOLATE DEPENDENCIES • III. CONFIG - STORE CONFIG IN THE ENVIRONMENT • IV. BACKING SERVICES - TREAT BACKING SERVICES AS ATTACHED RESOURCES • V. BUILD, RELEASE, RUN - STRICTLY SEPARATE BUILD AND RUN STAGES • VII. PORT BINDING - EXPORT SERVICES VIA PORT BINDING • IX. DISPOSABILITY - MAXIMIZE ROBUSTNESS WITH FAST STARTUP AND GRACEFUL SHUTDOWN • X. DEV/PROD PARITY - KEEP DEVELOPMENT, STAGING, AND PRODUCTION AS SIMILAR AS POSSIBLE • XII. ADMIN PROCESSES - RUN ADMIN/MANAGEMENT TASKS AS ONE-OFF PROCESSES
  5. AMAZON OPSWORKS SOLUTION Stack Layers Stack is basically a container

    for a set of Amazon EC2 instances (with related resources) that have a common purpose or should be logically managed as a group A Layer defines how to set up and configure a set of instances and related resources Instances Instances are running your code according to layer specification. You define how you are going to scale Then you make a deployment to specific instances and customize the deployment with Chef recipes
  6. STEP 1. CREATE A STACK 1. NAME 2. OS (AMAZON

    LINUX OR UBUNTU LTS) 3. REGION 4. DO NOT FORGET TO USE YOUR FAVORITE PINK COLOR TO MARK THE STACK 
  7. STEP 2. ADD LAYER 1. TYPE 2. SELECT COMPONENTS VERSIONS

    (FOR RAILS: RUBY, GEMSET, BUNDLER, PHUSION PASSENGER OR UNICORN) 3. ADDITIONAL SETTINGS
  8. STEP 3. ADD INSTANCE 1. NAME 2. SIZE 3. AVAILABILITY

    ZONE 4. SCALING TYPE (24/7, TIME- BASED, LOAD-BASED) 5. OS
  9. STEP 5. DEPLOY AN APP 1. COMMAND 2. ADVANCED: TARGET

    INSTANCES 3. ADVANCED: CHEF JSON
  10. FLUFFY CATS APPLICATION THIS IS THE NEXT BILLION-DOLLAR BUSINESS. THE

    COOLEST SITE EVER ABOUT FLUFFY CATS. ISN’T IT CUTE?
  11. FLUFFY CATS APPLICATION: ARCHITECTURE Amazon RDS/MySQL Database Rails App Server

    Amazon S3/File storage Elastic Load Balancer Me – The user
  12. ALTERNATIVES Heroku/Fully managed PaaS Elastic BeansTalk OpsWorks CloudFormation Cheff/Puppet +

    IaaS Lower complexity/ Lower flexibility Higher complexity/ Higher flexibility
  13. PITFALLS 1. VENDOR LOCK-IN (WHO CARES) 2. IT’S STILL BETA

    (BUGS, SMALL EXPERTISE, ETC.) 3. TO MAKE COMPLICATED THINGS, YOU NEED TO LEARN RUBY AND CHEF 4. AMAZON OPSWORKS USES CHEF SOLO 0.7, LATEST VERSION IS 0.11.0 5. A LOT OF COOKBOOKS AND RECIPES ARE INCOMPATIBLE WITH AMAZON OPSWORKS
  14. CONCLUSIONS • USE GOOD INSTRUMENTS FOR GREAT GOOD • USE

    AUTOMATED DEPLOYMENTS (OR YOUR ARCHITECT WILL PUNISH YOU) • AMAZON OPSWORKS COULD SIMPLIFY YOUR DEPLOYMENT TASKS OR MAY NOT
  15. STILL HAVE QUESTIONS? Do not ask questions, just go and

    register your free Amazon account and taste the red pill
  16. USEFUL LINKS 1. FLUFFY CATS APPLICATION SOURCE CODE: HTTPS://GITHUB.COM/STOUNE/FLUFFY_CATS.GIT 2.

    FLUFFY CATS CUSTOM CHEF COOKBOOKS: HTTPS://GITHUB.COM/STOUNE/FLUFFY_CATS_COOKBOOKS.GIT 3. THE TWELVE FACTOR APP 4. AMAZON OPSWORKS USER GUIDE 5. OPSCODE DOCS