cmg monitoring of hybrid cloudcmgcanada.altervista.org/presentations/2018 apr... · docker...

33
© 2018 IBM Corporation Monitoring Hybrid Cloud Workloads using Open source technologies. Presented by: Joe Calcada. For Spring CMG. April 24 2018.

Upload: others

Post on 20-May-2020

5 views

Category:

Documents


0 download

TRANSCRIPT

Page 1: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

© 2018 IBM Corporation

Monitoring Hybrid Cloud Workloads using Open source technologies.

Presented by: Joe Calcada. For Spring CMG.April 24 2018.

Page 2: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

Introduction to Microservices, Docker, & KubernetesMonitoring Hybrid Cloud with Open Source ToolsDemo

Page 3: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

An engineering approach focused on decomposing an application into single-function modules with well defined interfaces which are independently deployed and operated by a small team who owns the entire lifecycle of the service.

Microservices accelerate delivery by minimizing communication and coordination between people while reducing the scope and risk of change.

Microservices

Page 4: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

text

Microservice Architecture

Developer Benefits- Small team development- Repeatable- Consistent- Faster response and

deployments- Independent lifecycle

Monolithic app Microservices

Scaling Scaling

Page 5: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

text

Microservice Architecture

Page 6: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

What’s A Container?Not a middleware container – no interceptors, no transactional or security support …

Nothing to do with EJB or Web containers

A standard way to package an application and all its dependencies so that it can be moved between environments and run without any changes.

Containers work by isolating the differences between applications inside the container so that everything outside the container can be standardized.

Implemented typically as a light weight mechanism to build and deploy user code and data along with the required components with bare minimal Linux kernel

6

Page 7: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

Development Test QA Production Scale Out

Anyapplicationstack

Anyhardwareenvironment

Development VM

QA server Public Cloud Contributor’s laptop

Production ClusterCustomer Data

Center

Static website Web frontend User DB Queue Analytics DB

Containers Accelerate Software Delivery

Container

Page 8: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

Common Container Use Cases # Scenario 1 DevOps

Want to drive cultural and technology change aligned to a DevOps methodology2 Continuous Integration / Continuous Deployment

Want to increase rates of innovation by shipping more software faster and improving developer & operations productivity;

3 Software Upgrades / Platform RefreshWant to revisit architecture as part of v2v upgrades or platform refresh; re-architect for portability

4 App Modernization / MicroservicesWant to transition from monolithic application code bases to microservices and distributed processing architectures; new features delivered as microservices; exploit serverless computing

5 Path to the CloudWant to migrate workloads to cloud, re-architect for portability

6 Big Data ProcessingWant to provide self-service big data access and analytic processing environments to different lines of business

7 Infrastructure OptimizationWant to maximize infrastructure efficiency and reduce operating costs by increasing server density, reducing licensing costs and maintaining application portability

Page 9: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

Docker – MissionDocker is an open platform for building distributed applications for developers and system administrators.

Build Ship Run

Anywhere

Any App

Page 10: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

Docker Containers Provide Extreme Portability

Standardizationà ApplicationportabilityPackage,ship,andrunapplicationsanywhere

TheDockerHubRegistryhas400,000+"Dockerized"applications

A platform to build, ship, and run applications in “containers”. Developers & SysAdmins love the flexibility and standardization of Docker

LightweightContainers are “light” users of system resources, smaller than VMs, start up much faster, and have better performance

Ecosystem-friendlyA new industry standard, with a vibrant ecosystem of partners.

1300+ community contributors; 100,000 third-party Docker projects on GitHub

User-friendlyDevelopersbuildwitheaseandshiphigher-qualityapplicationsSysAdmins deployworkloadsbasedonbusinessprioritiesandpolicies.

"Containers managed by Docker are effective in resource isolation. They are almost on par with the Linux OS and hypervisors in secure operations management and configuration governance." Joerg Fritsch, Gartner Analyst, Security Properties of Containers Managed by Docker, January 7, 2015

Page 11: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

Docker uses a copy-on-write (union) file system

New files(and edits) are only visible to current/above layers

Layers allow for reuse

• More containers per host

• Faster start-up/download time – base layers are "cached"

Images

• Tarball of layers (each layer is a tarball)

File System

Base OS / Kernel

Fedora Ubuntu

WXS tWASLiberty

CNTR1 CNTR2 CNTR3 CNTR4

app1 app2 app4app3Layer

Layer

Layer

Host

Docker Basics – A Technical Overview

Page 12: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

Speed of Deployment

Obtain within…

Manual deployment takes…

Automated deployment takes…

Starts in…

Bare Metal Days Hours Minutes Minutes

VM Minutes Minutes Seconds < Minute

Container Seconds Minutes Seconds Seconds

Page 13: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

Near Bare-Metal Performance

