我寫了一個(gè)更新函數(shù),但是多次執(zhí)行會報(bào)錯context deadline exceeded。我的功能:func Update(link string, m bson.M) { configInfo := config.Config() // client := GetInstance().client // ctx := GetInstance().ctx client, _ := mongo.NewClient(options.Client().ApplyURI("mongodb://localhost:27017"))ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second) defer cancel() err := client.Connect(ctx) if err != nil { fmt.Print("connect error!") fmt.Println(err) } db := client.Database("test") lianjia := db.Collection("test") _, err = lianjia.UpdateOne(ctx, bson.M{"Link": link}, bson.M{"$set": m}) if err != nil { fmt.Print("update error!") fmt.Println(err) }}輸出:update error!context deadline exceeded
5 回答

慕仙森
TA貢獻(xiàn)1827條經(jīng)驗(yàn) 獲得超8個(gè)贊
更改 mongodb://localhost:27017
為 mongodb://127.0.0.1:27017/

不負(fù)相思意
TA貢獻(xiàn)1777條經(jīng)驗(yàn) 獲得超10個(gè)贊
嘗試更改上下文超時(shí),例如 30 秒
ctx, cancel := context.WithTimeout(context.Background(), time.Second*30)

慕雪6442864
TA貢獻(xiàn)1812條經(jīng)驗(yàn) 獲得超5個(gè)贊
嘗試使用
ctx := context.Background()
代替,
ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second)
當(dāng)我嘗試使用 MongoDB 服務(wù)器開發(fā) REST 后端時(shí),這解決了我的問題

智慧大石
TA貢獻(xiàn)1946條經(jīng)驗(yàn) 獲得超3個(gè)贊
您的 URI 錯誤,因?yàn)槟褂玫氖?docker。
如果您的 mongoDB 容器調(diào)用mongoContainer
,您應(yīng)該:
client, _ := mongo.NewClient(options.Client().ApplyURI("mongodb://mongoContainer"))

吃雞游戲
TA貢獻(xiàn)1829條經(jīng)驗(yàn) 獲得超7個(gè)贊
在 GoLand 中調(diào)試時(shí),如果您有一個(gè)斷點(diǎn)并且程序等待,然后您繼續(xù)并收到此錯誤,有時(shí)會發(fā)生這種情況。如果刪除斷點(diǎn)并再次運(yùn)行該程序,它就會起作用。至少我的情況就是這樣。
- 5 回答
- 0 關(guān)注
- 471 瀏覽
添加回答
舉報(bào)
0/150
提交
取消