我正在使用 Go 的 MongodDB 驅動程式(https://pkg.go.dev/go.mongodb.org/[email protected]/mongo#section-documentation)并且想要獲取部署的 mongoDB 服務器的版本。
例如,如果它是一個 MySQL 資料庫,我可以執行以下操作:
db, err := sql.Open("mysql", DbUser ":" DbPwd "@tcp(" Host ")/" DbName)
if err != nil {
log.Printf("Error while connecting to DB: %v", err)
}
defer db.Close()
var dbVersion string
if err := db.QueryRow("SELECT VERSION()").Scan(&dbVersion); err != nil {
dbVersion = "NA"
log.Printf("Couldnt obtain db version: %w", err)
}
fmt.Println("DB Version: ", dbVersion)
我瀏覽了檔案,但找不到線索。
我還需要獲取其他元資料,例如特定資料庫的大小等。
任何幫助,將不勝感激。謝謝!
uj5u.com熱心網友回復:
MongoDB 版本可以通過運行命令,特別是buildInfo命令來獲取。
使用 shell,你可以這樣做:
db.runCommand({buildInfo: 1})
結果是一個檔案,其version屬性包含服務器版本,例如:
{
"version" : "5.0.6",
...
}
要使用官方驅動程式運行命令,請使用Database.RunCommand()方法。
例如:
// Connect to MongoDB and acquire a Database:
ctx := context.Background()
opts := options.Client().ApplyURI("mongodb://localhost")
client, err := mongo.Connect(ctx, opts)
if err != nil {
log.Fatalf("Failed to connect to db: %v", err)
}
defer client.Disconnect(ctx)
db := client.Database("your-db-name")
// And now run the buildInfo command:
buildInfoCmd := bson.D{bson.E{Key: "buildInfo", Value: 1}}
var buildInfoDoc bson.M
if err := db.RunCommand(ctx, buildInfoCmd).Decode(&buildInfoDoc); err != nil {
log.Printf("Failed to run buildInfo command: %v", err)
return
}
log.Println("Database version:", buildInfoDoc["version"])
uj5u.com熱心網友回復:
根據@icza 的回答,這里是如何獲取資料庫的其他元資料:
我們需要使用dbStats命令來獲取元資料。
host := "<your-host-name>:<pot-number>"
url := "mongodb://" host
credential := options.Credential{
AuthSource: "authentication-database",
Username: "username",
Password: "password",
}
clientOpts := options.Client().ApplyURI(url).SetAuth(credential)
ctx := context.Background()
client, err := mongo.Connect(ctx, clientOpts)
if err != nil {
log.Fatal("Failed to connect to db : %w", err)
}
defer client.Disconnect(ctx)
if err := client.Ping(context.TODO(), readpref.Primary()); err != nil {
panic(err)
}
fmt.Println("Successfully connected and pinged.")
db := client.Database("your-database-name")
dbStatsCmd := bson.D{bson.E{Key: "dbStats", Value: 1}}
var dbStatsDoc bson.M
if err := db.RunCommand(ctx, dbStatsCmd).Decode(&dbStatsDoc); err != nil {
log.Printf("Failed to run dbStats command: %v", err)
return
}
log.Println("\nTotal Used Size in MB: ", dbStatsDoc["totalSize"].(float64) / 1048576 , " ,Total Free size in MB (part of total used size): ", dbStatsDoc["totalFreeStorageSize"].(float64)/1048576)
轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/450665.html
下一篇:JSON未拆分到不同的單元格中
