AWS patterns for humans
Юрий Дадычин
FE DM, Levi9
Yes, I'm a FE architect at Levi9.
And yes, I'm going to speak about AWS
WHY???
I've took AWS Certification training
There was a lot of marketing
- EC, DB's, S3 and so on
- Licenses
- Availability
I have spotted a some kind of pattern
- Pattern of hi-load and hi-availability app setup
- Access control principles
- Applications which can be hybrid-ised
Let's introduce ourselves
- Who are using AWS among you?
- What are you using?
Cool, nice to know many of you know a lot about AWS
But for those who are far from AWS I'll run threw AWS
I'll start from idea
-
IaaS
-
PaaS
-
SaaS
-
I mean cloud computing
data:image/s3,"s3://crabby-images/b7157/b71570d4fcea4bb6d7346242bd7b0bacaabbfb2a" alt=""
data:image/s3,"s3://crabby-images/54569/54569a38727483261f641f2e128c7e9e55893a5f" alt=""
data:image/s3,"s3://crabby-images/43c83/43c832840c42ee2470086915eca39cf1820e7b2b" alt=""
data:image/s3,"s3://crabby-images/b3591/b3591d18c55a9160154695feadab79071ccf0ccd" alt=""
data:image/s3,"s3://crabby-images/b0b29/b0b2927fe9cc0e7331ff77a41d09fbde9f697821" alt=""
data:image/s3,"s3://crabby-images/add72/add72dab22439cecfef0e98d291ec25d3175c2cb" alt=""
data:image/s3,"s3://crabby-images/08f94/08f942d88816a5967abcdc3364a66fe5668a5d8e" alt=""
data:image/s3,"s3://crabby-images/fee86/fee863007adc16237b4eb116f8f52a86d49324f9" alt=""
data:image/s3,"s3://crabby-images/08063/0806393e0278072e491420fa6926ad10fe3d2be1" alt=""
data:image/s3,"s3://crabby-images/bd168/bd168a722e0cb2ec040ec8b0d9a982e940afccb7" alt=""
data:image/s3,"s3://crabby-images/a56ea/a56ead06f5722fc08ec1d068eb6bb937d72d7da1" alt=""
data:image/s3,"s3://crabby-images/b9b31/b9b31ec1f3f8d076d60cc93ab50bd267031809ba" alt=""
data:image/s3,"s3://crabby-images/f9ea7/f9ea71bb4fbb32cd7e0b4cec63e54bc3456df135" alt=""
data:image/s3,"s3://crabby-images/b2696/b269621f605d9b4520184072f29667dfb9772226" alt=""
data:image/s3,"s3://crabby-images/a036c/a036c6bce60225c2a19419722ea3f785a0ee59b3" alt=""
Lambda
exports.myHandler = function(event, context,
callback) {
console.log("value1 = " + event.key1);
console.log("value2 = " + event.key2);
callback(null, "some success message");
// or
// callback("some error type");
}
data:image/s3,"s3://crabby-images/42592/42592d5c41f5354549dc2abc782c459cd4d52200" alt=""
data:image/s3,"s3://crabby-images/37bd6/37bd604b330b37287628427dc1ae9d7029c232e6" alt=""
So what do we see?
- Application must be easy to scale
- Try to decouple app for scalable micro-services to have control on bottle-neck parts
- You can use hybrid server-DB set but consider lower latency
- Use queues and notification based ISC(inter-service communication)
- Consider FE SPA as stand-alone application deployed aside of any of your application
Well designed application
data:image/s3,"s3://crabby-images/b7022/b7022fd0cf8620a81f98e543c0e50cc916cca9b3" alt=""
data:image/s3,"s3://crabby-images/bd04c/bd04cddbcc307a318df6247cb47ff5bf9dc38291" alt=""
What is best for micro-services?
- Docker
- REST ISC in RAML or http://swagger.io/ or old fags WSDL
- http://microservices.io/
Couple words about FE and micro-services?
data:image/s3,"s3://crabby-images/52d65/52d65aab2499de88bcbf2832d8f880ca00eb9e6d" alt=""
Yep, it's some kind of stand alone application
- https://github.com/stylesuxx/generator-react-webpack-redux
- https://github.com/angular/angular-cli#generating-and-serving-an-angular2-project-via-a-development-server -> Proxy To Backend(s)
{
"/api": {
"target": "http://localhost:3000",
"secure": false
}
}
Thanks
AWS for humans
By Yuriy Dadichin
AWS for humans
How to build AWS friendly applications
- 521