人妖在线一区,国产日韩欧美一区二区综合在线,国产啪精品视频网站免费,欧美内射深插日本少妇

新聞動(dòng)態(tài)

Golang高性能持久化解決方案BoltDB數(shù)據(jù)庫(kù)介紹

發(fā)布日期:2022-02-01 08:58 | 文章來(lái)源:源碼中國(guó)

1. 介紹Bolt

BoltDB是純Go語(yǔ)言實(shí)現(xiàn)的持久化解決方案,保存數(shù)據(jù)至內(nèi)存映射文件。稱之為持久化解決方案不是數(shù)據(jù)庫(kù),因?yàn)閿?shù)據(jù)庫(kù)這個(gè)詞有很多額外功能是bolt所不具備的。正是因?yàn)槿狈@些功能使得bolt如此優(yōu)雅、好用。

Bolt就是一個(gè)Go包。無(wú)需在系統(tǒng)中安裝,開始編碼前也無(wú)需配置,什么都不需要,僅需要go get github.com/boltdb/bolt,然后import “github.com/boltdb/bolt”。

要完全使用bolt的存儲(chǔ)功能,只需要一個(gè)文件名。無(wú)論從開發(fā)者或用戶視角都感覺不可思議。不知你的感想如何,在我的工作經(jīng)歷中花過很多時(shí)間搭建數(shù)據(jù)庫(kù)環(huán)境,調(diào)試配置問題,用戶和權(quán)限以及其他各種問題,如關(guān)系型數(shù)據(jù)庫(kù)PostgreSql、Oracle和NoSQL。這些bolt都不需要,沒有用戶、無(wú)需安裝,僅一個(gè)文件名。這對(duì)應(yīng)用程序的用戶來(lái)說也是一種恩惠,因?yàn)樗麄円膊槐貫槟切┞闊﹩栴}而瞎折騰。

Bolt不是關(guān)系型數(shù)據(jù)庫(kù)。甚至不存儲(chǔ)文檔,雖然你可以按照這種方式使用它。其僅僅存儲(chǔ)鍵值對(duì)…但是如果你不知道這是什么意思或者不知道你如何使用它進(jìn)行存儲(chǔ),也不用擔(dān)心。它超級(jí)簡(jiǎn)單,而且非常靈活,讓我們來(lái)看看。

2. 示例

bolt存儲(chǔ)是分組為桶,桶是一組鍵值對(duì)集合的名稱,就像Go中的map。桶的名稱、鍵以及值都是[]byte類型。桶可以包括其他桶,也可以通過[]byte類型名稱作為key。

…就是這樣。不,真的,就這樣。Bolt基本上是一組嵌套映射。這種簡(jiǎn)單性使得它易于使用。不需要設(shè)置表、模式、復(fù)雜的查詢語(yǔ)言。讓我們看看一個(gè)bolt入門示例:

package main
import (
	"fmt"
	"github.com/boltdb/bolt"
	"log"
)
var world = []byte("greeting")
func main() {
	db, err := bolt.Open("d:/bolt.db", 0644, nil)
	if err != nil {
		log.Fatal(err)
	}
	defer db.Close()
	key := []byte("hello")
	value := []byte("Hello World!")
	// store some data
	err = db.Update(func(tx *bolt.Tx) error {
		bucket, err := tx.CreateBucketIfNotExists(world)
		if err != nil {
			return err
		}
		err = bucket.Put(key, value)
		if err != nil {
			return err
		}
		return nil
	})
	if err != nil {
		log.Fatal(err)
	}
	// retrieve the data
	err = db.View(func(tx *bolt.Tx) error {
		bucket := tx.Bucket(world)
		if bucket == nil {
			return fmt.Errorf("Bucket %s not found!", world)
		}
		val := bucket.Get(key)
		fmt.Println(string(val))
		return nil
	})
	if err != nil {
		log.Fatal(err)
	}
}

輸出:Hello World!

我想你正在思索————這代碼似乎有點(diǎn)長(zhǎng)。但請(qǐng)記住,我完全處理了所有錯(cuò)誤,至少是半正確的方式,我們正在做的所有這些:

創(chuàng)建數(shù)據(jù)庫(kù)

創(chuàng)建結(jié)構(gòu)(greeting分組)

存儲(chǔ)數(shù)據(jù)到結(jié)構(gòu)中

從結(jié)構(gòu)中獲取數(shù)據(jù)

不算太壞,加上空行也不過54行代碼。下面詳細(xì)解釋下上面示例具體實(shí)現(xiàn)內(nèi)容。

3. 示例分析

首先bolt.Open連接數(shù)據(jù)庫(kù),如果需要?jiǎng)?chuàng)建文件或打開已存在的文件。
所有bolt讀寫操作都必須在事務(wù)內(nèi)進(jìn)行。在只讀事務(wù)中同時(shí)可以有很多讀操作,但寫操作一次只能有一個(gè)(當(dāng)寫入器寫入時(shí),讀取器維護(hù)數(shù)據(jù)庫(kù)的一致視圖)。