http://domino.research.ibm.com/library/cyberdig.nsf/papers/0929052195DD819C85257D2300681E7B/$File/rc25482.pdf

Page 14: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

• Ease the management and monitoring of large numbers of disparate containers, distributed across multiple hosts

• Container scheduling• Placement of containers on the most appropriate host based on constraints• Rescheduling if a container or a host fails• Ability to rollout/rollback updates whilst maintaining availability

• Deployment of multiple containers that form an application from version controlled configuration

• Policies for placement, security, performance, HA

• Routing of inbound and inter-container requests (service discovery and routing)

• Enterprise integration with existing tools e.g. CI/CD and SSO/RBAC

Container Orchestration

Page 15: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

KubernetesKubernetes is a portable, extensible open-source platform for managing containerized workloads and services, that facilitates both declarative configuration and automation.

Kubernetes has a number of features. It can be thought of as:• a container platform• a microservices platform• a portable cloud platform and a lot more.

Kubernetes provides a container-centric management environment. It orchestrates computing, networking, and storage infrastructure on behalf of user workloads. This provides much of the simplicity of Platform as a Service (PaaS) with the flexibility of Infrastructure as a Service (IaaS), and enables portability across infrastructure providers.

Kubernetes is comprised of a set of independent, composable control processes that continuously drive the current state towards the provided desired state.

Source: https://kubernetes.io/docs/concepts/overview/what-is-kubernetes/

Page 16: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

Slide Title Goes HereKubernetes Architecture

API

UI

CLI

Kubernetes Master

Worker Node 1Worker Node 2Worker Node 3Worker Node n Image

Registry• etcd• API Server• Controller Manager

Server• Scheduler Server

Page 17: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

Monitoring hybrid cloud Environments

17

• Traditional Environment means the on-premise environment of physical or virtualized servers that has been common for years with both automated and non-automated provisioning.

• Application platform for developing and managing on-premises, containerized applications (PaaS/CaaS) (IE. IBM Cloud Private).

• One-stop cloud computing solution which provides multiple types of solutions (IaaS/SaaS/PaaS/CaaS/FaaS). (IE. IBM Cloud)

• 3rd Party Cloud may be either on-premises or cloud-based, depending on the provider.

Page 18: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

Monitoring the various types of Cloud Workloads

18

Monitoring the Environments

Page 19: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

The Full Monitoring Table

19

Monitoring the Environments

Page 20: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

Incident Management Tool Chain

Monitor Analyze Plan Execute

Logging

Monitoring

EventManagement

Runbooks

Notification

Dashboards & Reporting

Collaboration

20

Ticketing & Trending

IBM Cloud Monitoring

Elastic Stack

NOI Slack

DASH

ANS

Console

RBA

Grafana

IBM 3rd Party

CAM

Log Analysis ICD

APM

Prometheus

CEM

Page 21: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

21

Levels of CSMO in Private Clouds (ICP for example)

• Level0– Outofthebox:• Built-inDashboardformetrics• Built-inLogconsole

• Level1– Defaultmonitoringworkloads• DeployPrometheusformetrics• DeployElasticsearch (ELK)forLogging

• Level2– ExternalMonitoringandLogging• ExternalAPMmonitorsmetricsandthresholds

• SyntheticTransactions• Elasticsearch stacksforwardstoexternalElasticsearch stack

• Consumedexternally• Level3– IntegrationwithCSMOtoolchain

• Forwardeventstoa“ManagerofManagers”(ie.Omnibus)• ForwardLogeventsto“ManagerofManagers”(ie.Omnibus)• canopenincidentsandintegratewithcontroldesktoolsandrunbooktools

Page 22: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

22

Monitoring an IBM Cloud Private Deployment (level 0)

WithinIBMCloudPrivatethereareseveralwaystoviewhighlevelKeyPerformanceIndicators1. TheICPdashboardshowsahighleveloverviewof

resourceusageandstatus.2. TheKubernetesDashboardshowsCPUandmemory

consumptionofthefullclusteranddeployments3. Withinanapplicationyoucanviewperformanceof

thepod.

Allwellandgoodbutyoucanonlylookand“nottouch”.ThereareAPIsavailable.

WeneedtobeablemonitorandalertonOutofBoundsconditionsfortheapplicationsandtheirinfrastructure.

Page 23: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

23

What is the base level of Monitoring/Logging? (Level 1)

MonitoringandlogginginICP1. TheICPdashboardshowsthestatus,

metricsandlogentriesforalltheworkloads&Infrastructure.

2. AnElasticsearch stackcollectslogsfromalltheworkloads&Infrastructure.MultipleElasticsearchstacksarepossible(buteachlogcanonlyresideinonestack)

3. APrometheusstackcollectslogsfromtheKubernetesworkload

4. CustomizableGrafanaandKibanadashboardsareavailableforuse

5. Prometheuscansendalertstoexternalsystem(email,webhooks)

