mirror of
https://github.com/seaweedfs/seaweedfs.git
synced 2024-01-19 02:48:24 +00:00
Merge branch 'master' of https://github.com/seaweedfs/seaweedfs
This commit is contained in:
commit
b40ba7c7fe
|
@ -33,6 +33,13 @@ spec:
|
||||||
helm.sh/chart: {{ .Chart.Name }}-{{ .Chart.Version | replace "+" "_" }}
|
helm.sh/chart: {{ .Chart.Name }}-{{ .Chart.Version | replace "+" "_" }}
|
||||||
app.kubernetes.io/instance: {{ .Release.Name }}
|
app.kubernetes.io/instance: {{ .Release.Name }}
|
||||||
app.kubernetes.io/component: filer
|
app.kubernetes.io/component: filer
|
||||||
|
{{ with .Values.podLabels }}
|
||||||
|
{{- toYaml . | nindent 8 }}
|
||||||
|
{{- end }}
|
||||||
|
annotations:
|
||||||
|
{{ with .Values.podAnnotations }}
|
||||||
|
{{- toYaml . | nindent 8 }}
|
||||||
|
{{- end }}
|
||||||
spec:
|
spec:
|
||||||
restartPolicy: {{ default .Values.global.restartPolicy .Values.filer.restartPolicy }}
|
restartPolicy: {{ default .Values.global.restartPolicy .Values.filer.restartPolicy }}
|
||||||
{{- if .Values.filer.affinity }}
|
{{- if .Values.filer.affinity }}
|
||||||
|
|
|
@ -32,6 +32,13 @@ spec:
|
||||||
helm.sh/chart: {{ .Chart.Name }}-{{ .Chart.Version | replace "+" "_" }}
|
helm.sh/chart: {{ .Chart.Name }}-{{ .Chart.Version | replace "+" "_" }}
|
||||||
app.kubernetes.io/instance: {{ .Release.Name }}
|
app.kubernetes.io/instance: {{ .Release.Name }}
|
||||||
app.kubernetes.io/component: master
|
app.kubernetes.io/component: master
|
||||||
|
{{ with .Values.podLabels }}
|
||||||
|
{{- toYaml . | nindent 8 }}
|
||||||
|
{{- end }}
|
||||||
|
annotations:
|
||||||
|
{{ with .Values.podAnnotations }}
|
||||||
|
{{- toYaml . | nindent 8 }}
|
||||||
|
{{- end }}
|
||||||
spec:
|
spec:
|
||||||
restartPolicy: {{ default .Values.global.restartPolicy .Values.master.restartPolicy }}
|
restartPolicy: {{ default .Values.global.restartPolicy .Values.master.restartPolicy }}
|
||||||
{{- if .Values.master.affinity }}
|
{{- if .Values.master.affinity }}
|
||||||
|
|
|
@ -24,6 +24,13 @@ spec:
|
||||||
helm.sh/chart: {{ .Chart.Name }}-{{ .Chart.Version | replace "+" "_" }}
|
helm.sh/chart: {{ .Chart.Name }}-{{ .Chart.Version | replace "+" "_" }}
|
||||||
app.kubernetes.io/instance: {{ .Release.Name }}
|
app.kubernetes.io/instance: {{ .Release.Name }}
|
||||||
app.kubernetes.io/component: s3
|
app.kubernetes.io/component: s3
|
||||||
|
{{ with .Values.podLabels }}
|
||||||
|
{{- toYaml . | nindent 8 }}
|
||||||
|
{{- end }}
|
||||||
|
annotations:
|
||||||
|
{{ with .Values.podAnnotations }}
|
||||||
|
{{- toYaml . | nindent 8 }}
|
||||||
|
{{- end }}
|
||||||
spec:
|
spec:
|
||||||
restartPolicy: {{ default .Values.global.restartPolicy .Values.s3.restartPolicy }}
|
restartPolicy: {{ default .Values.global.restartPolicy .Values.s3.restartPolicy }}
|
||||||
{{- if .Values.s3.tolerations }}
|
{{- if .Values.s3.tolerations }}
|
||||||
|
|
|
@ -26,6 +26,13 @@ spec:
|
||||||
helm.sh/chart: {{ .Chart.Name }}-{{ .Chart.Version | replace "+" "_" }}
|
helm.sh/chart: {{ .Chart.Name }}-{{ .Chart.Version | replace "+" "_" }}
|
||||||
app.kubernetes.io/instance: {{ .Release.Name }}
|
app.kubernetes.io/instance: {{ .Release.Name }}
|
||||||
app.kubernetes.io/component: volume
|
app.kubernetes.io/component: volume
|
||||||
|
{{ with .Values.podLabels }}
|
||||||
|
{{- toYaml . | nindent 8 }}
|
||||||
|
{{- end }}
|
||||||
|
annotations:
|
||||||
|
{{ with .Values.podAnnotations }}
|
||||||
|
{{- toYaml . | nindent 8 }}
|
||||||
|
{{- end }}
|
||||||
spec:
|
spec:
|
||||||
{{- if .Values.volume.affinity }}
|
{{- if .Values.volume.affinity }}
|
||||||
affinity:
|
affinity:
|
||||||
|
|
|
@ -654,3 +654,8 @@ certificates:
|
||||||
# you will need to store your provided certificates in the secret read by the different services:
|
# you will need to store your provided certificates in the secret read by the different services:
|
||||||
# seaweedfs-master-cert, seaweedfs-filer-cert, etc. Can see any statefulset definition to see secret names
|
# seaweedfs-master-cert, seaweedfs-filer-cert, etc. Can see any statefulset definition to see secret names
|
||||||
enabled: false
|
enabled: false
|
||||||
|
|
||||||
|
# Labels to be added to all the created pods
|
||||||
|
podLabels: {}
|
||||||
|
# Annotations to be added to all the created pods
|
||||||
|
podAnnotations: {}
|
||||||
|
|
|
@ -169,7 +169,7 @@ func runFiler(cmd *Command, args []string) bool {
|
||||||
|
|
||||||
go stats_collect.StartMetricsServer(*f.bindIp, *f.metricsHttpPort)
|
go stats_collect.StartMetricsServer(*f.bindIp, *f.metricsHttpPort)
|
||||||
|
|
||||||
filerAddress := util.JoinHostPort(*f.ip, *f.port)
|
filerAddress := pb.NewServerAddress(*f.ip, *f.port, *f.portGrpc).String()
|
||||||
startDelay := time.Duration(2)
|
startDelay := time.Duration(2)
|
||||||
if *filerStartS3 {
|
if *filerStartS3 {
|
||||||
filerS3Options.filer = &filerAddress
|
filerS3Options.filer = &filerAddress
|
||||||
|
|
|
@ -63,6 +63,10 @@ func NewWebDavServer(option *WebDavOption) (ws *WebDavServer, err error) {
|
||||||
if option.FilerRootPath == "/" {
|
if option.FilerRootPath == "/" {
|
||||||
option.FilerRootPath = ""
|
option.FilerRootPath = ""
|
||||||
}
|
}
|
||||||
|
// filer.path non "/" option means we are accessing filer's sub-folders
|
||||||
|
if option.FilerRootPath != "" {
|
||||||
|
fs = NewWrappedFs(fs, path.Clean(option.FilerRootPath))
|
||||||
|
}
|
||||||
|
|
||||||
ws = &WebDavServer{
|
ws = &WebDavServer{
|
||||||
option: option,
|
option: option,
|
||||||
|
@ -204,8 +208,6 @@ func (fs *WebDavFileSystem) Mkdir(ctx context.Context, fullDirPath string, perm
|
||||||
}
|
}
|
||||||
|
|
||||||
func (fs *WebDavFileSystem) OpenFile(ctx context.Context, fullFilePath string, flag int, perm os.FileMode) (webdav.File, error) {
|
func (fs *WebDavFileSystem) OpenFile(ctx context.Context, fullFilePath string, flag int, perm os.FileMode) (webdav.File, error) {
|
||||||
// Add filer.path
|
|
||||||
fullFilePath = fs.option.FilerRootPath + fullFilePath
|
|
||||||
glog.V(2).Infof("WebDavFileSystem.OpenFile %v %x", fullFilePath, flag)
|
glog.V(2).Infof("WebDavFileSystem.OpenFile %v %x", fullFilePath, flag)
|
||||||
|
|
||||||
var err error
|
var err error
|
||||||
|
@ -377,8 +379,6 @@ func (fs *WebDavFileSystem) stat(ctx context.Context, fullFilePath string) (os.F
|
||||||
}
|
}
|
||||||
|
|
||||||
func (fs *WebDavFileSystem) Stat(ctx context.Context, name string) (os.FileInfo, error) {
|
func (fs *WebDavFileSystem) Stat(ctx context.Context, name string) (os.FileInfo, error) {
|
||||||
// Add filer.path
|
|
||||||
name = fs.option.FilerRootPath + name
|
|
||||||
glog.V(2).Infof("WebDavFileSystem.Stat %v", name)
|
glog.V(2).Infof("WebDavFileSystem.Stat %v", name)
|
||||||
|
|
||||||
return fs.stat(ctx, name)
|
return fs.stat(ctx, name)
|
||||||
|
|
97
weed/server/wrapped_webdav_fs.go
Normal file
97
weed/server/wrapped_webdav_fs.go
Normal file
|
@ -0,0 +1,97 @@
|
||||||
|
package weed_server
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"golang.org/x/net/webdav"
|
||||||
|
"io/fs"
|
||||||
|
"os"
|
||||||
|
"strings"
|
||||||
|
)
|
||||||
|
|
||||||
|
type wrappedFs struct {
|
||||||
|
subFolder string
|
||||||
|
webdav.FileSystem
|
||||||
|
}
|
||||||
|
|
||||||
|
// NewWrappedFs returns a webdav.FileSystem identical to fs, except it
|
||||||
|
// provides access to a sub-folder of fs that is denominated by subFolder.
|
||||||
|
// It transparently handles renaming paths and filenames so that the outer part of the wrapped filesystem
|
||||||
|
// does not leak out.
|
||||||
|
func NewWrappedFs(fs webdav.FileSystem, subFolder string) webdav.FileSystem {
|
||||||
|
return wrappedFs{
|
||||||
|
subFolder: subFolder,
|
||||||
|
FileSystem: fs,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (w wrappedFs) Mkdir(ctx context.Context, name string, perm os.FileMode) error {
|
||||||
|
name = w.subFolder + name
|
||||||
|
return w.FileSystem.Mkdir(ctx, name, perm)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (w wrappedFs) OpenFile(ctx context.Context, name string, flag int, perm os.FileMode) (webdav.File, error) {
|
||||||
|
name = w.subFolder + name
|
||||||
|
file, err := w.FileSystem.OpenFile(ctx, name, flag, perm)
|
||||||
|
file = wrappedFile{
|
||||||
|
File: file,
|
||||||
|
subFolder: &w.subFolder,
|
||||||
|
}
|
||||||
|
|
||||||
|
return file, err
|
||||||
|
}
|
||||||
|
|
||||||
|
func (w wrappedFs) RemoveAll(ctx context.Context, name string) error {
|
||||||
|
name = w.subFolder + name
|
||||||
|
return w.FileSystem.RemoveAll(ctx, name)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (w wrappedFs) Rename(ctx context.Context, oldName, newName string) error {
|
||||||
|
oldName = w.subFolder + oldName
|
||||||
|
newName = w.subFolder + newName
|
||||||
|
return w.FileSystem.Rename(ctx, oldName, newName)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (w wrappedFs) Stat(ctx context.Context, name string) (os.FileInfo, error) {
|
||||||
|
name = w.subFolder + name
|
||||||
|
info, err := w.FileSystem.Stat(ctx, name)
|
||||||
|
info = wrappedFileInfo{
|
||||||
|
subFolder: &w.subFolder,
|
||||||
|
FileInfo: info,
|
||||||
|
}
|
||||||
|
return info, err
|
||||||
|
}
|
||||||
|
|
||||||
|
type wrappedFile struct {
|
||||||
|
webdav.File
|
||||||
|
subFolder *string
|
||||||
|
}
|
||||||
|
|
||||||
|
func (w wrappedFile) Readdir(count int) ([]fs.FileInfo, error) {
|
||||||
|
infos, err := w.File.Readdir(count)
|
||||||
|
for i, info := range infos {
|
||||||
|
infos[i] = wrappedFileInfo{
|
||||||
|
subFolder: w.subFolder,
|
||||||
|
FileInfo: info,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return infos, err
|
||||||
|
}
|
||||||
|
|
||||||
|
func (w wrappedFile) Stat() (fs.FileInfo, error) {
|
||||||
|
info, err := w.File.Stat()
|
||||||
|
info = wrappedFileInfo{
|
||||||
|
subFolder: w.subFolder,
|
||||||
|
FileInfo: info,
|
||||||
|
}
|
||||||
|
return info, err
|
||||||
|
}
|
||||||
|
|
||||||
|
type wrappedFileInfo struct {
|
||||||
|
subFolder *string
|
||||||
|
fs.FileInfo
|
||||||
|
}
|
||||||
|
|
||||||
|
func (w wrappedFileInfo) Name() string {
|
||||||
|
name := w.FileInfo.Name()
|
||||||
|
return strings.TrimPrefix(name, *w.subFolder)
|
||||||
|
}
|
Loading…
Reference in a new issue