mirror of
https://github.com/etcd-io/etcd.git
synced 2024-09-27 06:25:44 +00:00
Merge pull request #4090 from xiang90/writable
etcdserver: always check if the data dir is writable before starting
This commit is contained in:
commit
d62edfb464
@ -204,6 +204,10 @@ func NewServer(cfg *ServerConfig) (*EtcdServer, error) {
|
|||||||
cl *cluster
|
cl *cluster
|
||||||
)
|
)
|
||||||
|
|
||||||
|
if terr := fileutil.TouchDirAll(cfg.DataDir); terr != nil {
|
||||||
|
return nil, fmt.Errorf("cannot access data directory: %v", terr)
|
||||||
|
}
|
||||||
|
|
||||||
if !cfg.V3demo && fileutil.Exist(path.Join(cfg.SnapDir(), databaseFilename)) {
|
if !cfg.V3demo && fileutil.Exist(path.Join(cfg.SnapDir(), databaseFilename)) {
|
||||||
return nil, errors.New("experimental-v3demo cannot be disabled once it is enabled")
|
return nil, errors.New("experimental-v3demo cannot be disabled once it is enabled")
|
||||||
}
|
}
|
||||||
@ -284,10 +288,6 @@ func NewServer(cfg *ServerConfig) (*EtcdServer, error) {
|
|||||||
cfg.PrintWithInitial()
|
cfg.PrintWithInitial()
|
||||||
id, n, s, w = startNode(cfg, cl, cl.MemberIDs())
|
id, n, s, w = startNode(cfg, cl, cl.MemberIDs())
|
||||||
case haveWAL:
|
case haveWAL:
|
||||||
if err := fileutil.IsDirWriteable(cfg.DataDir); err != nil {
|
|
||||||
return nil, fmt.Errorf("cannot write to data directory: %v", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
if err := fileutil.IsDirWriteable(cfg.MemberDir()); err != nil {
|
if err := fileutil.IsDirWriteable(cfg.MemberDir()); err != nil {
|
||||||
return nil, fmt.Errorf("cannot write to member directory: %v", err)
|
return nil, fmt.Errorf("cannot write to member directory: %v", err)
|
||||||
}
|
}
|
||||||
@ -323,9 +323,8 @@ func NewServer(cfg *ServerConfig) (*EtcdServer, error) {
|
|||||||
return nil, fmt.Errorf("unsupported bootstrap config")
|
return nil, fmt.Errorf("unsupported bootstrap config")
|
||||||
}
|
}
|
||||||
|
|
||||||
err = os.MkdirAll(cfg.MemberDir(), privateDirMode)
|
if terr := fileutil.TouchDirAll(cfg.MemberDir()); terr != nil {
|
||||||
if err != nil && err != os.ErrExist {
|
return nil, fmt.Errorf("cannot access member directory: %v", terr)
|
||||||
return nil, err
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sstats := &stats.ServerStats{
|
sstats := &stats.ServerStats{
|
||||||
|
@ -26,6 +26,8 @@ import (
|
|||||||
|
|
||||||
const (
|
const (
|
||||||
privateFileMode = 0600
|
privateFileMode = 0600
|
||||||
|
// owner can make/remove files inside the directory
|
||||||
|
privateDirMode = 0700
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
@ -57,6 +59,16 @@ func ReadDir(dirpath string) ([]string, error) {
|
|||||||
return names, nil
|
return names, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TouchDirAll is simliar to os.MkdirAll. It creates directories with 0700 permission if any directory
|
||||||
|
// does not exists. TouchDirAll also ensures the given directory is writable.
|
||||||
|
func TouchDirAll(dir string) error {
|
||||||
|
err := os.MkdirAll(dir, privateDirMode)
|
||||||
|
if err != nil && err != os.ErrExist {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
return IsDirWriteable(dir)
|
||||||
|
}
|
||||||
|
|
||||||
func Exist(name string) bool {
|
func Exist(name string) bool {
|
||||||
_, err := os.Stat(name)
|
_, err := os.Stat(name)
|
||||||
return err == nil
|
return err == nil
|
||||||
|
Loading…
x
Reference in New Issue
Block a user