Categories
Bibliography DevOps Java Kubernetes Software Engineering Spring Framework

Continuous Delivery for Java Apps: Build a CD Pipeline Step by Step Using Kubernetes, Docker, Vagrant, Jenkins, Spring, Maven and Artifactory – B078B3FJ7J, 2017

See: Continuous Delivery for Java Apps: Build a CD Pipeline Step by Step Using Kubernetes, Docker, Vagrant, Jenkins, Spring, Maven and Artifactory, Publisher ‏ : ‎ Leanpub (December 14, 2017)

See also: Spring Bibliography, Spring Framework and Cloud Native

Fair Use Source:

This book will guide you through the implementation of the real-world Continuous Delivery using top-notch technologies. Instead of finishing this book thinking “I know what Continuous Delivery is, but I have no idea how to implement it”, you will end up with your machine set up with a Kubernetes cluster running Jenkins Pipelines in a distributed and scalable fashion (each Pipeline run on a new Jenkins slave dynamically allocated as a Kubernetes pod) to test (unit, integration, acceptance, performance and smoke tests), build (with Maven), release (to Artifactory), distribute (to Docker Hub) and deploy (on Kubernetes) a Spring Boot app to testing, staging and production environments implementing the Canary Release deployment pattern.

TABLE OF CONTENTS:

INTRODUCTION
Agile
Scrum
Scrum and Continuous Integration
Deployed vs Released
Scrum and Continuous Delivery
XP and Continuous Delivery
Automated Tests
Continuous Integration
Feature Branch
Continuous Delivery
Continuous Delivery Pipeline
Continuous Delivery vs Continuous Deployment
Canary Release
A/B Tests
Feature Flags

NOTEPAD APP: AUTOMATED TESTS, MAVEN AND FLYWAY
Pre-Requisites
The Notepad Application
Automated Tests
Unit Tests
Integration Tests
 Acceptance Tests
  Page Object
  Distributed Acceptance Tests with Selenium-Grid
 Smoke Tests
 Performance Tests with Gatling.io
Apache Maven
Maven Snapshot vs Release
The Default Lifecycle and its Phases
Maven Repositories
Repository Manager (Artifactory)
Maven Plugins: Surefire and Failsafe
Maven Profile
Running Unit Tests
Running Integration Tests
Running Acceptance Tests
Running Smoke Tests
Running Performance Tests
Publish Artifacts to Artifactory with Maven
Publish a Snapshot to Artifactory
Publish a Release to Artifactory
The release:prepare Goal
The release:perform Goal
 Flyway

DOCKER
Introduction to Docker
Difference Between Container and Image
Docker Hub
Create your Account
Official Docker Repositories
Image Tags
Non-Official Docker Images
Create a Repository, an Image and Push it to Docker Hub
 Running Containers on Docker
  Running Containers as Daemons
  Container Clean Up
  Naming Containers
  Exposing Ports
  Persistent Data with Volumes
  Environment Variables
Docker Networking
  Create a Bridge Network
  Container Static IP Address
  Linking Containers
 Most Used Docker Commands
  Images
  Containers
  Misc
 Building Docker Images: Dockerfile

JENKINS: PIPELINE AS CODE AND CHATOPS
 Jenkins Overview
 Jenkins Concepts
  Job (or Project)
  Build
  Artifact
  Workspace
  Executor
  Plugin
  Node, Master, and Agent (or Slave)
 ChatOps
  Create a Slack Workspace
  Integrate Slack with Jenkins
  Slack Notification Plugin
  Use Hubot to Interact with Jenkins
 Jenkins Pipeline
  Declarative Pipeline vs Scripted Pipeline
  Scripted Pipeline
  Using Docker with Jenkins Pipelines
  Running Docker from Within the Jenkins Container
Scaling Jenkins with Slaves

KUBERNETES
 Why Kubernetes?
 Set up a Kubernetes Cluster using Vagrant
 Hands-on Introduction to Kubernetes
 Kubernetes Concepts
  Namespaces
  Pods
  Labels
  Replica Sets
  Services
  Service Discovery using DNS
  Service Discovery using Namespaces
  Volumes
  Handling External Configurations
  Config Maps
  Changing Logback Log Level at Runtime
  Secrets
  Using Secrets as Environment Variables
  Using Secrets as Files from a Pod
  Deployments
  Readiness Probes
  Liveness Probes
  Canary Release
