POPC Infrastructure
as GitOps Implementation
GitOps
data:image/s3,"s3://crabby-images/6033a/6033a38892c688ec422032b3fe545609a521c378" alt=""
GIT
Infrastructure as a Code
Terraform
Ansible
Infrastructure as a Code
data:image/s3,"s3://crabby-images/a7db4/a7db42d1e3bb3c78c96ed77a6f7de6e029535aa1" alt=""
resource "azurerm_resource_group" "dtm-dev" {
name = "dtm-dev"
location = "West Europe"
}
resource "azurerm_virtual_network" "dtm-dev" {
name = "dtm-dev"
location = azurerm_resource_group.dtm-dev.location
resource_group_name = azurerm_resource_group.dtm-dev.name
address_space = ["10.1.0.0/16"]
}
VM
LB
Resource Group
data:image/s3,"s3://crabby-images/422cc/422ccbdad7d65e6f6216c926f905ad19eb847682" alt=""
DevOps
data:image/s3,"s3://crabby-images/2a51c/2a51cd53ef6b1f49b73ebbd9bc4ff695abfb5b93" alt=""
Plan
data:image/s3,"s3://crabby-images/6033a/6033a38892c688ec422032b3fe545609a521c378" alt=""
GIT
push
apply
Container Management
data:image/s3,"s3://crabby-images/55e23/55e230c9e952098460e9e169c6ec026639d51928" alt=""
Kubernetes
OpenShift
Rancher
Cloud Foundary
PKS
Container Management
Master
Node
Node
apiVersion: apps/v1
kind: Deployment
metadata:
name: notifications-gateway
labels:
app: notifications-gateway
spec:
replicas: 1
selector:
matchLabels:
app: notifications-gateway
strategy:
type: RollingUpdate
.....
apply
Node
Deployment
ReplikaSet
POD
K8S (AKS) Deployment
data:image/s3,"s3://crabby-images/a7db4/a7db42d1e3bb3c78c96ed77a6f7de6e029535aa1" alt=""
data:image/s3,"s3://crabby-images/422cc/422ccbdad7d65e6f6216c926f905ad19eb847682" alt=""
DevOps
data:image/s3,"s3://crabby-images/6033a/6033a38892c688ec422032b3fe545609a521c378" alt=""
GIT
push
apply
node
node
node
data:image/s3,"s3://crabby-images/656c3/656c32fafeafe105974d09b90ab831873eddd96f" alt=""
LB
LB
VPN Gateway
data:image/s3,"s3://crabby-images/422cc/422ccbdad7d65e6f6216c926f905ad19eb847682" alt=""
AppUser
data:image/s3,"s3://crabby-images/422cc/422ccbdad7d65e6f6216c926f905ad19eb847682" alt=""
Dev
internal access
internal access
external access
data:image/s3,"s3://crabby-images/2a51c/2a51cd53ef6b1f49b73ebbd9bc4ff695abfb5b93" alt=""
AKS Plan
Manage K8S Resources
ArgoCD
FluxCD
Terraform
Ansible
Jenkins X
Manage K8S Resources
data:image/s3,"s3://crabby-images/422cc/422ccbdad7d65e6f6216c926f905ad19eb847682" alt=""
DevOps
data:image/s3,"s3://crabby-images/6033a/6033a38892c688ec422032b3fe545609a521c378" alt=""
GIT
node
data:image/s3,"s3://crabby-images/2a51c/2a51cd53ef6b1f49b73ebbd9bc4ff695abfb5b93" alt=""
K8s Resources
data:image/s3,"s3://crabby-images/51176/51176f3dd5dc16a17b2839c168976a5ccd10ff1b" alt=""
push
pull
node
node
synchronize
service
pod
secret
data:image/s3,"s3://crabby-images/656c3/656c32fafeafe105974d09b90ab831873eddd96f" alt=""
Manage K8S Resources
data:image/s3,"s3://crabby-images/f6710/f6710da5cfdd9b7ccbde327bf9ed8e4b8af435b0" alt=""
Manage K8S Resources
data:image/s3,"s3://crabby-images/fd549/fd5497331a67fa4844d7b829b330218febf30aec" alt=""
ArgoCD Deployment
data:image/s3,"s3://crabby-images/a7db4/a7db42d1e3bb3c78c96ed77a6f7de6e029535aa1" alt=""
data:image/s3,"s3://crabby-images/422cc/422ccbdad7d65e6f6216c926f905ad19eb847682" alt=""
DevOps
data:image/s3,"s3://crabby-images/6033a/6033a38892c688ec422032b3fe545609a521c378" alt=""
GIT
push
apply
node
node
node
data:image/s3,"s3://crabby-images/656c3/656c32fafeafe105974d09b90ab831873eddd96f" alt=""
LB
LB
VPN Gateway
data:image/s3,"s3://crabby-images/51176/51176f3dd5dc16a17b2839c168976a5ccd10ff1b" alt=""
access to ArgoCD
data:image/s3,"s3://crabby-images/2a51c/2a51cd53ef6b1f49b73ebbd9bc4ff695abfb5b93" alt=""
ArgoCD Plan
Logs
GrayLog
EFK (Elasticsearch Logstash Kibana)
ELK (Elasticsearch FluentD Kibana)
Data Dog
Logs
app
fluentD
data:image/s3,"s3://crabby-images/5dac2/5dac2ac03db1505e94ca7c4d5c34a2dd5edcc091" alt=""
elastic
kibana
app
fluentD
data:image/s3,"s3://crabby-images/5dac2/5dac2ac03db1505e94ca7c4d5c34a2dd5edcc091" alt=""
data:image/s3,"s3://crabby-images/422cc/422ccbdad7d65e6f6216c926f905ad19eb847682" alt=""
DevOps
logging
logging
query logs
data:image/s3,"s3://crabby-images/656c3/656c32fafeafe105974d09b90ab831873eddd96f" alt=""
Logs
data:image/s3,"s3://crabby-images/a3b30/a3b300aac8e960ee4f6ecab31efee082aa43f270" alt=""
Metrics
Prometheus
Graphite
Zabbix
Grafana (UI)
Metrics
app
prometheus
grafana
data:image/s3,"s3://crabby-images/422cc/422ccbdad7d65e6f6216c926f905ad19eb847682" alt=""
DevOps
query metrics
app
svc
apiVersion: v1
kind: Service
metadata:
annotations:
prometheus.io/scrape: 'true'
prometheus.io/path: '/actuator/prometheus'
prometheus.io/port: '8081'
prometheus.io/scheme: 'http'
labels:
app: notifications-gateway
name: notifications-gateway
spec:
....
scrape metrics
app
app
svc
scrape metrics
data:image/s3,"s3://crabby-images/656c3/656c32fafeafe105974d09b90ab831873eddd96f" alt=""
Metrics
data:image/s3,"s3://crabby-images/6033a/6033a38892c688ec422032b3fe545609a521c378" alt=""
GIT
push
data:image/s3,"s3://crabby-images/2a51c/2a51cd53ef6b1f49b73ebbd9bc4ff695abfb5b93" alt=""
Board Def
data:image/s3,"s3://crabby-images/422cc/422ccbdad7d65e6f6216c926f905ad19eb847682" alt=""
DevOps
data:image/s3,"s3://crabby-images/656c3/656c32fafeafe105974d09b90ab831873eddd96f" alt=""
grafana
board
puller
pull
data:image/s3,"s3://crabby-images/5dac2/5dac2ac03db1505e94ca7c4d5c34a2dd5edcc091" alt=""
node
Metrics
data:image/s3,"s3://crabby-images/ff11a/ff11a9f14c770ff2577fbe14b82d6e2a5db4a4d0" alt=""
Secrets
Vault
Consule
SealedSecrets
Secrets
sealed controller
node
argoCD
sealed secret
data:image/s3,"s3://crabby-images/6033a/6033a38892c688ec422032b3fe545609a521c378" alt=""
GIT
data:image/s3,"s3://crabby-images/2a51c/2a51cd53ef6b1f49b73ebbd9bc4ff695abfb5b93" alt=""
Secret
data:image/s3,"s3://crabby-images/422cc/422ccbdad7d65e6f6216c926f905ad19eb847682" alt=""
DevOps
kind: Secret
metadata:
name: rabbitmq
namespace: rabbitmq
data:
password: dmVylY3JldA==
username: cmFml0
kind: SealedSecret
metadata:
name: rabbitmq
namespace: rabbitmq
spec:
encryptedData:
password: AgBd6Kf...
username: AgA0KuM7...
template:
metadata:
name: rabbitmq
...
kubeseal
data:image/s3,"s3://crabby-images/2a51c/2a51cd53ef6b1f49b73ebbd9bc4ff695abfb5b93" alt=""
SealedSecret
secret
pull
create
notify
unseale
data:image/s3,"s3://crabby-images/656c3/656c32fafeafe105974d09b90ab831873eddd96f" alt=""
push
Secrets
node
Vault
data:image/s3,"s3://crabby-images/422cc/422ccbdad7d65e6f6216c926f905ad19eb847682" alt=""
DevOps
get secret
data:image/s3,"s3://crabby-images/656c3/656c32fafeafe105974d09b90ab831873eddd96f" alt=""
init
data:image/s3,"s3://crabby-images/5dac2/5dac2ac03db1505e94ca7c4d5c34a2dd5edcc091" alt=""
app
secrets
put secret
Secrets
node
apiVersion: apps/v1
kind: Deployment
metadata:
name: notifications-gateway
labels:
app: notifications-gateway
spec:
template:
metadata:
annotations:
vault.hashicorp.com/agent-inject: "true"
vault.hashicorp.com/agent-inject-secret-smsapi: kube-dev/data/smsapi
vault.hashicorp.com/agent-inject-secret-application.properties: kube-dev/data/rabbitmq
vault.hashicorp.com/agent-inject-template-application.properties: |
{{- with secret "kube-dev/data/rabbitmq" -}}
spring.rabbitmq.username={{ .Data.data.username }}
spring.rabbitmq.password={{ .Data.data.password }}{{ "\n" }}
{{- end -}}
{{- with secret "kube-dev/data/smsapi" -}}
notifications.sms.provider.token={{ .Data.data.token }}
{{- end -}}
vault.hashicorp.com/role: internal-app
Vault configuration:
CICD
node
Jenkins
Tekton
CircleCi
Jenkins X
Jenkins Configuration as a Code
node
data:image/s3,"s3://crabby-images/6033a/6033a38892c688ec422032b3fe545609a521c378" alt=""
GIT
push
data:image/s3,"s3://crabby-images/2a51c/2a51cd53ef6b1f49b73ebbd9bc4ff695abfb5b93" alt=""
Configuration
data:image/s3,"s3://crabby-images/422cc/422ccbdad7d65e6f6216c926f905ad19eb847682" alt=""
DevOps
argoCD
cofig map
pull
create
mount
data:image/s3,"s3://crabby-images/656c3/656c32fafeafe105974d09b90ab831873eddd96f" alt=""
jenkins
data:image/s3,"s3://crabby-images/5dac2/5dac2ac03db1505e94ca7c4d5c34a2dd5edcc091" alt=""
jenkins pod
Jenkins Pipelines as a Code
node
data:image/s3,"s3://crabby-images/6033a/6033a38892c688ec422032b3fe545609a521c378" alt=""
GIT
push
data:image/s3,"s3://crabby-images/2a51c/2a51cd53ef6b1f49b73ebbd9bc4ff695abfb5b93" alt=""
Pipelines
data:image/s3,"s3://crabby-images/422cc/422ccbdad7d65e6f6216c926f905ad19eb847682" alt=""
DevOps
pull
data:image/s3,"s3://crabby-images/656c3/656c32fafeafe105974d09b90ab831873eddd96f" alt=""
jenkins
data:image/s3,"s3://crabby-images/f9d29/f9d2994183cc1e0da4915747acee06054694eff8" alt=""
data:image/s3,"s3://crabby-images/4dc71/4dc71bb0d5893b4be664b2056fb1222048e7d317" alt=""
seed-job
data:image/s3,"s3://crabby-images/fa1c3/fa1c3540b1dcf3396982f22263d55fc4029bd895" alt=""
CICD
node
data:image/s3,"s3://crabby-images/0e251/0e251d7294fab66bddb05125c103b8e81635ceed" alt=""
data:image/s3,"s3://crabby-images/6033a/6033a38892c688ec422032b3fe545609a521c378" alt=""
GIT
push
data:image/s3,"s3://crabby-images/2a51c/2a51cd53ef6b1f49b73ebbd9bc4ff695abfb5b93" alt=""
code
data:image/s3,"s3://crabby-images/422cc/422ccbdad7d65e6f6216c926f905ad19eb847682" alt=""
Dev
trigger
data:image/s3,"s3://crabby-images/656c3/656c32fafeafe105974d09b90ab831873eddd96f" alt=""
data:image/s3,"s3://crabby-images/a7d53/a7d531e5055fb10bc68fe99b5422a695816a7b46" alt=""
data:image/s3,"s3://crabby-images/6033a/6033a38892c688ec422032b3fe545609a521c378" alt=""
data:image/s3,"s3://crabby-images/dc0b8/dc0b852c8472a1bcd054de363ede1cfa485ce925" alt=""
jenkins
worker
creates
clone
build
unit tests
integration tests
check style
archunits
app:1.0
app:master
data:image/s3,"s3://crabby-images/2b0cd/2b0cd3b847f758640f09d69fed07b0bae41e0f97" alt=""
app
Image Registry
Thank You
DevOps
By andipansa
DevOps
- 143