Skip to main content

Cloud

https://steampipe.io - https://github.com/turbot/steampipe - Use SQL to instantly query your cloud services

Types of cloud

  • Public: AWS, GCP, Azure, DigitalOcean... Shares compute resources among different customers.
  • Private (on-premises): OpenStack, VMware...
  • Hybrid: private & public clouds connected together. See https://aws.amazon.com/hybrid

https://docs.aws.amazon.com/whitepapers/latest/aws-overview/types-of-cloud-computing.html

https://www.redhat.com/en/topics/cloud-computing/public-cloud-vs-private-cloud-and-hybrid-cloud

Types of cloud services

TODO

  • IaaS
    • EC2
  • PaaS
  • SaaS

Tools

Server Images

Snapshot of the OS, software, files...

Two categories: Virtual Machines and Containers.

  • Docker
  • Packer
  • Vagrant. For local development environments.

Configuration Management

Install software on existing servers.

  • Ansible
  • Chef
  • Puppet

More tools: https://en.wikipedia.org/wiki/Comparison_of_open-source_configuration_management_software

Note that Ansible can do some provisioning too (automates provisioning, configuration management, application deployment, orchestration, and many other IT processes - source), but it's better to use a provisioning tool.

info

If you use server images (Docker, Packer), you don't have much need for configuration management tools, you only need provisioning tools. For example, use Terraform and Docker together.

If you don't use server images, it's common to use provisioning and configuration tools together. For example, use Terraform to provision the servers and Ansible to configure them.

Provisioning

To create the actual infrastructure (servers, databases, queues, load balancers, firewalls, SSL certificates etc.).

  • Terraform
  • CloudFormation
  • Pulumi
  • Azure Resource Manager
info

Provisioning tools can also do some configuration. For example, you can run user data scripts on an EC2 machine using CloudFormation and Terraform.

Orchestration

  • Kubernetes
  • ECS
  • Docker Swarm
  • Nomad
  • Heat (OpenStack)

High availability, fault tolerance and disaster recovery

  • High availability ($): a system with minimal (but not zero) downtime. For example, availability of 99.99%. It can recover from failure automatically with some downtime.
  • Fault tolerance ($$): a system that can continue to operate without interruption in case of failure.
  • Disaster recovery: recover from major failures like data centers or region disasters.

https://www.freecodecamp.org/news/high-availability-fault-tolerance-and-disaster-recovery-explained/

https://www.geeksforgeeks.org/high-availability-vs-fault-tolerance-vs-disaster-recovery/

Diagrams

Mermaid architecture diagrams - https://mermaid.js.org/syntax/architecture

https://diagrams.mingrammer.com

https://www.diagrams.net

https://www.cloudcraft.co

https://cloudairy.com - Easy to use and also allows animated gif export - see example here

https://pragprog.com/titles/apdiag/creating-software-with-modern-diagramming-techniques

AWS icons - https://awsicons.dev