Kubernetes Architecture
Kubernetes Master Components
Etcd
API Server
Controller Manager
Scheduler
 Kubernetes Node Components
  Service Proxy
  Kubelet
  cAdvisor
 Kubernetes Add-ons
  Web UI (Dashboard)
   Monitoring Kubernetes with Heapster, InfluxDB and Grafana
   Web UI Overview
  DNS

HANDS-ON PROJECT

APPENDICES

Categories
Bibliography DevOps DevSecOps-Security-Privacy

B08FBLVVFG

See: Ansible for DevOps: Server and configuration management for humans

Fair Use Source:

Categories
Bibliography

B07KFQL927

See: Managing Kubernetes: Operating Kubernetes Clusters in the Real World 1st Edition

See also Kubernetes and Cloud Native

Fair Use Source:

Categories
Bibliography

B0851SQW4V

See: Kubernetes Operators: Automating the Container Orchestration Platform 1st Edition

See also Kubernetes and Cloud Native

Fair Use Source:

Categories
Bibliography

B083VY7YHL

See: Guide pratique de Kubernetes – L’art de construire des conteneurs d’applications – collection O’Reilly (French Edition)

See also Kubernetes and Cloud Native

Fair Use Source:

Categories
Bibliography

B07YP1XSZ9

See: Kubernetes: Up and Running: Dive into the Future of Infrastructure 2nd Edition

See also Kubernetes and Cloud Native

Fair Use Source:

Categories
Bibliography

B07VCPM5VQ

See: Programming Kubernetes: Developing Cloud-Native Applications 1st Edition

See also Kubernetes and Cloud Native

Fair Use Source:

Categories
Bibliography

B07PJ4HM92

See: Cloud Native DevOps with Kubernetes: Building, Deploying, and Scaling Modern Applications in the Cloud 1st Edition

See also Kubernetes and Cloud Native

Fair Use Source:

Categories
Bibliography

B07QH3JCC6

See: Kubernetes Patterns: Reusable Elements for Designing Cloud-Native Applications 1st Edition

See also Kubernetes and Cloud Native

Fair Use Source:

Categories
Bibliography

B081J62KLW

See: Kubernetes Best Practices: Blueprints for Building Successful Applications on Kubernetes 1st Edition

See also Kubernetes and Cloud Native

Fair Use Source:

Categories
Bibliography

1617294292

See: Cloud Native Patterns: Designing change-tolerant software 1st Edition

See also Kubernetes and Cloud Native

Fair Use Source: https://www.manning.com/books/cloud-native-patterns

Categories
Bibliography

B08M9FMRFL

See: Learning Serverless: Design, Develop, and Deploy with Confidence 1st Edition

See also Kubernetes and Cloud Native

Fair Use Source:

Categories
Bibliography

1617296643

See: Knative in Action

See also Kubernetes and Cloud Native

Fair Use Source: https://www.manning.com/books/knative-in-action, https://github.com/knative/serving, https://redhat.com/en/topics/microservices/what-is-knative, https://knative.dev/docs, https://ibm.com/cloud/learn/knative, https://cloud.google.com/knative

Categories
Bibliography

B088CVL179

See: Knative Cookbook: Building Effective Serverless Applications with Kubernetes and OpenShift 1st Edition

Kubernetes-based, scale-to-zero, request-driven compute:

Knative Serving builds on Kubernetes to support deploying and serving of applications and functions as serverless containers. Serving is easy to get started with and scales to support advanced scenarios.

The Knative Serving project provides middleware primitives that enable:

  • Rapid deployment of serverless containers
  • Automatic scaling up and down to zero
  • Routing and network programming
  • Point-in-time snapshots of deployed code and configurations

See also Kubernetes and Cloud Native, https://github.com/knative/serving, https://redhat.com/en/topics/microservices/what-is-knative, https://knative.dev/docs, https://ibm.com/cloud/learn/knative, https://cloud.google.com/knative

Fair Use Source:

Categories
Bibliography

B088N615VS

See: kubectl reference: Kubernetes command-line interface version 1.18.0 Paperback – May 15, 2020

See also Kubernetes and Cloud Native

Fair Use Source: