From a961ff9ebf1c5d944ce2a8856f03519d8988d70c Mon Sep 17 00:00:00 2001 From: Cory LaNou Date: Wed, 30 Mar 2016 11:21:03 -0500 Subject: [PATCH 1/4] minor restore fixes; fsync meta snapshots --- cmd/influxd/restore/restore.go | 12 +++++++++++- services/meta/client.go | 2 +- 2 files changed, 12 insertions(+), 2 deletions(-) diff --git a/cmd/influxd/restore/restore.go b/cmd/influxd/restore/restore.go index c50c61cdbb9..ef6f307c74b 100644 --- a/cmd/influxd/restore/restore.go +++ b/cmd/influxd/restore/restore.go @@ -170,7 +170,7 @@ func (cmd *Command) unpackMeta() error { // Copy meta config and remove peers so it starts in single mode. c := cmd.MetaConfig - c.LoggingEnabled = false + c.Dir = cmd.metadir // Create the meta dir if os.MkdirAll(c.Dir, 0700); err != nil { @@ -193,6 +193,16 @@ func (cmd *Command) unpackMeta() error { if err := client.SetData(&data); err != nil { return fmt.Errorf("set data: %s", err) } + + // remove the raft.db file if it exists + err = os.Remove(filepath.Join(cmd.metadir, "raft.db")) + if err != nil { + if os.IsNotExist(err) { + return nil + } + return err + } + return nil } diff --git a/services/meta/client.go b/services/meta/client.go index 07859f613a2..deba0af5031 100644 --- a/services/meta/client.go +++ b/services/meta/client.go @@ -975,7 +975,7 @@ func snapshot(path string, data *Data) error { return err } - if err = f.Close(); nil != err { + if err = f.Sync(); err != nil { return err } From 6c6fe87a40c2757dea68dac35888e6cf98a0ceab Mon Sep 17 00:00:00 2001 From: Cory LaNou Date: Wed, 30 Mar 2016 11:39:57 -0500 Subject: [PATCH 2/4] add error message if detecting raft.db file --- services/meta/client.go | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/services/meta/client.go b/services/meta/client.go index deba0af5031..d086bf9188b 100644 --- a/services/meta/client.go +++ b/services/meta/client.go @@ -90,6 +90,15 @@ func NewClient(config *Config) *Client { func (c *Client) Open() error { c.mu.Lock() defer c.mu.Unlock() + + // Check to see if there is a raft db, if so, error out with a message + // to downgrade, export, and then import the meta data + + raftFile := filepath.Join(c.path, "raft.db") + if _, err := os.Stat(raftFile); err == nil { + return fmt.Errorf("detected %s. either downgrade and export your meta data to import before continuing, or delete the file to start fresh", raftFile) + } + // Try to load from disk if err := c.Load(); err != nil { return err From 7bda8102ac1791831697cccec2ee5b58050270e0 Mon Sep 17 00:00:00 2001 From: Cory LaNou Date: Wed, 30 Mar 2016 11:48:22 -0500 Subject: [PATCH 3/4] update changelog --- CHANGELOG.md | 1 + 1 file changed, 1 insertion(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 2f758eb7ff2..daf1bc7acff 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -22,6 +22,7 @@ - [#6148](https://github.com/influxdata/influxdb/pull/6148): Build script is now compatible with Python 3. Added ability to create detached signatures for packages. Build script now uses Python logging facility for messages. - [#6115](https://github.com/influxdata/influxdb/issues/6115): Support chunking query results mid-series. Limit non-chunked output. - [#6166](https://github.com/influxdata/influxdb/pull/6166): Teach influxdb client how to use chunked queries and use in the CLI. +- [#6158](https://github.com/influxdata/influxdb/pull/6158): Update influxd to detect an upgrade from `0.11` to `0.12`. Minor restore bug fixes. ### Bugfixes From 9bd60c3e0762b3ca112bac13a1c784bce5296333 Mon Sep 17 00:00:00 2001 From: Cory LaNou Date: Wed, 30 Mar 2016 15:43:25 -0500 Subject: [PATCH 4/4] remove node.json as well, change where we check for raft.db in startup --- cmd/influxd/restore/restore.go | 9 +++++++++ cmd/influxd/run/server.go | 7 +++++++ services/meta/client.go | 8 -------- 3 files changed, 16 insertions(+), 8 deletions(-) diff --git a/cmd/influxd/restore/restore.go b/cmd/influxd/restore/restore.go index ef6f307c74b..3fcbf476cf9 100644 --- a/cmd/influxd/restore/restore.go +++ b/cmd/influxd/restore/restore.go @@ -203,6 +203,15 @@ func (cmd *Command) unpackMeta() error { return err } + // remove the node.json file if it exists + err = os.Remove(filepath.Join(cmd.metadir, "node.json")) + if err != nil { + if os.IsNotExist(err) { + return nil + } + return err + } + return nil } diff --git a/cmd/influxd/run/server.go b/cmd/influxd/run/server.go index b602020422c..1710abf8938 100644 --- a/cmd/influxd/run/server.go +++ b/cmd/influxd/run/server.go @@ -115,6 +115,13 @@ func NewServer(c *Config, buildInfo *BuildInfo) (*Server, error) { } } + // Check to see if there is a raft db, if so, error out with a message + // to downgrade, export, and then import the meta data + raftFile := filepath.Join(c.Meta.Dir, "raft.db") + if _, err := os.Stat(raftFile); err == nil { + return nil, fmt.Errorf("detected %s. either downgrade and export your meta data to import before continuing, or delete the file to start fresh", raftFile) + } + // In 0.10.0 bind-address got moved to the top level. Check // The old location to keep things backwards compatible bind := c.BindAddress diff --git a/services/meta/client.go b/services/meta/client.go index d086bf9188b..13946a733f4 100644 --- a/services/meta/client.go +++ b/services/meta/client.go @@ -91,14 +91,6 @@ func (c *Client) Open() error { c.mu.Lock() defer c.mu.Unlock() - // Check to see if there is a raft db, if so, error out with a message - // to downgrade, export, and then import the meta data - - raftFile := filepath.Join(c.path, "raft.db") - if _, err := os.Stat(raftFile); err == nil { - return fmt.Errorf("detected %s. either downgrade and export your meta data to import before continuing, or delete the file to start fresh", raftFile) - } - // Try to load from disk if err := c.Load(); err != nil { return err