go couchbase (gocb) 错误 - 不明确的超时或明确的超时

Kei*_*ell 6 go couchbase sql++ gocb

我刚刚开始使用 Go 中的 Couchbase,使用库 gocb。

就像尝试向我的服务器查询特定 ID 并获取结果的概念证明一样。下面是修改后的代码示例。

cOpts := gocb.ClusterOptions{
        Authenticator: gocb.PasswordAuthenticator{
            Username: "user",
            Password: "pw",
        },
    }

    cluster, err := gocb.Connect("couchbase://my.dev.server.net/", cOpts)
    if err != nil {
        panic(err)
    }

    qOpts := gocb.QueryOptions{}

    // create query
    queryStr := "SELECT * FROM myBucket WHERE id = '123456789'"

    rows, err := cluster.Query(queryStr, &qOpts)
    if err != nil {
        panic(err)
    }

    fmt.Printf("rows: %v\n", rows)

    for rows.Next() {
        var intfc interface{}
        err = rows.Row(&intfc)
        if err != nil {
            panic(err)
        }
        fmt.Printf("interface result: %v\n", intfc)

    }
Run Code Online (Sandbox Code Playgroud)

couchbase 服务器版本为 5.1。

我要么得到...

panic: ambiguous timeout | {"statement":"SELECT * FROM myBucketName WHERE id = '123456789'","client_context_id":"cdd52a06-c7a5-4d3d-8r26-99fg806d559e"}
Run Code Online (Sandbox Code Playgroud)

...当我运行上面的代码时。
或者 如果我在之后输入以下几行,gocb.Connect(...我会收到此后的错误。

panic: ambiguous timeout | {"statement":"SELECT * FROM myBucketName WHERE id = '123456789'","client_context_id":"cdd52a06-c7a5-4d3d-8r26-99fg806d559e"}
Run Code Online (Sandbox Code Playgroud)

...错误...

panic: unambiguous timeout | {"InnerError":{"InnerError":{"InnerError":{},"Message":"unambiguous timeout"}},"OperationID":"WaitUntilReady","Opaque":"","TimeObserved":25000263891,"RetryReasons":["NOT_READY"],"RetryAttempts":105,"LastDispatchedTo":"","LastDispatchedFrom":"","LastConnectionID":""}  
Run Code Online (Sandbox Code Playgroud)

注意:我在这里更改了UsernamePasswordServer/connStrbucket和 ,id仅用于示例目的。

我在这里缺少什么?

Kei*_*ell 3

感谢@vsr 的回答。
所有其他响应都有帮助,但直到我执行该建议并cluster.Bucket("mybucket")在连接后添加后才起作用。

缺少的一件事是输入“Bucket”名称。见下文...

除了 @vsr 帮助和答案之外,我刚刚在网站上的文档中找到了一些关于此的内容。
[https://docs.couchbase.com/go-sdk/current/howtos/n1ql-queries-with-sdk.html](Couchbase Docs)在刚开始使用的Golang示例中,在代码的注释中提到“对于服务器版本 6.5 或更高版本,您不需要在此处打开存储桶”,然后在下一行打开一个存储桶。好信息。

    cOpts := gocb.ClusterOptions{
        Authenticator: gocb.PasswordAuthenticator{
            Username: "user",
            Password: "pw",
        },
    }

    cluster, err := gocb.Connect("couchbase://my.dev.server.net/", cOpts)
    if err != nil {
        panic(err)
    }

    bucketName := "myBucket"
    cluster.Bucket(bucketName)

    qOpts := gocb.QueryOptions{}

    // create query
    queryStr := "SELECT * FROM myBucket WHERE id = '123456789'"

    rows, err := cluster.Query(queryStr, &qOpts)
    if err != nil {
        panic(err)
    }

    fmt.Printf("rows: %v\n", rows)

    for rows.Next() {
        var intfc interface{}
        err = rows.Row(&intfc)
        if err != nil {
            panic(err)
        }
        fmt.Printf("interface result: %v\n", intfc)
    }
Run Code Online (Sandbox Code Playgroud)

只需添加该cluster.Bucket("myBucket")行即可完成这项工作。
该服务器很旧,并且是缺乏资源的开发服务器,因此我也增加了超时,因为我知道它会很慢。cOpts我通过将集群选项(在代码中命名)调整为以下内容来提高超时...

    cOpts := gocb.ClusterOptions{
        Authenticator: gocb.PasswordAuthenticator{
            Username: "user",
            Password: "pw",
        },
        TimeoutsConfig: gocb.TimeoutsConfig{
            ConnectTimeout: 95 * time.Second,
            QueryTimeout:   95 * time.Second,
            SearchTimeout:  95 * time.Second,
        },
    }
Run Code Online (Sandbox Code Playgroud)

这会将超时时间延长到 95 秒,我不需要那么多,但服务器速度足够慢,以至于在 UI 中执行相同的查询需要 40 秒,所以我只是想确定一下。
我还调整了查询​​的超时时间。我不确定它们之间有什么区别,但我在下面进行了调整。

    qOpts := gocb.QueryOptions{}
    qOpts.Readonly = true
    qOpts.ScanWait = 95 * time.Second
    qOpts.Timeout = 95 * time.Second
Run Code Online (Sandbox Code Playgroud)

此外,如果您不知道的话,我是 couchbase 的新手,查询没有使用索引字段。我查找了该存储桶的索引字段并将其添加到查询中,这样时间就减少了一半以上。

编辑:USE KEYS在 N1QL 中使用该语句似乎非常快,比任何查询都快。我调整了代码,因此qryStr查询字符串如下所示......

queryStr := "SELECT * FROM myBucket USE KEYS ['123456789']"
Run Code Online (Sandbox Code Playgroud)

  • 如果您已经知道文档密钥,则可以使用 USE KEYS 或密钥值获取 https://couchbase.live/examples/basic-go-kv-get (3认同)
  • 在 myBucket(id) 上创建索引 ix1; 看看是否有所改善。结帐 https://index-advisor.couchbase.com/indexadvisor/#1 (2认同)