31
How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

  • Upload
    others

  • View
    1

  • Download
    0

Embed Size (px)

Citation preview

Page 1: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

How HashiCorp platform tools can make the difference in development and deployment

Dmytro Mykhailov

Page 2: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

Dmytro Mykhailov

Solution Architect

• 3,5 years in EPAM

• >12 years in IT

• Microsoft Stack:• .NET• Azure

skype: dmitry.mikhaylov

email: [email protected]

blog: https://devraccoon.com/

Page 3: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

Problems in applications

• Holy Server

• Messy configuration

• Slow environments setup

• Works-on-my-machine syndrome

• Expensive resources that do nothing

• Hard non-consistent integration and end-to-end test environments

• Where is your disaster recovery?

• Are your secrets safe?

Page 4: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

Holy Server

• Thing that can be treated as benefits:

- Easy to setup

- No need of delivery infrastructure upfront

- No need of tools knowledge

• Drawbacks:

- Hard to maintain

- Service failure is a catastrophe

- Custom knowledge of how to configure similar server

Page 5: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

Immutable Infrastructure for Rescue

Immutable infrastructure is an approach to managing services and software deployments on IT resources wherein components are replaced rather than changed. An application or services is effectively redeployed each time any change occurs.

© WhatIs.com

Page 6: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

Immutable Infrastructure for Rescue

Image of WEBv32.2

Public portal v4.3Admin portal v1.2

Database v2.1

New feature CI ToolNotify Build

Developer

DBA

DevOps

Page 7: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

Immutable Infrastructure for Rescue

WEB v32.1

WEB v32.1

Backend Service A v12.34APIGW

LB

Backend Service B v3.2

Database A

Database B

WEB v32.1

Page 8: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

Messy Configuration –Reactive Configuration Database

Config

Config

Configuration Data

Dev

QA

Prod

Page 9: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

Messy Configuration –Reactive Configuration Database

Config

Config

Dev

Config DB

Config DB

Config DB

QA

Prod

Common Config Seed

Page 10: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

Messy Configuration –Reactive Configuration Database

ConfigDB Master

ConfigDB Agent

ConfigDB Agent

ConfigDB Agent

Page 11: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

Environments Setup, Disaster Recovery -Infrastructure-as-a-Code

Page 12: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

Tests, Works-on-my-machine syndrome –Containers and Images

Local Dev Machine

MacOS

CI/CD Pipeline

Build

Run

Test

QA Server

Linux

Build

Deploy Run

Page 13: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

Tests, Works-on-my-machine syndrome –Containers and Images

Local Dev Machine

MacOS

CI/CD Pipeline Dev Virtual Server

Linux

Build

Deploy Run

Page 14: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

Expensive not-used resources –Elastic cluster setup

17%

CPU

10%

CPU

55%

CPU

Page 15: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

Expensive not-used resources –Elastic cluster setup

Cluster Scheduler

CPU

55%72%

CPU

40%

Requests forallocation and deploy

Page 16: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

Secrets management

Configuration Data

Dev

QA

Prod

Config

ConfigAudit?Manage?Revoke?Where?How?

Page 17: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

Secrets management - Vault

Configuration Data

Dev

QA

Prod

Config

ConfigAuditManageRevoke

Vault

Page 18: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

Security Management - Vaults

ConfigDB Master

Vault

AuditManageRevoke

Page 19: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

Autopilot Pattern less or none application modification for containers

Application

Autopilot Process

Service Discovery & Health Check

On Start Post Stop

Health Health

On Change

Pre Stop

Page 20: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

Tao of HashiCorp

• Workflows, Not Technologies• Simple, Modular, Composable• Communicating Sequential Processes• Immutability• Versioning through Codification• Automation through Codification• Resilient Systems• Pragmatism

Page 21: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

Packer for Immutable Infrastructure

https://www.packer.io/

Packer is an open source tool for creating identical machine images for multiple platforms from a single source configuration.

Page 22: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

Packer for Immutable Infrastructure

https://www.packer.io/

Build Automated Machine Images

Page 23: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

Terraform for Infrastructure-as-a-Code

https://www.terraform.io/

Write, Plan, and Create Infrastructure as Code

Terraform enables you to safely and predictably create, change, and improve production infrastructure. It is an open source tool that codifies APIs into declarative configuration files that can be shared amongst team members, treated as code, edited, reviewed, and versioned.

Page 24: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

Consul for Service Discovery, Health Checking

https://www.consul.io/

Service Discovery and Configuration Made Easy

Page 25: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

Nomad for cluster scheduling

https://www.nomadproject.io/

Easily deploy applications at any scale

Page 26: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

Vagrant against works-on-my-machine syndrome

https://www.vagrantup.com/

Development Environments Made Easy

Page 27: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

Vault for sensitive data

https://www.vaultproject.io/

A Tool for Managing Secrets

Page 28: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

HashiCorp Tools Ecosystem – Small Scale

Local Dev Machine

</>

CI Pipeline Work Environment

VM Image Repository

CD Pipeline

Page 29: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

HashiCorp Tools Ecosystem – Large Scale

Local Dev Machine

</>

CI Pipeline

Server

CD Pipeline

Server

Nomad Cluster

VM Images

Page 30: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

Questions?

[email protected] https://www.linkedin.com/in/dmitry-mikhaylov-03b78971/blog: https://devraccoon.com

Dmytro Mykhailov

Page 31: How HashiCorp platform tools can make the difference in … · 2019-04-26 · How HashiCorp platform tools can make the difference in development and deployment Dmytro Mykhailov

Thank you!