aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorUstuzhanin Anton <toshaust@gmail.com>2021-02-18 00:35:36 +0500
committerUstuzhanin Anton <toshaust@gmail.com>2021-02-18 00:35:36 +0500
commit1e8ca97f81198da8f95300ae225524dbb39949ad (patch)
tree60929ef6903051f675c0ef4601f179b0a5a9276d
parent641cce456f2b128a12e4fd62ff81b811482df127 (diff)
parent767e95d2b6b5dc792cb33d9c33614e8825481296 (diff)
downloadseaweedfs-csi-driver-1e8ca97f81198da8f95300ae225524dbb39949ad.tar.xz
seaweedfs-csi-driver-1e8ca97f81198da8f95300ae225524dbb39949ad.zip
Merge remote-tracking branch 'origin/master' into helm
# Conflicts: # README.md
-rw-r--r--README.md5
-rw-r--r--deploy/helm/seaweedfs-csi-driver/templates/daemonset.yml2
-rw-r--r--deploy/helm/seaweedfs-csi-driver/templates/statefulset.yml2
-rw-r--r--deploy/helm/seaweedfs-csi-driver/values.yaml2
-rw-r--r--pkg/driver/mounter.go7
-rw-r--r--pkg/driver/mounter_seaweedfs.go18
-rw-r--r--pkg/driver/nodeserver.go6
7 files changed, 29 insertions, 13 deletions
diff --git a/README.md b/README.md
index 855522f..f48d255 100644
--- a/README.md
+++ b/README.md
@@ -45,7 +45,8 @@ $ kubectl delete -f deploy/kubernetes/sample-busybox-pod.yaml
$ kubectl delete -f deploy/kubernetes/sample-seaweedfs-pvc.yaml
$ kubectl delete -f deploy/kubernetes/seaweedfs-csi.yaml
```
-## Install by helm chart
+
+# Deployment by helm chart
1. Clone project
```bash
@@ -53,7 +54,7 @@ git clone https://github.com/seaweedfs/seaweedfs-csi-driver.git
```
2. Install
```bash
-helm install --set seaweedfsFiller=<url to filer host:port> seaweedfs-csi-driver ./seaweedfs-csi-driver/deploy/helm/seaweedfs-csi-driver
+helm install --set seaweedfsFiler=<filerHost:port> seaweedfs-csi-driver ./seaweedfs-csi-driver/deploy/helm/seaweedfs-csi-driver
```
3. Clean up
diff --git a/deploy/helm/seaweedfs-csi-driver/templates/daemonset.yml b/deploy/helm/seaweedfs-csi-driver/templates/daemonset.yml
index 386d669..513b137 100644
--- a/deploy/helm/seaweedfs-csi-driver/templates/daemonset.yml
+++ b/deploy/helm/seaweedfs-csi-driver/templates/daemonset.yml
@@ -60,7 +60,7 @@ spec:
- name: CSI_ENDPOINT
value: unix:///csi/csi.sock
- name: SEAWEEDFS_FILER
- value: {{ .Values.seaweedfsFiller | quote }}
+ value: {{ .Values.seaweedfsFiler | quote }}
- name: NODE_ID
valueFrom:
fieldRef:
diff --git a/deploy/helm/seaweedfs-csi-driver/templates/statefulset.yml b/deploy/helm/seaweedfs-csi-driver/templates/statefulset.yml
index afdef7d..665c36b 100644
--- a/deploy/helm/seaweedfs-csi-driver/templates/statefulset.yml
+++ b/deploy/helm/seaweedfs-csi-driver/templates/statefulset.yml
@@ -63,7 +63,7 @@ spec:
- name: CSI_ENDPOINT
value: unix:///var/lib/csi/sockets/pluginproxy/csi.sock
- name: SEAWEEDFS_FILER
- value: {{ .Values.seaweedfsFiller | quote }}
+ value: {{ .Values.seaweedfsFiler | quote }}
- name: NODE_ID
valueFrom:
fieldRef:
diff --git a/deploy/helm/seaweedfs-csi-driver/values.yaml b/deploy/helm/seaweedfs-csi-driver/values.yaml
index a5d5750..2e1a3bc 100644
--- a/deploy/helm/seaweedfs-csi-driver/values.yaml
+++ b/deploy/helm/seaweedfs-csi-driver/values.yaml
@@ -1,6 +1,6 @@
# host and port of your SeaweedFs filer
-seaweedfsFiller: ""
+seaweedfsFiler: ""
storageClassName: seaweedfs-storage
isDefaultStorageClass: false
tlsSecret: ""
diff --git a/pkg/driver/mounter.go b/pkg/driver/mounter.go
index 9aaa84a..5085b49 100644
--- a/pkg/driver/mounter.go
+++ b/pkg/driver/mounter.go
@@ -4,8 +4,9 @@ import (
"fmt"
"time"
- "github.com/chrislusf/seaweedfs/weed/glog"
"os/exec"
+
+ "github.com/chrislusf/seaweedfs/weed/glog"
"k8s.io/utils/mount"
)
@@ -19,8 +20,8 @@ type Mounter interface {
Mount(target string) error
}
-func newMounter(bucketName string, driver *SeaweedFsDriver) (Mounter, error) {
- return newSeaweedFsMounter(bucketName, driver)
+func newMounter(bucketName string, driver *SeaweedFsDriver, volContext map[string]string) (Mounter, error) {
+ return newSeaweedFsMounter(bucketName, driver, volContext)
}
func fuseMount(path string, command string, args []string) error {
diff --git a/pkg/driver/mounter_seaweedfs.go b/pkg/driver/mounter_seaweedfs.go
index d93e736..9d34b5d 100644
--- a/pkg/driver/mounter_seaweedfs.go
+++ b/pkg/driver/mounter_seaweedfs.go
@@ -10,21 +10,23 @@ import (
type seaweedFsMounter struct {
bucketName string
driver *SeaweedFsDriver
+ volContext map[string]string
}
const (
seaweedFsCmd = "weed"
)
-func newSeaweedFsMounter(bucketName string, driver *SeaweedFsDriver) (Mounter, error) {
+func newSeaweedFsMounter(bucketName string, driver *SeaweedFsDriver, volContext map[string]string) (Mounter, error) {
return &seaweedFsMounter{
bucketName: bucketName,
- driver: driver,
+ driver: driver,
+ volContext: volContext,
}, nil
}
func (seaweedFs *seaweedFsMounter) Mount(target string) error {
- glog.V(0).Infof("mounting %s%s to %s", seaweedFs.driver.filer, seaweedFs.bucketName, target)
+ glog.V(0).Infof("mounting %s %s to %s", seaweedFs.driver.filer, seaweedFs.bucketName, target)
args := []string{
"mount",
@@ -35,6 +37,16 @@ func (seaweedFs *seaweedFsMounter) Mount(target string) error {
fmt.Sprintf("-filer=%s", seaweedFs.driver.filer),
fmt.Sprintf("-filer.path=/buckets/%s", seaweedFs.bucketName),
}
+
+ for arg, value := range seaweedFs.volContext {
+ switch arg {
+ case "map.uid":
+ args = append(args, fmt.Sprintf("-map.uid=%s", value))
+ case "map.gid":
+ args = append(args, fmt.Sprintf("-map.gid=%s", value))
+ }
+ }
+
if seaweedFs.driver.ConcurrentWriters > 0 {
args = append(args, fmt.Sprintf("-concurrentWriters=%d", seaweedFs.driver.ConcurrentWriters))
}
diff --git a/pkg/driver/nodeserver.go b/pkg/driver/nodeserver.go
index 0509f79..71f40ba 100644
--- a/pkg/driver/nodeserver.go
+++ b/pkg/driver/nodeserver.go
@@ -55,7 +55,9 @@ func (ns *NodeServer) NodePublishVolume(ctx context.Context, req *csi.NodePublis
mo = append(mo, "ro")
}
- mounter, err := newMounter(volumeID, ns.Driver)
+ volContext := req.GetVolumeContext()
+
+ mounter, err := newMounter(volumeID, ns.Driver, volContext)
if err != nil {
return nil, err
}
@@ -163,4 +165,4 @@ func checkMount(targetPath string) (bool, error) {
}
}
return notMnt, nil
-} \ No newline at end of file
+}