/
datapath.go
109 lines (93 loc) · 4.51 KB
/
datapath.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
/*
Copyright 2019 The Rook Authors. All rights reserved.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
// Package config provides a shared way of referring to data storage locations for Ceph Daemons,
// including both the in-container location and on-host location as well as whether the data is
// persisted to the host.
package config
import (
"path"
)
// A DataPathMap is a struct which contains information about where Ceph daemon data is stored in
// containers and whether the data should be persisted to the host. If it is persisted to the host,
// directory on the host where the specific daemon's data is stored is given.
type DataPathMap struct {
// HostDataDir should be set to the path on the host where the specific daemon's data is stored.
// If this is empty, the daemon does not persist data to the host, but data may still be shared
// between containers in a pod via an empty dir.
HostDataDir string
// ContainerDataDir should be set to the path in the container where the specific daemon's data
// is stored. If this is empty, the daemon does not store data at all, even in the container,
// and data is not shared between container in a pod via empty dir.
ContainerDataDir string
// HostLogAndCrashDir dir represents Ceph's logging and crash dump dir on the host.
// Logs are stored in the "log" subdir and crash dumps in the "crash" subdir of this directory.
// If this is empty logs are not persisted to the host.
// The log dir is always /var/log/ceph. If logs are not persisted to the
// host, logs are not shared between containers via empty dir or any other mechanism.
HostLogAndCrashDir string
}
// NewStatefulDaemonDataPathMap returns a new DataPathMap for a daemon which requires a persistent
// config (mons, osds). daemonDataDirHostRelativePath is the path relative to the dataDirHostPath
// where the daemon's data is stored on the host's filesystem. Daemons which use a DataPathMap
// created by this method will only have access to their own data and not the entire dataDirHostPath
// which may include data from other daemons.
func NewStatefulDaemonDataPathMap(
dataDirHostPath, daemonDataDirHostRelativePath string,
daemonType DaemonType, daemonID, namespace string,
) *DataPathMap {
return &DataPathMap{
HostDataDir: path.Join(dataDirHostPath, daemonDataDirHostRelativePath),
ContainerDataDir: cephDataDir(daemonType, daemonID),
HostLogAndCrashDir: path.Join(dataDirHostPath, namespace),
}
}
// NewStatelessDaemonDataPathMap returns a new DataPathMap for a daemon which does not persist data
// to the host (mgrs, mdses, rgws)
func NewStatelessDaemonDataPathMap(
daemonType DaemonType, daemonID, namespace, dataDirHostPath string,
) *DataPathMap {
return &DataPathMap{
HostDataDir: "",
ContainerDataDir: cephDataDir(daemonType, daemonID),
HostLogAndCrashDir: path.Join(dataDirHostPath, namespace),
}
}
// NewDatalessDaemonDataPathMap returns a new DataPathMap for a daemon which does not utilize a data
// dir in the container as the mon, mgr, osd, mds, and rgw daemons do.
func NewDatalessDaemonDataPathMap(namespace, dataDirHostPath string) *DataPathMap {
return &DataPathMap{
HostDataDir: dataDirHostPath,
ContainerDataDir: "",
HostLogAndCrashDir: path.Join(dataDirHostPath, namespace),
}
}
func cephDataDir(daemonType DaemonType, daemonID string) string {
// daemons' default data dirs are: /var/lib/ceph/<daemon-type>/ceph-<daemon-id>
return path.Join(VarLibCephDir, string(daemonType), "ceph-"+daemonID)
}
// ContainerCrashDir returns the directory of the crash collector
func (d *DataPathMap) ContainerCrashDir() string {
return VarLibCephCrashDir
}
// ContainerLogDir returns the directory of the Ceph logs
func (d *DataPathMap) ContainerLogDir() string {
return VarLogCephDir
}
// HostLogDir returns the directory path on the host for Ceph logs
func (d *DataPathMap) HostLogDir() string {
return path.Join(d.HostLogAndCrashDir, "log")
}
// HostCrashDir returns the directory path on the host for Ceph crashes
func (d *DataPathMap) HostCrashDir() string {
return path.Join(d.HostLogAndCrashDir, "crash")
}