0

我试图在 mongodb 中一次获取 10000 个文档,但我得到了:

信息 :

代码 :


package main

import (
    "context"
    "fmt"
    "net/http"
    "os"
    "time"

    "go.mongodb.org/mongo-driver/bson"
    "go.mongodb.org/mongo-driver/mongo"
    "go.mongodb.org/mongo-driver/mongo/options"
)

var database *mongo.Database

func main() {

    ctx, _ := context.WithTimeout(context.Background(), 10*time.Second)
    client, err := mongo.Connect(ctx, options.Client().ApplyURI("mongodb://20.20.20.43:27017"))
    if err != nil {
        panic(err)
    }

    database = client.Database("chat_data")

    chatText := make([]chat, 0)
    now := time.Now().Unix()
    ctx, _ = context.WithTimeout(context.Background(), 30*time.Second)

    // mongodb batch option
    opt := options.Find()
    opt.SetBatchSize(15_000)
    opt.SetAllowPartialResults(false)

    // mongodb filter
    filter := bson.M{"timestamp": bson.M{"$gte": now - 108000}}

    cur, err := database.Collection("chat").Find(ctx, filter, opt)
    if err != nil {
        // fmt.Fprint(w, err)
        fmt.Println(err)
        return
    }
    defer cur.Close(ctx)

    for cur.Next(ctx) {
        var result chat
        err := cur.Decode(&result)
        if err != nil {
            fmt.Println(err)
            continue
        }
        // do something with result....
        // fmt.Println(result)
        chatText = append(chatText, result)
    }
    if err := cur.Err(); err != nil {
        // fmt.Fprint(w, cur.Err())
        fmt.Println(err)
        return
    }

    fmt.Println("done")
    fmt.Println(len(chatText))
}

我可以用 mongodb 和 go 驱动程序实现这一点吗?总是达到 30 秒超时

编辑 1

我尝试在python(使用pymongo)中只需要0m2.159s使用该过滤器查询36k doc

4

2 回答 2

0

尝试 7000,如果有效,请尝试 12000,如果无效,请尝试 4000,等等。

记下这些请求需要多长时间才能确定执行时间是否与批量大小成正比。

于 2020-04-27T18:19:37.333 回答
0

您只查询该timestamp字段。如果您首先使用该字段在该集合上创建索引timestamp,您应该获得更快的结果,并在此过程中获得免费排序。

于 2020-04-28T04:42:39.210 回答