45
Above the clouds with container-native storage Ryan Cook, Senior Software Engineer Davis Phillips, Principal Software Engineer Glenn West, Principal Software Engineer Annette Clewett, Senior Storage Architect May 10, 2018

container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

  • Upload
    others

  • View
    13

  • Download
    0

Embed Size (px)

Citation preview

Page 1: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

Above the clouds with container-native storageRyan Cook, Senior Software EngineerDavis Phillips, Principal Software Engineer Glenn West, Principal Software EngineerAnnette Clewett, Senior Storage Architect

May 10, 2018

Page 2: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

Introductions

● Davis Phillips - Principal Software Engineer● Glenn West - Principal Software Engineer● Annette Clewett - Storage Architect● Ryan Cook - Senior Software Engineer

Page 3: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

Container-native Storage

Page 4: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

Openshift Persistent Storage Framework

Page 5: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

Openshift Persistent Storage Framework

“A request for storage”

Provider: ABCCapacity: 10 GiBFeatures: XYZ

PersistentVolumeClaim“submits”

Page 6: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

Openshift Persistent Storage Framework

“A request for storage”

Provider: ABCCapacity: 10 GiBFeatures: XYZ

PersistentVolumeClaim

“A provider of storage”

Provider URL: …Credentials: …Options: ...

StorageClass

“sets up”

“submits” “submitted to”

Page 7: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

Openshift Persistent Storage Framework

“A request for storage”

Provider: ABCCapacity: 10 GiBFeatures: XYZ

PersistentVolumeClaim

“A provider of storage”

Provider URL: …Credentials: …Options: ...

StorageClass

“sets up”

“submits” “submitted to”

Storage Backend

“instructs”

Page 8: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

Openshift Persistent Storage Framework

“A request for storage”

Provider: ABCCapacity: 10 GiBFeatures: XYZ

PersistentVolumeClaim

“A provider of storage”

Provider URL: …Credentials: …Options: ...

StorageClass

“Provisioned Storage”

Name: …Size: …AccessMode: ...

PersistentVolume

“sets up”

“submits” “submitted to” “creates”

Storage Backend

“instructs” “provisions”

Page 9: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

Openshift Persistent Storage Framework

“A request for storage”

Provider: ABCCapacity: 10 GiBFeatures: XYZ

PersistentVolumeClaim

“A provider of storage”

Provider URL: …Credentials: …Options: ...

StorageClass

“Provisioned Storage”

Name: …Size: …AccessMode: ...

PersistentVolume

APPLICATION POD(S)

“sets up”

“submits” “submitted to” “creates”

Storage Backend

“instructs” “provisions”

“mounted by”

Page 10: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

GlusterFS - Distributed File StorageScale Out Performance, Capacity & Availability

Sca

le U

p C

apac

ity

RED HAT GLUSTER STORAGEFOR ON-PREMISE

SERVER(CPU/MEM)

SERVER(CPU/MEM)

SERVER(CPU/MEM)

Single, Global namespace

● Deploys on Red Hat-supported servers and underlying storage: DAS, JBOD

● Scale-out linearly● Replicate synchronously and

asynchronous

Page 11: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

Federating Local Storage

FILE 1 FILE 2

BRICK BRICK

CLIENT MOUNTserver1:/exp1 server2:/exp2

GLUSTERFS VOLUME

FILE 1 FILE 2

Page 12: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

Container-Native Storage on Openshift

POD

CONTAINERIZED RED HAT GLUSTER STORAGE

RHEL HOST OS

RED HATGLUSTER POD

GLUSTER VOLUMES

PHYSICAL DISKHOST NETWORK

Page 13: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

Container-Native Storage on Openshift

POD

RHGS POD

RHGS POD

RHGS POD

RHGS POD

INFRAPOD

INFRA

HEKETIRESTFUL GLUSTERFS

MANAGEMENT

RED HATHEKETI POD

REST API

GLUSTERFS PODS

Page 14: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

Container-Native Storage on Openshift

POD

RHGS POD

POD

RHGS POD

RHGS POD

INFRAPOD

INFRA

Page 15: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

Container-Native Storage on Openshift

POD

RHGS POD

POD

RHGS POD

RHGS POD

INFRAPOD

INFRAPERSISTENT

VOLUME CLAIM

1.)

Page 16: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

Container-Native Storage on Openshift

POD

RHGS POD

POD

RHGS POD

RHGS POD

INFRAPOD

INFRAPERSISTENT

VOLUME CLAIM2.)

1.)

Page 17: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

Container-Native Storage on Openshift

POD

RHGS POD

POD

RHGS POD

RHGS POD

INFRAPOD

INFRA

GLUSTER VOLUME

PERSISTENT VOLUME CLAIM

2.)

3.)

1.)

Page 18: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

Container-Native Storage on Openshift

POD

RHGS POD

POD

RHGS POD

RHGS POD

INFRAPOD

INFRA

GLUSTER VOLUME

PERSISTENT VOLUME CLAIM

PERSISTENT VOLUME

PERSISTENT VOLUME

4.)

2.)

3.)

4.)

1.)

Page 19: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

Container-Native Storage on Openshift

Page 20: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

Container-Native Storage on Openshift

