當前位置: 首頁>>代碼示例>>Golang>>正文


Golang Engine.BatchPut方法代碼示例

本文整理匯總了Golang中github.com/influxdb/influxdb/datastore/storage.Engine.BatchPut方法的典型用法代碼示例。如果您正苦於以下問題:Golang Engine.BatchPut方法的具體用法?Golang Engine.BatchPut怎麽用?Golang Engine.BatchPut使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在github.com/influxdb/influxdb/datastore/storage.Engine的用法示例。


在下文中一共展示了Engine.BatchPut方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。

示例1: writeBatch

func writeBatch(db storage.Engine, c *Config) int {
	ws := c.MakeBatch()
	if err := db.BatchPut(ws); err != nil {
		panic(err)
	}
	return len(ws)
}
開發者ID:Kenterfie,項目名稱:influxdb,代碼行數:7,代碼來源:main.go

示例2: benchmarkWrites

func benchmarkWrites(db storage.Engine, c *Config, points int) int {
	writesChan := make([]chan []storage.Write, c.threads)
	for i := range writesChan {
		writesChan[i] = make(chan []storage.Write, 1)
	}

	count := 0
	p := points

	go func() {
		defer func() {
			for _, ch := range writesChan {
				close(ch)
			}
		}()

		for {
			for _, ch := range writesChan {
				w := c.MakeBatch()
				ch <- w
				l := len(w)
				count += l
				p -= l
				if p <= 0 {
					return
				}
			}
		}
	}()

	wg := sync.WaitGroup{}
	for i := 0; i < c.threads; i++ {
		wg.Add(1)
		go func(idx int) {
			defer wg.Done()
			for w := range writesChan[idx] {
				if err := db.BatchPut(w); err != nil {
					panic(err)
				}
				fmt.Print(".")
			}
		}(i)
	}

	wg.Wait()
	fmt.Printf("\n")
	return count
}
開發者ID:carriercomm,項目名稱:facette,代碼行數:48,代碼來源:main.go


注:本文中的github.com/influxdb/influxdb/datastore/storage.Engine.BatchPut方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。