mirror of
https://github.com/go-gitea/gitea.git
synced 2025-01-10 03:58:17 +08:00
c4d8d53a6d
* Use vendored go-swagger (#8087) * Use vendored go-swagger * vendor go-swagger * revert un wanteed change * remove un-needed GO111MODULE * Update Makefile Co-Authored-By: techknowlogick <matti@mdranta.net> * re-generate swagger file |
||
---|---|---|
.. | ||
.gitignore | ||
.travis.yml | ||
audit.go | ||
client.go | ||
conn_pool.go | ||
ddocs.go | ||
LICENSE | ||
observe.go | ||
pools.go | ||
port_map.go | ||
README.markdown | ||
streaming.go | ||
tap.go | ||
upr.go | ||
users.go | ||
util.go | ||
vbmap.go | ||
views.go |
A smart client for couchbase in go
This is a unoffical version of a Couchbase Golang client. If you are looking for the Offical Couchbase Golang client please see [CB-go])[https://github.com/couchbaselabs/gocb].
This is an evolving package, but does provide a useful interface to a couchbase server including all of the pool/bucket discovery features, compatible key distribution with other clients, and vbucket motion awareness so application can continue to operate during rebalances.
It also supports view querying with source node randomization so you don't bang on all one node to do all the work.
Install
go get github.com/couchbase/go-couchbase
Example
c, err := couchbase.Connect("http://dev-couchbase.example.com:8091/")
if err != nil {
log.Fatalf("Error connecting: %v", err)
}
pool, err := c.GetPool("default")
if err != nil {
log.Fatalf("Error getting pool: %v", err)
}
bucket, err := pool.GetBucket("default")
if err != nil {
log.Fatalf("Error getting bucket: %v", err)
}
bucket.Set("someKey", 0, []string{"an", "example", "list"})