mirror of
https://github.com/zrepl/zrepl.git
synced 2025-01-20 13:18:47 +01:00
config for pull and source
This commit is contained in:
parent
e2bf557d17
commit
48a08e4f4d
@ -22,16 +22,38 @@ type JobEnum struct {
|
|||||||
|
|
||||||
type PushJob struct {
|
type PushJob struct {
|
||||||
Type string `yaml:"type"`
|
Type string `yaml:"type"`
|
||||||
|
Name string `yaml:"name"`
|
||||||
Replication PushReplication `yaml:"replication"`
|
Replication PushReplication `yaml:"replication"`
|
||||||
Snapshotting Snapshotting `yaml:"snapshotting"`
|
Snapshotting Snapshotting `yaml:"snapshotting"`
|
||||||
Pruning Pruning `yaml:"pruning"`
|
Pruning PruningSenderReceiver `yaml:"pruning"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type SinkJob struct {
|
type SinkJob struct {
|
||||||
Type string `yaml:"type"`
|
Type string `yaml:"type"`
|
||||||
|
Name string `yaml:"name"`
|
||||||
Replication SinkReplication `yaml:"replication"`
|
Replication SinkReplication `yaml:"replication"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type PullJob struct {
|
||||||
|
Type string `yaml:"type"`
|
||||||
|
Name string `yaml:"name"`
|
||||||
|
Replication PullReplication `yaml:"replication"`
|
||||||
|
Pruning PruningSenderReceiver `yaml:"pruning"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type PullReplication struct {
|
||||||
|
Connect ConnectEnum `yaml:"connect"`
|
||||||
|
RootDataset string `yaml:"root_dataset"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type SourceJob struct {
|
||||||
|
Type string `yaml:"type"`
|
||||||
|
Name string `yaml:"name"`
|
||||||
|
Replication SourceReplication `yaml:"replication"`
|
||||||
|
Snapshotting Snapshotting `yaml:"snapshotting"`
|
||||||
|
Pruning PruningLocal `yaml:"pruning"`
|
||||||
|
}
|
||||||
|
|
||||||
type PushReplication struct {
|
type PushReplication struct {
|
||||||
Connect ConnectEnum `yaml:"connect"`
|
Connect ConnectEnum `yaml:"connect"`
|
||||||
Filesystems map[string]bool `yaml:"filesystems"`
|
Filesystems map[string]bool `yaml:"filesystems"`
|
||||||
@ -42,19 +64,30 @@ type SinkReplication struct {
|
|||||||
Serve ServeEnum `yaml:"serve"`
|
Serve ServeEnum `yaml:"serve"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type SourceReplication struct {
|
||||||
|
Serve ServeEnum `yaml:"serve"`
|
||||||
|
Filesystems map[string]bool `yaml:"filesystems"`
|
||||||
|
}
|
||||||
|
|
||||||
type Snapshotting struct {
|
type Snapshotting struct {
|
||||||
SnapshotPrefix string `yaml:"snapshot_prefix"`
|
SnapshotPrefix string `yaml:"snapshot_prefix"`
|
||||||
Interval time.Duration `yaml:"interval"`
|
Interval time.Duration `yaml:"interval"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type Pruning struct {
|
type PruningSenderReceiver struct {
|
||||||
KeepLocal []PruningEnum `yaml:"keep_local"`
|
KeepSender []PruningEnum `yaml:"keep_sender"`
|
||||||
KeepRemote []PruningEnum `yaml:"keep_remote"`
|
KeepReceiver []PruningEnum `yaml:"keep_receiver"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type PruningLocal struct {
|
||||||
|
Keep []PruningEnum `yaml:"keep"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type Global struct {
|
type Global struct {
|
||||||
Logging []LoggingOutletEnum `yaml:"logging"`
|
Logging []LoggingOutletEnum `yaml:"logging"`
|
||||||
Monitoring []MonitoringEnum `yaml:"monitoring,optional"`
|
Monitoring []MonitoringEnum `yaml:"monitoring,optional"`
|
||||||
|
Control GlobalControl `yaml:"control"`
|
||||||
|
Serve GlobalServe `yaml:"serve"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type ConnectEnum struct {
|
type ConnectEnum struct {
|
||||||
@ -148,6 +181,18 @@ type PrometheusMonitoring struct {
|
|||||||
Listen string `yaml:"listen"`
|
Listen string `yaml:"listen"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type GlobalControl struct {
|
||||||
|
SockPath string `yaml:"sockpath,default=/var/run/zrepl/control"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type GlobalServe struct {
|
||||||
|
StdinServer GlobalStdinServer `yaml:"stdinserver"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type GlobalStdinServer struct {
|
||||||
|
SockDir string `yaml:"sockdir,default=/var/run/zrepl/stdinserver"`
|
||||||
|
}
|
||||||
|
|
||||||
func enumUnmarshal(u func(interface{}, bool) error, types map[string]interface{}) (interface{}, error) {
|
func enumUnmarshal(u func(interface{}, bool) error, types map[string]interface{}) (interface{}, error) {
|
||||||
var in struct {
|
var in struct {
|
||||||
Type string
|
Type string
|
||||||
@ -173,6 +218,8 @@ func (t *JobEnum) UnmarshalYAML(u func(interface{}, bool) error) (err error) {
|
|||||||
t.Ret, err = enumUnmarshal(u, map[string]interface{}{
|
t.Ret, err = enumUnmarshal(u, map[string]interface{}{
|
||||||
"push": &PushJob{},
|
"push": &PushJob{},
|
||||||
"sink": &SinkJob{},
|
"sink": &SinkJob{},
|
||||||
|
"pull": &PullJob{},
|
||||||
|
"source": &SourceJob{},
|
||||||
})
|
})
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
@ -14,6 +14,7 @@ func TestSampleConfigsAreParsedWithoutErrors(t *testing.T) {
|
|||||||
|
|
||||||
for _, p := range paths {
|
for _, p := range paths {
|
||||||
|
|
||||||
|
t.Run(p, func(t *testing.T) {
|
||||||
c, err := ParseConfig(p)
|
c, err := ParseConfig(p)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Errorf("error parsing %s:\n%+v", p, err)
|
t.Errorf("error parsing %s:\n%+v", p, err)
|
||||||
@ -21,6 +22,7 @@ func TestSampleConfigsAreParsedWithoutErrors(t *testing.T) {
|
|||||||
|
|
||||||
t.Logf("file: %s", p)
|
t.Logf("file: %s", p)
|
||||||
t.Log(pretty.Sprint(c))
|
t.Log(pretty.Sprint(c))
|
||||||
|
})
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
39
cmd/config/samples/pull.yml
Normal file
39
cmd/config/samples/pull.yml
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
jobs:
|
||||||
|
|
||||||
|
- name: pull_servers
|
||||||
|
type: pull
|
||||||
|
replication:
|
||||||
|
connect:
|
||||||
|
type: tls
|
||||||
|
address: "server1.foo.bar:8888"
|
||||||
|
ca: /certs/ca.crt
|
||||||
|
cert: /certs/cert.crt
|
||||||
|
key: /certs/key.pem
|
||||||
|
root_dataset: "pool2/backup_servers"
|
||||||
|
pruning:
|
||||||
|
keep_sender:
|
||||||
|
- type: not_replicated
|
||||||
|
- type: last_n
|
||||||
|
count: 10
|
||||||
|
- type: grid
|
||||||
|
grid: 1x1h(keep=all) | 24x1h | 14x1d
|
||||||
|
keep_bookmarks: all
|
||||||
|
keep_receiver:
|
||||||
|
- type: grid
|
||||||
|
grid: 1x1h(keep=all) | 24x1h | 35x1d | 6x30d
|
||||||
|
keep_bookmarks: all
|
||||||
|
|
||||||
|
global:
|
||||||
|
logging:
|
||||||
|
- type: "stdout"
|
||||||
|
time: true
|
||||||
|
level: "warn"
|
||||||
|
format: "human"
|
||||||
|
monitoring:
|
||||||
|
- type: "prometheus"
|
||||||
|
listen: ":9091"
|
||||||
|
control:
|
||||||
|
sockpath: /var/run/zrepl/control
|
||||||
|
serve:
|
||||||
|
stdinserver:
|
||||||
|
sockdir: /var/run/zrepl/stdinserver
|
@ -1,5 +1,6 @@
|
|||||||
jobs:
|
jobs:
|
||||||
- type: push
|
- type: push
|
||||||
|
name: "push"
|
||||||
replication:
|
replication:
|
||||||
connect:
|
connect:
|
||||||
type: tcp
|
type: tcp
|
||||||
@ -12,7 +13,7 @@ jobs:
|
|||||||
snapshot_prefix: zrepl_
|
snapshot_prefix: zrepl_
|
||||||
interval: 10m
|
interval: 10m
|
||||||
pruning:
|
pruning:
|
||||||
keep_local:
|
keep_sender:
|
||||||
- type: not_replicated
|
- type: not_replicated
|
||||||
- type: last_n
|
- type: last_n
|
||||||
count: 10
|
count: 10
|
||||||
@ -20,7 +21,7 @@ jobs:
|
|||||||
grid: 1x1h(keep=all) | 24x1h | 14x1d
|
grid: 1x1h(keep=all) | 24x1h | 14x1d
|
||||||
keep_bookmarks: all
|
keep_bookmarks: all
|
||||||
|
|
||||||
keep_remote:
|
keep_receiver:
|
||||||
- type: grid
|
- type: grid
|
||||||
grid: 1x1h(keep=all) | 24x1h | 35x1d | 6x30d
|
grid: 1x1h(keep=all) | 24x1h | 35x1d | 6x30d
|
||||||
keep_bookmarks: all
|
keep_bookmarks: all
|
||||||
@ -33,3 +34,8 @@ global:
|
|||||||
monitoring:
|
monitoring:
|
||||||
- type: "prometheus"
|
- type: "prometheus"
|
||||||
listen: ":9091"
|
listen: ":9091"
|
||||||
|
control:
|
||||||
|
sockpath: /var/run/zrepl/control
|
||||||
|
serve:
|
||||||
|
stdinserver:
|
||||||
|
sockdir: /var/run/zrepl/stdinserver
|
@ -1,5 +1,6 @@
|
|||||||
jobs:
|
jobs:
|
||||||
- type: sink
|
- type: sink
|
||||||
|
name: "laptop_sink"
|
||||||
replication:
|
replication:
|
||||||
root_dataset: "pool2/backup_laptops"
|
root_dataset: "pool2/backup_laptops"
|
||||||
serve:
|
serve:
|
||||||
@ -19,3 +20,8 @@ global:
|
|||||||
key: "key.pem"
|
key: "key.pem"
|
||||||
level: "warn"
|
level: "warn"
|
||||||
format: "human"
|
format: "human"
|
||||||
|
control:
|
||||||
|
sockpath: /var/run/zrepl/control
|
||||||
|
serve:
|
||||||
|
stdinserver:
|
||||||
|
sockdir: /var/run/zrepl/stdinserver
|
40
cmd/config/samples/source.yml
Normal file
40
cmd/config/samples/source.yml
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
jobs:
|
||||||
|
- name: pull_source
|
||||||
|
type: source
|
||||||
|
replication:
|
||||||
|
serve:
|
||||||
|
type: tcp
|
||||||
|
listen: "0.0.0.0:8888"
|
||||||
|
clients: {
|
||||||
|
"192.168.122.123" : "client1"
|
||||||
|
}
|
||||||
|
filesystems: {
|
||||||
|
"<": true,
|
||||||
|
"secret": false
|
||||||
|
}
|
||||||
|
snapshotting:
|
||||||
|
snapshot_prefix: zrepl_
|
||||||
|
interval: 10m
|
||||||
|
pruning:
|
||||||
|
keep:
|
||||||
|
- type: not_replicated
|
||||||
|
- type: last_n
|
||||||
|
count: 10
|
||||||
|
- type: grid
|
||||||
|
grid: 1x1h(keep=all) | 24x1h | 14x1d
|
||||||
|
keep_bookmarks: all
|
||||||
|
|
||||||
|
global:
|
||||||
|
logging:
|
||||||
|
- type: "stdout"
|
||||||
|
time: true
|
||||||
|
level: "warn"
|
||||||
|
format: "human"
|
||||||
|
monitoring:
|
||||||
|
- type: "prometheus"
|
||||||
|
listen: ":9091"
|
||||||
|
control:
|
||||||
|
sockpath: /var/run/zrepl/control
|
||||||
|
serve:
|
||||||
|
stdinserver:
|
||||||
|
sockdir: /var/run/zrepl/stdinserver
|
Loading…
Reference in New Issue
Block a user