Skip to content

Latest commit

 

History

History
159 lines (111 loc) · 6.87 KB

README.md

File metadata and controls

159 lines (111 loc) · 6.87 KB

HPE 3PAR and HPE Primera Volume Plugin for Docker

HPE Docker Volume Plugin is an open source project that provides persistent storage and features for your containerized applications using HPE 3PAR and HPE Primera Storage arrays. It supports both block and file (NFS shares) based features.

This Volume Plugin for Docker supports popular container platforms like Docker, Kubernetes, OpenShift

HPE Docker Volume Plugin Overview

Standalone Docker instance

Here is an example of the HPE Docker Volume plugin being used in a standalone Docker instance:

HPE Docker Volume Plugin


Kubernetes/OpenShift environment

Here is an example of the HPE Docker Volume plugin being used in an OpenShift environment:

HPE Docker Volume Plugin with OpenShift

Install and Quick Start instructions

Supported Features

  • Fibre Channel & iSCSI support for 3PAR
  • Fibre Channel support for Primera
  • Secure/Unsecure etcd cluster for fault tolerance
  • Advanced volume features
    • thin
    • dedup
    • full
    • compression
    • snapshots
    • clones
    • QoS
    • snapshot mount
    • mount_conflict_delay
    • concurrent volume access
    • replication
    • snapshot schedule
    • file system permissions and ownership
    • multiple backends
    • file share [CRD operations] only for 3PAR

Block operations usage

See the block operations usage guide for details on the supported operations and usage of the plugin.

File share operations usage

See the file share operations usage guide for details on the supported operations and usage of the plugin.

Troubleshooting

Troubleshooting issues with the plugin can be performed using these tips

SPOCK Link for HPE 3PAR and HPE Primera Volume Plugin for Docker

Limitations

  • List of issues around the containerized version of the plugin/Managed plugin is present in https://github.com/hpe-storage/python-hpedockerplugin/issues

  • $ docker volume prune is not supported for volume plugin, instead use $docker volume rm $(docker volume ls -q -f "dangling=true") to clean up orphaned volumes.

  • Shared volume support is present for containers running on the same host.

  • For upgrading the plugin from older version to the current released version, user needs to unmount all the volumes and follow the standard upgrade procedure described in docker guide.

  • Encryption of the 3PAR and Primera user password is supported on Volume Plug-in versions 3.1.1 & 3.3.1 and not supported on Volume Plug-in versions 3.2 & 3.3.

  • Volumes created using older plugins (2.0.2 or below) do not have snap_cpg associated with them, hence when the plugin is upgraded to 2.1 and user wants to perform clone/snapshot operations on these old volumes, he/she must set the snap_cpg for the corresponding volumes using 3par cli or any tool before performing clone/snapshot operations.

  • While inspecting a snapshot, its provisioning field is set to that of parent volume's provisioning type. In 3PAR however, it is shown as 'snp'.

  • Mounting a QoS enabled volume can take longer than a volume without QoS for both FC and iSCSI protocol.

  • For a cloned volume with the same size as source volume, comment field won’t be populated on 3PAR.

  • User not allowed to import a 3PAR legacy volume when it is under use(Active VLUN).

  • User needs to explicitly manage all the child snapshots, until which managed parent volume cannot be deleted

  • User cannot manage already managed volume by other docker host(i.e. volume thats start with 'dcv-')

  • It is recommended for a user to avoid importing legacy volume which has schedules associated with it. If this volume needs to be imported please remove existing schedule on 3PAR and import the legacy volume.

  • "Snapshot schedule creation can take more time resulting into Docker CLI timeout. However, snapshot schedule may still get created in the background. User can follow below two steps in case of time out issue from docker daemon while creating snapshot schedule."

docker volume inspect <snapshot_name>. This should display snapshot details with snapshot schedule information.

Verify if schedule got created on the array using 3PAR CLI command:
$ showsched
  • If a mount fails due to dangling LUN use this section of troubleshooting guide Removing Dangling LUN

  • If two or more backends are defined with the same name then the last backend is picked up and rest ignored.

  • after doing scsi rescan if the symlinks for the device are not populated in /dev/disk/by-path, Plugin will not function correctly during mount operation.

  • For volume upper size limitation, please do refer 3PAR's documentation.

  • The configuration parameter mount_prefix, is applicable for containerized plugin only. If used with the managed plugin, mount operation fails.

  • For statefulset pod stuck in "ContainerCreating" state after a worker node reboot, the following manual procedure has to be done -- Details

  • For Pod mount using File Persona, this flag allowPrivilegeEscalation: true under securityContextis mandantory for volume plugin to mount a file persona NFS share. eg.

kind: Pod
apiVersion: v1
metadata:
  name: podfiletestw4-uid-gid-nosecurity
spec:
  containers:
  - name: nginx
    securityContext:
#       runAsUser: 10500
#       runAsGroup: 10800
      privileged: true
      capabilities:
        add: ["SYS_ADMIN"]
      allowPrivilegeEscalation: true
    image: nginx
    volumeMounts:
    - name: export
      mountPath: /export
  restartPolicy: Always
  volumes:
  - name: export
    persistentVolumeClaim:
      claimName: sc-file-pvc-uid-gid
  • if the doryd systemctl daemon does'nt start, then you have edit vi /etc/systemd/system/doryd.service
[Unit]
Description=manage doryd service for HPE 3PAR Volume plugin for Docker

[Service]
Type=simple
ExecStart=/usr/libexec/kubernetes/kubelet-plugins/volume/exec/hpe.com~hpe/doryd /etc/kubernetes/admin.conf hpe.com
Restart=on-abort

[Install]
WantedBy=multi-user.target

Updated /etc/kubernetes/admin.conf by /etc/origin/master/admin.kubeconfig and then do systemctl daemon-reload and systemctl restart doryd