microservices
TRANSCRIPT
![Page 1: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/1.jpg)
Microservices
Mateus PradoSystems Engineer
Walmart.com LATAM
![Page 2: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/2.jpg)
$ whoami
Hi, i’m Mateus,Software and infrastructure architect.
I like Java, Ruby, C, Python, Cloud and Unix.
![Page 3: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/3.jpg)
Frontend components Business
Data layer
Messaging
Common application architecture
L B
![Page 4: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/4.jpg)
Easy to deploy
![Page 5: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/5.jpg)
New devs
![Page 6: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/6.jpg)
Continuous Delivery
![Page 7: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/7.jpg)
Try new technologies
![Page 8: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/8.jpg)
Scalability
![Page 9: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/9.jpg)
Monolithic
![Page 10: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/10.jpg)
Microservices
![Page 11: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/11.jpg)
The Unix Philosophy
![Page 12: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/12.jpg)
The Unix Philosophy
![Page 13: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/13.jpg)
Characteristics of
Microservices
![Page 14: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/14.jpg)
Small, single responsibility
Fit in your head
“If a class is bigger than my head then it is too big”
You can throw them away - rewrite, maintain
Easy to test.
![Page 15: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/15.jpg)
Resilience
Yes, they will fail, inevitably happen when least desired.
Failures test in production?
Yes.
If you do not find, your customer will.
Deploy automation, continuous delivery…
![Page 16: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/16.jpg)
Scale
…what you need to scale.
Run on multiple regions.
![Page 17: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/17.jpg)
Many technologies
Use Ruby for GET /users/login
Use Java for POST /checkout
Use C for GET /metrics/time-first-byte
Use .Net for GET /about-us :)
Try languages, db, queue
![Page 18: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/18.jpg)
–Johnny Appleseed
“Type a quote here.”
MICROSERVERMICROSERVICES
![Page 19: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/19.jpg)
MicroservERS
![Page 20: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/20.jpg)
![Page 21: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/21.jpg)
Forever
![Page 22: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/22.jpg)
sysadmin troop
![Page 23: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/23.jpg)
...
![Page 24: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/24.jpg)
Do not fear
![Page 25: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/25.jpg)
Jenkins
Chef
Capistrano
Puppet
Rundeck
own scripts
Automate all the things
![Page 26: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/26.jpg)
Too many log files
![Page 27: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/27.jpg)
Log aggregation
![Page 28: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/28.jpg)
Application
NFS to /var/www
VM0 VM2 VM3
Storage volumes
NFS to /var/lib/rabbitmq/mnesia
![Page 29: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/29.jpg)
S3
Distributed storages
![Page 30: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/30.jpg)
Ah, so, look well…
Monitoring
![Page 31: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/31.jpg)
SMS
Twitter, Facebook
Smoke
own remediation scripts.
efficient
Notifications and auto-remediation
![Page 32: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/32.jpg)
Cloud
![Page 33: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/33.jpg)
Homemade
![Page 34: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/34.jpg)
"They need to play." - lorieri
![Page 35: Microservices](https://reader031.vdocuments.us/reader031/viewer/2022020307/55a929851a28abb3768b481f/html5/thumbnails/35.jpg)
Q&A