剛開始調(diào)用db.Update,帶有一個(gè)函數(shù)作為參數(shù),函數(shù)自身的參數(shù)為bolt.Tx ————bolt的事務(wù)對(duì)象。然后創(chuàng)建桶(bolt所有數(shù)據(jù)都用桶組織),接著增加鍵值對(duì)。寫事務(wù)完成后開始讀操作————使用DB.View事務(wù)獲取剛寫入的數(shù)據(jù)。

bolt事務(wù)機(jī)制的強(qiáng)大之處在于它超級(jí)簡(jiǎn)單——函數(shù)作用域就是事務(wù)的范圍。如果函數(shù)傳入U(xiǎn)pdate并返回nil,事務(wù)中所有更新操作是原子的存入庫(kù)中。如果函數(shù)返回錯(cuò)誤則事務(wù)回滾。這使得bolt事務(wù)對(duì)Go開發(fā)者來(lái)說非常簡(jiǎn)單。只要像平時(shí)一樣返回一個(gè)錯(cuò)誤,就可以提前退出函數(shù),bolt也做了正確的事情。無(wú)需擔(dān)心手動(dòng)回滾更新或其他事情,只需返回一個(gè)錯(cuò)誤。

你可能需要另一個(gè)基本操作是遍歷桶中的鍵/值對(duì),在這種情況下,只需調(diào)用Bucket.Cursor(),它返回一個(gè)游標(biāo)值,它有Next()、Prev()等函數(shù),它們返回鍵/值對(duì),并像您預(yù)期的那樣工作。

bolt API還有很多內(nèi)容,但剩下的大部分內(nèi)容都是關(guān)于數(shù)據(jù)庫(kù)統(tǒng)計(jì)和一些更高級(jí)使用場(chǎng)景內(nèi)容……但要開始在bolt數(shù)據(jù)庫(kù)中存儲(chǔ)數(shù)據(jù),上述內(nèi)容就是你真正需要知道的。

4. 總結(jié)

對(duì)于更復(fù)雜的應(yīng)用程序,僅在數(shù)據(jù)庫(kù)中存儲(chǔ)字符串可能不夠,但這沒關(guān)系,Go的編碼相關(guān)包可以幫忙。你可以很容易地使用encoding/json或encoding/gob將結(jié)構(gòu)序列化到數(shù)據(jù)庫(kù)中,以唯一的名稱或id作為鍵。再者bolt的好處是較低的使用門檻,不需要找出整個(gè)數(shù)據(jù)庫(kù)模式或安裝任何東西,就可以以高性能、可管理的方式將數(shù)據(jù)存儲(chǔ)至磁盤。

bolt的主要缺點(diǎn)是沒有查詢。你不能要求:給我所有以bar開頭foo對(duì)象。您可以在數(shù)據(jù)庫(kù)中創(chuàng)建自己的索引,并手動(dòng)保持其更新。這很簡(jiǎn)單,只需為特定查詢將IDs切片(slice)序列化到“indices”桶中即可。顯然這是開始開發(fā)自己關(guān)系數(shù)據(jù)庫(kù)的領(lǐng)域,但是如果你不打算做得太過火,那么所有這些代碼就夠了。那些外部DSL中的查詢只是為內(nèi)存中數(shù)據(jù)存儲(chǔ)編寫的代碼。

Bolt并非適用于所有應(yīng)用。你必須了解應(yīng)用程序的需求,以及bolt的鍵/值樣式是否足以滿足這些需求。如果是這樣,我想你會(huì)非常樂意使用簡(jiǎn)單的數(shù)據(jù)存儲(chǔ)系統(tǒng),而無(wú)需太多的腦力開銷。

以上就是Golang高性能持久化解決方案BoltDB數(shù)據(jù)庫(kù)介紹的詳細(xì)內(nèi)容,更多關(guān)于Golang持久化BoltDB的資料請(qǐng)關(guān)注本站其它相關(guān)文章!

美國(guó)服務(wù)器租用

版權(quán)聲明:本站文章來(lái)源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來(lái)源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來(lái)源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來(lái),僅供學(xué)習(xí)參考,不代表本站立場(chǎng),如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。

相關(guān)文章

實(shí)時(shí)開通

自選配置、實(shí)時(shí)開通

免備案

全球線路精選!

全天候客戶服務(wù)

7x24全年不間斷在線

專屬顧問服務(wù)

1對(duì)1客戶咨詢顧問

在線
客服

在線客服:7*24小時(shí)在線

客服
熱線

400-630-3752
7*24小時(shí)客服服務(wù)熱線

關(guān)注
微信

關(guān)注官方微信
頂部