HostingInfrastructure(Virtualservers)

KubernetesCloud

Foundry

Prometheus

ELKStack

Heapster

ExtendableDashboardsandAlerts(Grafana/Kibana)

DefaultDashboards

Alerts

1

23

45

Page 24: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

24

Prometheus

PrometheusisaCloudNativeComputingFoundation(CNCF)project,isasystemsandservicemonitoringsystem.Itcollectsmetricsfromconfiguredtargetsatgivenintervals,evaluatesruleexpressions,displaystheresults,andcantriggeralertsifsomeconditionisobservedtobetrue.https://prometheus.io/

PrometheushasseveralcomponentsforTimeSeriesDataCollection,anAlertManagerandthePrometheusServerwhichscrapesandstoresthedata.

PrometheusisinstalledviaaHelmChartintoICP.

Page 25: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

25

IBM APM v8 (level 1+2)

IBMAPMisacomprehensivesolutionthathelpsyoumanagetheperformanceandavailabilityofapplicationsthataredeployedonpremises(private),inapubliccloud,orasahybridcombination.Thissolutionprovidesyouwithvisibility,control,andautomationofyourapplications,ensuringoptimalperformanceandefficientuseofresources.

YoucanreduceandpreventoutagesandslowdownsaroundtheclockinahybridapplicationworldasCloudAPMassistsyouinmovingfromidentifyingperformanceissuestoisolatingwheretheproblemisoccurringanddiagnosingissuesbeforeyourbusinessisimpacted.

Page 26: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

26

Grafana

Grafanaisanopensourcemetricanalytics&visualizationsuite.Itismostcommonlyusedforvisualizingtimeseriesdataforinfrastructureandapplicationanalyticsbutmanyuseitinotherdomainsincludingindustrialsensors,homeautomation,weather,andprocesscontrol.https://grafana.com/grafana

WhilePrometheushaslimiteddashboardingcapabilitiesofitsown,regulardisplayofmetricswillbedoneusingGrafanadashboards.

PrometheusandtheGrafanaDashboardsareinstalledtogetherasapplicationsintoICPusingHelmcharts.

Page 27: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

27

ELK stack or Elasticsearch Stack

TheElasticsearchstack(previouslyknownastheELKStack)isaLogManagementsystemwhichiscomposedof3layers:• Kibanaistheextensibleuserinterfaceforconfiguringandmanagingallaspects

oftheElasticStack.• Elasticsearchisadistributed,JSON-basedsearchandanalyticsenginedesigned

forhorizontalscalability,maximumreliability,andeasymanagement.• Logstash isadynamicdatacollectionpipelinewithanextensibleplugin

ecosystem andstrongElasticsearchsynergy.• Beatsisaplatformforlightweightshippersthatsend datafromedgemachines

toLogstash andElasticsearch.

Elasticseach ispackagedasaseriesofHelmchartsandaredeployedautomaticallywhenICPisinstalled(canbecustomizedand/oropted-outof)

Page 28: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

28

What are the advanced Logging capabilities for ICP? (Level 3)

HostingInfrastructure(Virtualservers)

KubernetesCloud

Foundry

ELK/LogstashStack

Heapster

IstioExternal

Elasticsearch

Splunk

LogAnalysis

Youcanforwardlogstoanexternalrepositorysothatyoucanconsumelogsinyourownexistinglogmanagementsystem.

Logscannotbeforwardedtomultiplerepositories.

Page 29: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

29

What are the advanced CSMO toolchain capabilities for ICP? (Level 3)

HostingInfrastructure(Virtualservers)

KubernetesCloud

Foundry

Prometheus Heapster

APM

ELKStack

ManagerofManagersProbes/Observers

ManagerofManagersEvents

ManagerofManagersprobesandobserverscollecteventsfrommultipledatasourcesincludingKubernetes,Prometheus&DevOpsmonitoring

APMmonitorsPrivateCloud(bothworkloadsandInfrastructure)andforwardseventstoManagerofManagers

MoM EventManagementlayerperformsde-duplication,correlation,grouping,etc…

Page 30: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

30

The answer is not always in metric collection (Level 3)

Buildtomanage• Generate“health”eventsfromwithinyourapplication• TestableAPIs

SyntheticTransactions (I.e.Seleniumtooling)• Userexperience• Coverageforcomponentsoutsideofyourapplication

Page 31: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

31

CustomDashboardswithGrafanaPre-builtdashboardsareavailableherehttps://grafana.com/dashboards andcanbeimportedtoyourGrafana application– thepre-builtdashboardsmayrequiresome“adjusting:foryourenvironment.

Page 32: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,

32 32

Page 33: CMG Monitoring of Hybrid Cloudcmgcanada.altervista.org/presentations/2018 Apr... · Docker Containers Provide Extreme Portability Standardization àApplication portability Package,