AVAILABILITYZONE A

AVAILABILITYZONE B

AVAILABILITYZONE C

Node Node Node Node Node Node

Page 21: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

VMware vSphere Platform

Page 22: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

OpenShift Container Platform on VMware w/CNSStorage types in vSphere

● NFS● vSphere-volume● CNS

Page 23: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

vSphere Storage - NFSPros

Easy to use and setup

Cons

No ReadWriteMany or ReadOnlyMany support

Limits POD scaling for services that would benefit from it

Not supported for Registry, Metrics or Logging

Page 24: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

vSphere Storage - vSphere-Volume New in Kubernetes 1.6 using vSphere Cloud Provider

Pros

Makes provisioning storage a streamlined process

Supports multiple datastores in vSphere

Dynamic Provisioning using Storage Classes

Cons

No ReadWriteMany support

Tied to Node

Registry is not Supported

Page 25: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

vSphere Storage - CNS Gluster File StoragePros

ReadWriteMany and ReadOnlyMany Support

Replication

Highly available

Dynamic Provisioning using Storage Classes

Support for Registry, Logging and Metrics

Cons

May require additional licenses

Page 26: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

vSphere Plugin - Why CNS?Topic CNS/CRS vSphere PluginDynamic Provisioning ✔ ✔

RWO (Block), RWX (File), Object

✔ (All three in one) ✗

Hybrid Deployment VMware, Bare Metal, AWS, ...

✔(Dev, deploy, use anywhere)

Online Resize Support ✔ ✗

Volume Metrics/PV Consumption

✔ ✗

Custom Volume Naming ✔ (Use business Rules) ✗

Integration with OCP Install, Management, Monitoring ✗

High Availability ✔ 3 Failure Domains ✗

Mounts ✔~7-25 seconds Slow ~ 1 min – 2 min

Failover Transparent Slow ~ 3-5 minutes (App outage)

Page 27: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

Sample Architecture - CNS Registry only

Page 28: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

Sample Architecture - CNS App & Registry

Page 29: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

Azure

Page 30: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

OCP on Azure w/CNSStorage Options

Existing Storage Choices

● Azure Disk● CNS

kind: StorageClassapiVersion: storage.k8s.io/v1metadata: name: fastprovisioner: kubernetes.io/azure-diskparameters: skuName: Standard_LRS location: eastus storageAccount: azure_storage_account_name

kind: StorageClassapiVersion: storage.k8s.io/v1metadata: name: slowprovisioner: kubernetes.io/glusterfsparameters: resturl: "http://127.0.0.1:8081" restuser: "admin" secretName: "heketi-secret" secretNamespace: "default" gidMin: "40000" gidMax: "50000"

AZURE DISK Profile

CNS Profile

Page 31: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

Azure Disk Storage Pros

● Native to Azure ● Azure Underlying Redundancy Used● Direct cost to usage per PV● Direct use of Premium / SSD Drives

Cons

● ReadWriteOnce only supported model● Number of drives per host severely limited (Limits containers per host)● Very Slow PV Creation (Multiple Minutes)

NoteMake sure vmname and hostname the same

Page 32: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

CNS Gluster File Storage vs Azure DiskPros

Fast PV Create Time

ReadWriteMany and ReadOnlyMany Support

Highly available

Dynamic Provisioning using Storage Classes

Support for Registry, Logging and Metrics

Ability to do very small to very large PV

Cons

May require additional licenses

Page 33: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

Azure with CNS Storage

CNSNodes

CNS Registry

Page 34: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

Azure Why CNS?

Page 35: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

AWS

Page 36: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

OCP on AWS w/CNSStorage Types on AWS

● EFS● EBS● S3

Page 37: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

AWS Storage - EFSPros

● Not AZ specific● ReadWriteMany support● Automatically scaled storage

Cons

● No guaranteed performance● Not suitable for all application workloads● Cannot be used for logging and metrics● Requires a specific playbook to be ran

Page 38: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

AWS Storage - EBSPros

● Guaranteed performance

Cons

● AZ specific● ReadWriteMany support requires all pods must run on a single node

Page 39: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

AWS Storage - S3Pros

● Automatically scaled● Perfect for the image registry

Cons

● Object based storage cannot be used for persistent container storage

Page 40: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

AWS - CNS Gluster File StoragePros

● ReadWriteMany and ReadOnlyMany Support● Replication● Highly available regardless of AZ● All workloads supported (logging, metrics, prometheus)

Cons

● May require additional licenses● Requires large instances

Page 41: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

AWS with CNS Application Storage

CNS Nodes

Page 42: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

AWS- Why CNS?

Page 43: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

Q&A

Page 44: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

Links

● Ref archs○ https://goo.gl/BhvCHm

● https://access.redhat.com/products/red-hat-container-native-storage

Page 45: container-native storage - Microsoft...RED HAT GLUSTER STORAGE RHEL HOST OS RED HAT GLUSTER POD GLUSTER VOLUMES HOST NETWORK PHYSICAL DISK. ... VMware vSphere Platform. OpenShift Container

THANK YOUplus.google.com/+RedHat

linkedin.com/company/red-hat

youtube.com/user/RedHatVideos

facebook.com/redhatinc

twitter.com/RedHat