How to build an app in the cloud?
Edition 2024
How to join?
data:image/s3,"s3://crabby-images/e8c6e/e8c6ef89277015ca842e6454cd59bb48a8ea5ff8" alt=""
Use the phone, Luke!
data:image/s3,"s3://crabby-images/e8c6e/e8c6ef89277015ca842e6454cd59bb48a8ea5ff8" alt=""
Piotr Stapp
- Unique name - just sing a song: "Don't Stapp me know" ;)
- SAFe System Principal Architect @ Demant Technology Center
- ex - Senior software/DevOps/Architect @mBank/@FinAi/@Allegro
- Own company (small consulting + workshops)
- M.Sc (distction) Oxford Brooks University in Web Tech
- M.Sc. Warsaw University of Technology in Computer Science
data:image/s3,"s3://crabby-images/e8c6e/e8c6ef89277015ca842e6454cd59bb48a8ea5ff8" alt=""
data:image/s3,"s3://crabby-images/b8282/b8282032e556402051afb21ff08ef1a654d73e45" alt=""
data:image/s3,"s3://crabby-images/c2a0a/c2a0a6eac107560a3dbc5ddd814f0a751b552e6d" alt=""
Attention
All opinions are my own
and
do not necessarily reflect
the views of any companies.
data:image/s3,"s3://crabby-images/e8c6e/e8c6ef89277015ca842e6454cd59bb48a8ea5ff8" alt=""
Context
data:image/s3,"s3://crabby-images/e8c6e/e8c6ef89277015ca842e6454cd59bb48a8ea5ff8" alt=""
Agile -> Scrum -> SAFe
data:image/s3,"s3://crabby-images/b882b/b882b9f3735dc008025153365b3d8c0a9a3445d8" alt=""
App? Seriosly?
data:image/s3,"s3://crabby-images/e8c6e/e8c6ef89277015ca842e6454cd59bb48a8ea5ff8" alt=""
data:image/s3,"s3://crabby-images/b2082/b2082039c8336e1b4a3c9d82f1bdd4a744a02dd8" alt=""
data:image/s3,"s3://crabby-images/0475d/0475d9cb7b24dfb39c09a947ea8284fac5266b2c" alt=""
Internal Developer Platform
Benefits:
- Platforms are designed to achieve scale and reduce time-to-value.
- They eliminate toil by offering DevEx and simplified operations.
- Key components include self-sufficiency tools, common task assistance, reusable building blocks, and early feedback on problems or security risks.
data:image/s3,"s3://crabby-images/e8c6e/e8c6ef89277015ca842e6454cd59bb48a8ea5ff8" alt=""
data:image/s3,"s3://crabby-images/bdf55/bdf55c00b4ac4f0ed3fcd2a6adb927abbb8b190f" alt=""
Basic
data:image/s3,"s3://crabby-images/e8c6e/e8c6ef89277015ca842e6454cd59bb48a8ea5ff8" alt=""
Pick your favorite cloud
Version control
CI/CD
Did you include?
Our contract
- In this presentation money are not important
- In real life they are
data:image/s3,"s3://crabby-images/7dcdf/7dcdf503111e4f21b7c6abc9e49bd296aab3df79" alt=""
Resources
data:image/s3,"s3://crabby-images/e8c6e/e8c6ef89277015ca842e6454cd59bb48a8ea5ff8" alt=""
The incomplete list
Containers
- Azure Container Instances
- Azure Kubernetes Service (AKS)
- Azure Container Apps
- Azure Web App with containers or not
- Virtual machines + custom scripts (e.g. docker-compose up)
- Virtual machines + "cluster management" (e.g. Rancher, Kubermatic, ... )
No containers
- Not today - sorry :)
Upfront + static costs
Containers
- Azure Container Instances
- Azure Kubernetes Service (AKS)
- Azure Container Apps
- Azure Web Apps with containers or not
- Virtual machines + custom scripts (e.g. docker-compose up)
- Virtual machines + "cluster management" (e.g. Rancher, Kubermatic, ... )
Easy to scale up
Containers
- Azure Container Instances
- Azure Kubernetes Service (AKS) ***
- Azure Container Apps
- Azure Web Apps
- Virtual machines + custom scripts
- Virtual machines + "cluster management"
Easy to scale down
Containers
- Azure Container Instances
- Azure Kubernetes Service (AKS) ***
- Azure Container Apps
- Azure Web Apps
- Virtual machines + custom scripts
- Virtual machines + "cluster management" ***
DevEx
Containers
- Azure Container Instances
- Azure Kubernetes Service (AKS) ***
- Azure Container Apps
- Azure Web Apps
- Virtual machines + custom scripts
- Virtual machines + "cluster management" ***
Voting on hosting
Data
data:image/s3,"s3://crabby-images/e8c6e/e8c6ef89277015ca842e6454cd59bb48a8ea5ff8" alt=""
data:image/s3,"s3://crabby-images/fd4bd/fd4bd0b4157f386c0c2581bfd56e89f60b758ff2" alt=""
Small recap
- We build a platform - different systems may have different needs
- Still we need to give "something" with:
- integrated networking
- HAA
- support
- etc.
NoSQL
- Great, isn't it?
- New, isn't it?
SQL
- Solid, isn't it?
- Well known, isn't it?
Options
- Self-hosted "custom" one on VM's
- Azure Storage
- Cosmos DB
- "Native"
- Mongo
- GraphQL
- Postgres on Cosmos
- ....
- SQL as a Service
- MSSQL
- Postgres
- MySQL
- MariaDB
Custom stuff on VM's
Before you decide, you should know
- why PaaS DB won't work for you
- how to manage this custom stuff
Azure Storage
- Very cheap
- Simple key-value or "file database"
- Limit for maximum number of operations
- Used by https://haveibeenpwned.com/
In other words, if I want 100GB of storage and I want to hit it 10 million times, it’ll cost me $8 a month.
Azure SQL for ...
Cosmos DB
- "SQL", API for MongoDB, Gremlin, Cassandra, Table, ...
- Key-vaule, Column-Family, Documents, Graph
- Pricing:
- Standard
- Auto-scale
- Serverless
- Dynamic scaling? Yes!!
- Postgres on board? Yes!!!
What about ...
- DB2🙈 (check: IBM DB2 Azure Virtual Machines DBMS)
- Oracle 🙉 (check: Oracle Database Service for Microsoft Azure)
- Redis🙊 (check: Azure Cache for Redis)
- ....
data:image/s3,"s3://crabby-images/44db5/44db5b485109b98b528ac3973d3b843a4519d1c1" alt=""
GeeCON 2023: Wojtek Ptak
Hypergrowth scaling made simple
data:image/s3,"s3://crabby-images/02522/025222043aed1bbf89dabb5f6ea5e40fee29f6f5" alt=""
Options
- Self-hosted "custom" one on VM's
- Azure Storage
- Cosmos DB
- SQL as a Service
- Postgres
Voting
Services
or queues?
data:image/s3,"s3://crabby-images/e8c6e/e8c6ef89277015ca842e6454cd59bb48a8ea5ff8" alt=""
data:image/s3,"s3://crabby-images/bdf55/bdf55c00b4ac4f0ed3fcd2a6adb927abbb8b190f" alt=""
data:image/s3,"s3://crabby-images/bb70f/bb70f20d6fa0b802705b9c25ff3e8e3280321e28" alt=""
Let's zoom it
ActiveMQ vs Service Bus
data:image/s3,"s3://crabby-images/c5028/c5028aa9a2f2345745143756fdb3ca79f9838162" alt=""
RabbitMQ vs AMPQ
- AMQP 1.0 (used by Service Bus) is a completely different protocol than AMQP 0-9-1 (used by RabbitMQ)
- Rabbit implements AMQP 1.0 via a plugin
Kafka vs Event Hub
data:image/s3,"s3://crabby-images/2d98b/2d98b1d5ec3ab9d1959a4982990e3bf3bc8c4575" alt=""
data:image/s3,"s3://crabby-images/44413/444136365222349a1efd2e8c8c46bca9b2685309" alt=""
To queue or not to queue?
Monitoring & logging
data:image/s3,"s3://crabby-images/e8c6e/e8c6ef89277015ca842e6454cd59bb48a8ea5ff8" alt=""
data:image/s3,"s3://crabby-images/bdf55/bdf55c00b4ac4f0ed3fcd2a6adb927abbb8b190f" alt=""
Let's zoom it
data:image/s3,"s3://crabby-images/14555/14555b71b854116d50b7143250b119ab7001a887" alt=""
data:image/s3,"s3://crabby-images/c7164/c71647aed6f9d14c14fec341a3171582eb87fa77" alt=""
What about Azure?
data:image/s3,"s3://crabby-images/547ad/547ad3a9b32c610c3df0a1e0b8c047e3976d892d" alt=""
And more
The (in)complete list
- Application Insights
- Azure Monitor ++
- Grafana / Azure Managed Grafana
- Prometheus / Azure Monitor Managed Service for Prometheus
- Self-hosted ELK
- ....
I want to use
User Data Storage
accounts and passwords
data:image/s3,"s3://crabby-images/e8c6e/e8c6ef89277015ca842e6454cd59bb48a8ea5ff8" alt=""
Old days
data:image/s3,"s3://crabby-images/a2ea7/a2ea743e4e7a8c9223d95b5f069ab963d79cc726" alt=""
Receipe
- Take one technology that you <3
- Apply the first tutorial about user accounts
- Or copy some stuff from previous project
My case
- .NET Framework (a good one)
- Avoided problems:
- Passwords with base64
- SQL injection
- In PHP, NodeJS, Java, .... - situation is simmilar
Seriously!
data:image/s3,"s3://crabby-images/06b63/06b636231d9bc51c75201745a35c326948a7608a" alt=""
Today
data:image/s3,"s3://crabby-images/a9727/a97273e47a3ea74288894a8359ad635e64d20bd5" alt=""
The incomplete list
- Dedicated tools for user management:
- Active Directory
- OpenLDAP
- ...
- Ready to deploy and use:
- Keycloak,
- Identity Server 4
- ...
- SaaS:
- Auth0
- Userbase
- Azure B2C
Candidates
"Self-hosted"
- My own with NuGet / Maven / NPM / pip / ... support
- Active Directory / OpenLDAP / ...
- Keycloak / Identity Server 4 / ...
SaaS
- SaaS outside Azure: Auth0
- "SaaS" inside Azure: Azure B2C
- Totally "unknow" SaaS: Userbase
SaaS Features
- Facebook / Twitter / Github / .... login
- MFA with application and SMS
- FIDO2
- Custom domain
- Custom CSS
- ....
Money
"Have I Been Pwned"?
The end?
data:image/s3,"s3://crabby-images/e8c6e/e8c6ef89277015ca842e6454cd59bb48a8ea5ff8" alt=""
Our amazing IDP!
State
- We know how to store code
- We know how to host our app
- We know how to deploy it
- We know how to monitor it
- We know how to store data
- We know how to manage users
- We know ....
Are we ready to deploy?
Generate image representing our deployment using AI
data:image/s3,"s3://crabby-images/82096/8209653cbea6a4afd82c08d51a7bb0ae771f7488" alt=""
Your deploy will be like dance.
data:image/s3,"s3://crabby-images/35cc4/35cc43df90e80d5c88bb1c279a787738d4469289" alt=""
Generating perfect image....
Help! Aider! Hilfe! Pomocy!
data:image/s3,"s3://crabby-images/a8efc/a8efc3a719d1ef444670fd2459e6a48453911ed3" alt=""
How to become an architect in the cloud?
By Piotr Stapp
How to become an architect in the cloud?
- 111