What You'll Miss On AWS
& How To Find It Again
data:image/s3,"s3://crabby-images/2a2f4/2a2f44f5dccec0a62caf8430d8052919dd3ab3be" alt=""
@M1ke
Mike Lehan
data:image/s3,"s3://crabby-images/28d54/28d54e60fd5b147e5afc7331603811fde84cc213" alt=""
data:image/s3,"s3://crabby-images/1f2b2/1f2b2126af873b73f6baf82d6c71e5d4fcc5cbe4" alt=""
data:image/s3,"s3://crabby-images/3ca4c/3ca4c405cc62ad542375b0b1af52413a4be63584" alt=""
data:image/s3,"s3://crabby-images/b5995/b59950a67b25597d79617af83ba6407a72893f83" alt=""
data:image/s3,"s3://crabby-images/47018/470188107d446e9d5176f4dbe46f1cfd89c79811" alt=""
data:image/s3,"s3://crabby-images/897f0/897f09bdd41b79b9f8835bd9bad732b61b56f80e" alt=""
data:image/s3,"s3://crabby-images/3c2cd/3c2cd5f5117bd41132c6e8c09c4a8d66aca09bff" alt=""
data:image/s3,"s3://crabby-images/1675d/1675d1246a46f6596d495cb9aa713287926194b7" alt=""
S3: Simple Storage Service
EC2: Elastic Compute Cloud
RDS: Relational Database Service
EBS: Elastic Block Store
EFS: Elastic File System
ELB: Elastic Load Balancer
First, Acronyms!
Cheap file storage
Servers!
No more my.cnf!
Hard disks!
Networked HDD
You'll see!
What you'll miss | How we solve it | |
---|---|---|
1 | Your server actually being there | Launch servers in multiple availability zones |
2 | Domain mapping to an IP | Load balancing with a Route 53 alias |
3 | Users having consistent sessions | Enable sticky sessions |
4 | Making server config changes | Auto scaling groups & automated machine imaging |
5 | Using the file system | Elastic File System |
6 | SSH access to your server | Elastic IP and Lambda functions |
7 | Files uploading quickly | Multi-stage deployments |
8 | Sub 1s PHP execution times | Zend Opcache |
9 | Cron! | Scheduled Lambda functions |
tl;dr
data:image/s3,"s3://crabby-images/ba2b3/ba2b3c04f16e5e98eb67bf82c77baf6f50efef84" alt=""
Is this really the best way of doing things?
You'll miss: your server actually being available
data:image/s3,"s3://crabby-images/27a0b/27a0bf07bd6915152b65c8393be710feb36596a2" alt=""
data:image/s3,"s3://crabby-images/9a10a/9a10a4cf7747d35b1d881fb417a56d0482ffca6f" alt=""
eu-west-1 (Dublin) or eu-west-2 (London)
- Launch servers in multiple availability zones
- If using RDS, choose the "Multi AZ" option
- Use an "auto scaling group" to guarantee servers in a specified number of AZs
- No need to worry about S3, EFS or Lambda - synced across AZs automatically
You'll miss: domains mapping to IPs
data:image/s3,"s3://crabby-images/0602e/0602e1c932b6de6165585735abe2d8d15cff29cb" alt=""
data:image/s3,"s3://crabby-images/5d6c5/5d6c506acbbda34be68834d8404de7951e185f75" alt=""
- You don't need to worry about its AZ
- It can target a group of instances
- Even checks if an instance can receive HTTP connections
- Called a "balancer" but really just directs traffic randomly
- Because you obviously all use TLS, you'll need to give the Load Balancer your private key
You'll miss: users having consistent sessions
data:image/s3,"s3://crabby-images/da5dc/da5dc22290ff4d6c5ab5a0eb810161336a0d7d88" alt=""
data:image/s3,"s3://crabby-images/a4d7c/a4d7c8268ecc7d4e81c2baafca32e781871504ca" alt=""
Sticky sessions!
You'll miss: making server config changes on the fly
data:image/s3,"s3://crabby-images/fb2b8/fb2b83993f23baa30b8db776c7d58e07e60ea232" alt=""
data:image/s3,"s3://crabby-images/c5b72/c5b72108d3008a648f1669e65b30d033bf488e3f" alt=""
data:image/s3,"s3://crabby-images/2b457/2b457505f0952e89b70a053e1f50464e88dfed45" alt=""
Behold the "master" instance!
data:image/s3,"s3://crabby-images/a0c27/a0c27ae32e764eee6251727f40373159f422d94f" alt=""
Be lazy; use Lambda!
data:image/s3,"s3://crabby-images/99b55/99b5566782689347966a8566c01f5b067f091105" alt=""
- Check for AMIs in our account with a specific "tag"
- If there are more than 1, delete all but the newest - helps keep our S3 costs down and our account tidy
- Get the current launch configuration of our autoscaling group - we can assume this works
- Replace the variables in the data for the AMI ID and snapshot ID
- Create a new launch configuration
- Apply the launch configuration to the autoscaling group
Next, hacks and magic!
Autoscaling lets us make scheduled actions
data:image/s3,"s3://crabby-images/06461/064617b0912ebfe2f9ce24f975ab95567e34256f" alt=""
data:image/s3,"s3://crabby-images/f0100/f01009f2315eeb2b5209ed3190e8c0dd7e6c1c34" alt=""
It also lets us choose how it terminates instances
In summary
- Edit your master server
- Switch off your master server
- Make an image of it
- Create a launch configuration with that image
- Set your autoscaling group to use the new launch configuration
- Cycle out your old instances
- ?
- Profit
You'll miss: using the file system
How are there are no memes about file systems?
data:image/s3,"s3://crabby-images/0780d/0780df60814ab54aa3af07809e34278cd4b3a4e6" alt=""
This bit
Connect from any AZ
Works as a network mount
data:image/s3,"s3://crabby-images/b4cd2/b4cd2a7d808d8671ea20a0e392cedbc23511de7c" alt=""
EFS is also "limitless"
The "E" stands for exabyte:
1,000,000,000,000,000,000 bytes
data:image/s3,"s3://crabby-images/b4311/b43119e1615343a8e5ad89d7c897f4f76f071ddf" alt=""
You'll miss: SSH access to your server
data:image/s3,"s3://crabby-images/ea8e3/ea8e33936866aaaf04e8af6ec777a4e3c2c9cdc5" alt=""
data:image/s3,"s3://crabby-images/c76d0/c76d06bacba07988280af63284e05db5432c0f4b" alt=""
Elastic IP
data:image/s3,"s3://crabby-images/8aec5/8aec56ae6e689a5088cdc24076d63d34a1f4a86e" alt=""
data:image/s3,"s3://crabby-images/3c07e/3c07e82873a000691e9ace0caf12cd0b31f14b87" alt=""
data:image/s3,"s3://crabby-images/7b614/7b614b04808d32a52a742e3d0fc07adfd2973924" alt=""
.ssh/config
You'll miss: files uploading quickly
data:image/s3,"s3://crabby-images/f3020/f3020a342323892f8f833a13a1149bfb6f996fdf" alt=""
EFS slow down means your app files might end up inconsistent
If your app can't tolerate this you need to use atomic deployments
- Deploy your application to a writable directory on whichever server you have an elastic IP attached to
- Trigger a process on the server to copy your files to a named release folder (e.g. timestamp) on EFS
- Repoint a symlink to which your web server config points as the application root
Many deployment programs that use a remote agent (e.g. capistrano) already use this technique. We rolled our own in bash
You'll miss: PHP scripts executing in less than a second
data:image/s3,"s3://crabby-images/89404/894048ae0a62cc571c13e6ba0eb274cc0b8cbca1" alt=""
data:image/s3,"s3://crabby-images/018db/018db3929ab10b81c46919a99a34f3baab924c78" alt=""
Seriously, can we not have cool logos for PHP mods?
data:image/s3,"s3://crabby-images/e8f35/e8f3571783afc4f9a7fe0dec3b3aa5cd3cbedb23" alt=""
/etc/php/7.(0|1)/mods-available/opcache.ini
data:image/s3,"s3://crabby-images/d3957/d3957c6010d39a416e95e48d7694af4b303f6892" alt=""
data:image/s3,"s3://crabby-images/22f14/22f14979fc1d5ab59d6731490fa4e14a26a91f27" alt=""
Easy right?
data:image/s3,"s3://crabby-images/f7612/f7612048954deea8778701851b46a62cc5b8da1e" alt=""
github.com/rlerdorf/opcache-status
You'll miss: crontab for scheduling jobs
Why did I commit to this meme thing?
data:image/s3,"s3://crabby-images/ce565/ce5651644d859ce1b7bc70e10bd2875a71b8290a" alt=""
Logging is fun...
data:image/s3,"s3://crabby-images/23cfc/23cfcbe3314b6940550b25a6e941a6e0b36f83e8" alt=""
data:image/s3,"s3://crabby-images/ccfb0/ccfb0752479dc1797c813fa18f24f3c0fd7ae147" alt=""
Sounds like you'll miss a lot...
What do you gain?
- Ability to offer "always up" web services to your company or clients without building your own data centre(s)
- A growing standard for how distributed applications behave
- Stupidly cheap storage on S3 and processing on Lambda
- Bulletproof backups
- Multiple options for data sovereignty
AWS might appear hard, but it's easier than finding a relevant meme for each item in a list of infrastructure problems!
Liked this talk?
Let me know!
@m1ke on Twitter
github.com/m1ke
Enjoy the rest of PHPNW17
Please leave feedback
https://joind.in/talk/0e908
data:image/s3,"s3://crabby-images/5ee61/5ee61b501b86bfd81282002ea944c4cbe6bd062e" alt=""
What You'll Miss on AWS
By Mike Lehan
What You'll Miss on AWS
Moving from a traditional server environment to AWS can be scary and confusing; here are some ways to make it better. Presented at PHPNW17
- 2,891