【问题标题】:boltdb unexpected fault address when trying to copy尝试复制时boltdb出现意外故障地址
【发布时间】:2019-01-11 09:15:00
【问题描述】:

我有以下程序。

package main

import (
    "fmt"
    "log"

    "github.com/boltdb/bolt"
)

const dbFile = "testbolt.db"
const testBucket = "test"

func main() {
    db, err := bolt.Open(dbFile, 0600, nil)
    if err != nil {
        log.Fatal(err)
    }
    defer db.Close()

    err = db.Update(func(tx *bolt.Tx) error {
        _, err := tx.CreateBucketIfNotExists([]byte(testBucket))
        if err != nil {
            return err
        }
        return nil
    })
    if err != nil {
        log.Fatal("1", err)
    }

    err = db.Update(func(tx *bolt.Tx) error {
        b := tx.Bucket([]byte(testBucket))
        err := b.Put([]byte("l"), []byte("writesomething"))
        return err
    })
    if err != nil {
        log.Fatal("2", err)
    }

    var lastSth []byte
    var lastSthCopy []byte
    err = db.View(func(tx *bolt.Tx) error {
        b := tx.Bucket([]byte(testBucket))
        lastSth = b.Get([]byte("l"))
        fmt.Printf("lastSth %s@%p\n", lastSth, lastSth)
        lastSthCopy = make([]byte, len(lastSth))
        copy(lastSth, lastSthCopy) // this line fails.
        fmt.Printf("lastSth:%s@%p, lastSthCopy:%p\n", lastSth, lastSth, lastSthCopy)

        return nil
    })
    if err != nil {
        log.Fatal("3", err)
    }
}

虽然打印lastSth 字节片的地址和值没问题,但将值复制到另一个字节片会出现以下错误。

lastSth writesomething@0xc94055
unexpected fault address 0xc94055
fatal error: fault
[signal 0xc0000005 code=0x1 addr=0xc94055 pc=0x4549de]

请指教。

【问题讨论】:

  • BoltDb Github 页面中有一个issue。你看到了吗?无论如何,您的问题无法通过任意字节切片直接复制来重现:play.golang.org/p/cYCscNE8FDW
  • 是的,我已经看到了,但我相信问题涉及事务外部的引用,而这里的问题发生在事务内部,我很确定上面的代码可以重现问题(至少我得到了每次都这样)

标签: go segmentation-fault boltdb


【解决方案1】:

查看 copy() 的签名:

func copy(dst, src []Type) int

您目前拥有:

copy(lastSth, lastSthCopy) // copies lastSthCopy (src) to lasSth (dst)

我认为你有 dst 和 src 倒退。您可能的意思是:

copy(lastSthCopy, lastSth)

这修复了错误。将 []byte 复制到 bolt 的 []byte 会导致内存错误。

【讨论】:

    猜你喜欢
    • 2018-05-29
    • 1970-01-01
    • 1970-01-01
    • 2020-05-03
    • 2022-01-21
    • 1970-01-01
    • 2014-12-07
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多