go mongodb

mb6018e97449ea1 · · 402 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

连接参数配置

package mongod

import (
	"context"
	"go.mongodb.org/mongo-driver/bson/primitive"
	"go.mongodb.org/mongo-driver/mongo"
	"go.mongodb.org/mongo-driver/mongo/options"
	"log"
	"time"
	"src/golangConfig"
)

var (
	MongoServiceUrl       = "172.168.1.153:27017"
	MongoDataBaseName     = "baseName"
	MongoColPacketLogName = "logName"
	MongoDataBase     *mongo.Database   = nil
	MongoPacketLogCol *mongo.Collection = nil
	MongoClient       *mongo.Client     = nil
	MongoContext      context.Context   = nil
)

type Yxtranslog struct {
	Id         primitive.ObjectID `json:"id" bson:"_id"`
	name      string             `json:"name" bson:"name"`
	.........
}

func Connect() (context.Context, error) {

	MongoServiceUrl = golangConfig.InitConfigMap["mongoServiceUrl"].(string)
	MongoDataBaseName = golangConfig.InitConfigMap["mongoDataBaseName"].(string)
	MongoColPacketLogName = golangConfig.InitConfigMap["mongoColPacketLogName"].(string)
	ctx, _ := context.WithTimeout(context.Background(), 120*time.Second)

	client, err := mongo.Connect(ctx, &options.ClientOptions{Hosts: []string{MongoServiceUrl}})

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

	// Check the connection
	err = client.Ping(context.TODO(), nil)

	if err != nil {
		log.Fatal(err)
		return nil, err
	}
	MongoContext = ctx
	MongoClient = client
	MongoDataBase = MongoClient.Database(MongoDataBaseName)
	MongoPacketLogCol = MongoDataBase.Collection(MongoColPacketLogName)

	return ctx, err
}

func Disconnect() error {
	err := MongoClient.Disconnect(context.TODO())
	if err != nil {
		log.Fatal(err)
		return err
	}
	return nil
}

func GetTransLogCollection() *mongo.Collection {
	return MongoPacketLogCol
}

func insertMany(arr []interface{}) *mongo.InsertManyResult {
	collection := GetTransLogCollection()
	resm, err := collection.InsertMany(MongoContext, arr)
	if err != nil {
		log.Fatal(err)
	}
	return resm
}

func InsertMongodb(batch []interface{}) {

	go insertMany(batch)

	//Disconnect()

}

连接初始化

dbwrite.MongodInit()

以下代码为批量插入数据库(到达预设长度后,立即持久化。当最后长度不满足后,到达一定时间插入数据库),通过通道eventQueue操作数据

package dbwrite

import (
	"fmt"
	"time"
	"src/golangConfig"
	"src/mongod"
)

var (
	eventQueue     chan interface{}
	BatchWriteSize int
	Workers        int
	lingerTime     time.Duration
	batchProcessor = func(batch []interface{}) error {
		mongod.InsertMongodb(batch)
		return nil
	}
	errHandler = func(err error, batch []interface{}) {
		fmt.Println("some error happens")
	}
)

func setWorkers() {
	for i := 0; i < Workers; i++ {
		go func() {
			var batch []interface{}
			lingerTimer := time.NewTimer(5 * time.Second)
			if !lingerTimer.Stop() {
				<-lingerTimer.C
			}
			defer lingerTimer.Stop()

			for {
				select {
				case msg := <-eventQueue:
					batch = append(batch, msg)
					if len(batch) != BatchWriteSize {
						if len(batch) == 1 {
							lingerTimer.Reset(lingerTime)
						}
						break
					}

					if err := batchProcessor(batch); err != nil {
						errHandler(err, batch)
					}

					if !lingerTimer.Stop() {
						<-lingerTimer.C
					}

					batch = make([]interface{}, 0)
				case <-lingerTimer.C:
					if err := batchProcessor(batch); err != nil {
						errHandler(err, batch)
					}

					batch = make([]interface{}, 0)
				}
			}
		}()
	}
}

func PushMongodElement(e interface{}) {
	eventQueue <- e
}

func MongodInit() {
	eventQueue = make(chan interface{}, golangConfig.InitConfigMap["mongodEventQueueCache"].(int))
	BatchWriteSize = golangConfig.InitConfigMap["mongodBatchWriteSize"].(int)
	Workers = golangConfig.InitConfigMap["mongodWorkers"].(int)
	lingerTime = golangConfig.InitConfigMap["mongodLingerTime"].(time.Duration)
	mongod.Connect()
	setWorkers()
}

向通道eventQueue存入值 

json := bson.M{"name": name.....}
dbwrite.PushMongodElement(json)

 


有疑问加站长微信联系(非本文作者)

本文来自:51CTO博客

感谢作者:mb6018e97449ea1

查看原文:go mongodb

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

402 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传