本文整理匯總了Golang中github.com/couchbase/gocb.Connect函數的典型用法代碼示例。如果您正苦於以下問題:Golang Connect函數的具體用法?Golang Connect怎麽用?Golang Connect使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了Connect函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: main
func main() {
// Connect to Cluster
cluster, err := gocb.Connect("couchbase://127.0.0.1")
if err != nil {
fmt.Println("ERRROR CONNECTING TO CLUSTER:", err)
}
// Open Bucket
bucket, err = cluster.OpenBucket("travel-sample", "")
if err != nil {
fmt.Println("ERRROR OPENING BUCKET:", err)
}
// Setup a new query with a placeholder
myQuery := gocb.NewN1qlQuery("SELECT airportname, city, country FROM `travel-sample` " +
"WHERE type='airport' AND city=$1 ")
// Setup an array for parameters
var myParams []interface{}
myParams = append(myParams, "Reno")
// Execute Query
rows, err := bucket.ExecuteN1qlQuery(myQuery, myParams)
if err != nil {
fmt.Println("ERROR EXECUTING N1QL QUERY:", err)
}
// Iterate through rows and print output
var row interface{}
for rows.Next(&row) {
fmt.Printf("Results: %+v\n", row)
}
// Exiting
fmt.Println("Example Successful - Exiting")
}
示例2: main
func main() {
// Connect to Cluster
cluster, err := gocb.Connect("couchbase://127.0.0.1")
if err != nil {
fmt.Println("ERRROR CONNECTING TO CLUSTER:", err)
}
// Open Bucket
bucket, err = cluster.OpenBucket("travel-sample", "")
if err != nil {
fmt.Println("ERRROR OPENING BUCKET:", err)
}
// Create a document
key := "goDevguideExampleRetrieve"
val := "Retrieve Test Value"
_, err = bucket.Upsert(key, &val, 0)
if err != nil {
fmt.Println("ERRROR CREATING DOCUMENT:", err)
}
// Retrieve Document
var retValue interface{}
_, err = bucket.Get(key, &retValue)
if err != nil {
fmt.Println("ERRROR RETURNING DOCUMENT:", err)
}
fmt.Println("Document Retrieved:", retValue)
// Exiting
fmt.Println("Example Successful - Exiting")
}
示例3: main
func main() {
// Connect to Cluster
cluster, err := gocb.Connect("couchbase://127.0.0.1")
if err != nil {
fmt.Println("ERRROR CONNECTING TO CLUSTER:", err)
}
// Open Bucket
bucket, err = cluster.OpenBucket("travel-sample", "")
if err != nil {
fmt.Println("ERRROR OPENING BUCKET:", err)
}
// Setup a new query for building an index
myQuery := gocb.NewN1qlQuery("CREATE PRIMARY INDEX ON `travel-sample`")
rows, err := bucket.ExecuteN1qlQuery(myQuery, nil)
if err != nil {
fmt.Println("ERROR EXECUTING N1QL QUERY:", err)
}
// Iterate through rows and print output
var row interface{}
for rows.Next(&row) {
fmt.Printf("Results: %+v\n", row)
}
// Exiting
fmt.Println("Example Successful - Exiting")
}
示例4: userById
// userById attempts to return a JSON response for the supplied userid
// couchbase errors are handled in the handleError middleware method
func userById(c *gin.Context) {
myCluster, _ := gocb.Connect("couchbase://localhost")
myBucket, _ := myCluster.OpenBucket("gamesim-sample", "")
var value interface{}
_, err := myBucket.Get(c.Params.ByName("userid"), &value)
if err != nil {
c.Error(err).SetType(gin.ErrorTypePublic)
} else {
c.JSON(http.StatusOK, &value)
}
}
示例5: main
func main() {
// Connect to Cluster
cluster, err := gocb.Connect("couchbase://127.0.0.1")
if err != nil {
fmt.Println("ERRROR CONNECTING TO CLUSTER:", err)
}
// Open Bucket
bucket, err = cluster.OpenBucket("travel-sample", "")
if err != nil {
fmt.Println("ERRROR OPENING BUCKET:", err)
}
// Create a JSON document
type Doc struct {
Item string `json:"item"`
}
key := "goDevguideExampleBulkInsert"
val := Doc{"A bulk insert test value"}
// Create Array of BulkOps for Insert, and one for Get
var items []gocb.BulkOp
var itemsGet []gocb.BulkOp
// Add 10 items to the array that will be performed as a bulk operation
for i := 0; i < 10; i++ {
items = append(items, &gocb.InsertOp{Key: key + "_" + strconv.Itoa(i), Value: &val})
}
// Perform the bulk operation to Insert
err = bucket.Do(items)
if err != nil {
fmt.Println("ERRROR PERFORMING BULK INSERT:", err)
}
// Retrieve 10 items to the array that will be performed as a bulk operation
for i := 0; i < 10; i++ {
itemsGet = append(itemsGet, &gocb.GetOp{Key: key + "_" + strconv.Itoa(i), Value: &Doc{}})
}
// Perform the bulk operation to Get
err = bucket.Do(itemsGet)
if err != nil {
fmt.Println("ERRROR PERFORMING BULK GET:", err)
}
// Print the output
for i := 0; i < len(itemsGet); i++ {
fmt.Println(itemsGet[i].(*gocb.GetOp).Key, itemsGet[i].(*gocb.GetOp).Value.(*Doc).Item)
}
// Exiting
fmt.Println("Example Successful - Exiting")
}
示例6: deleteBucket
func deleteBucket(host string, bucket string, t *testing.T, noErr bool) {
connection, err := gocb.Connect(host)
if err != nil {
t.Fatal("Unable to connect to cluster: " + err.Error())
}
manager := connection.Manager("Administrator", "password")
if err := manager.RemoveBucket(bucket); err != nil && !noErr {
t.Fatalf("Error deleting bucket %s", bucket)
}
}
示例7: main
func main() {
// Connect to Cluster
cluster, err := gocb.Connect("couchbase://127.0.0.1")
if err != nil {
fmt.Println("ERRROR CONNECTING TO CLUSTER:", err)
}
// Open Bucket
bucket, err = cluster.OpenBucket("travel-sample", "")
if err != nil {
fmt.Println("ERRROR OPENING BUCKET:", err)
}
fmt.Println("Example Successful - Exiting")
}
示例8: NewGoCBStorageEngine
func NewGoCBStorageEngine(couchbaseUrl, bucketName string) *GoCBStorageEngine {
cluster, err := gocb.Connect(couchbaseUrl)
if err != nil {
log.Panicf("Could not connect to %v. Err: %v", couchbaseUrl, err)
}
bucket, err := cluster.OpenBucket(bucketName, "")
if err != nil {
log.Panicf("Could not open bucket: %v. Err: %v", bucket, err)
}
return &GoCBStorageEngine{
Bucket: bucket,
}
}
示例9: newGoCbClient
func newGoCbClient(serverURL string, bucketName string) *goCbClient {
cluster, err := gocb.Connect(serverURL)
if err != nil {
log.Fatalf("Could not connect to %v. Err: %v", serverURL, err)
}
bucket, err := cluster.OpenBucket(bucketName, "")
if err != nil {
log.Fatalf("Could not open bucket: %v. Err: %v", bucketName, err)
}
return &goCbClient{
bucket: bucket,
}
}
示例10: userList
// userlist queries the playerlist view from the gamesim bucket and returns
// a JSON response containing all documents returned by the view
func userList(c *gin.Context) {
myCluster, _ := gocb.Connect("couchbase://localhost")
myBucket, _ := myCluster.OpenBucket("gamesim-sample", "")
myQuery := gocb.NewViewQuery("players", "playerlist")
rows := myBucket.ExecuteViewQuery(myQuery)
var results = make([]map[string]interface{}, 0)
var row interface{}
for rows.Next(&row) {
results = append(results, row.(map[string]interface{}))
}
c.JSON(http.StatusOK, &results)
}
示例11: main
func main() {
// Cluster connection and bucket for couchbase
cluster, _ := gocb.Connect("couchbase://127.0.0.1")
bucket, _ = cluster.OpenBucket("travel-sample", "")
// Http Routing
http.Handle("/", http.FileServer(http.Dir("./static")))
http.HandleFunc("/api/airport/findAll", airportHandler)
http.HandleFunc("/api/flightPath/findAll", flightPathHandler)
http.HandleFunc("/api/user/login", loginHandler)
http.HandleFunc("/api/user/flights", userFlightsHandler)
fmt.Printf("Starting server on :3000\n")
http.ListenAndServe(":3000", nil)
}
示例12: main
func main() {
// Connect to Cluster
cluster, err := gocb.Connect("couchbase://127.0.0.1")
if err != nil {
fmt.Println("ERRROR CONNECTING TO CLUSTER:", err)
}
// Open Bucket
bucket, err = cluster.OpenBucket("travel-sample", "")
if err != nil {
fmt.Println("ERRROR OPENING BUCKET:", err)
}
// Create a document
key := "goDevguideExampleUpdate"
val := "Retrieve Test Value"
_, err = bucket.Upsert(key, &val, 0)
if err != nil {
fmt.Println("ERRROR CREATING DOCUMENT:", err)
}
// Retrieve Document
var retValue interface{}
_, err = bucket.Get(key, &retValue)
if err != nil {
fmt.Println("ERRROR RETURNING DOCUMENT:", err)
}
fmt.Println("Document Retrieved:", retValue)
// Add something to the value
retValue = retValue.(string) + " with Additional Test Value"
// Replace the existing document
_, err = bucket.Replace(key, &retValue, 0, 0)
if err != nil {
fmt.Println("ERRROR REPLACING DOCUMENT:", err)
}
// Retrieve updated document
_, err = bucket.Get(key, &retValue)
if err != nil {
fmt.Println("ERRROR RETURNING DOCUMENT:", err)
}
fmt.Println("Document Retrieved:", retValue)
// Exiting
fmt.Println("Example Successful - Exiting")
}
示例13: deleteAllBuckets
func deleteAllBuckets(host string, t *testing.T) {
connection, err := gocb.Connect(host)
if err != nil {
t.Fatal("Unable to connect to cluster: " + err.Error())
}
manager := connection.Manager("Administrator", "password")
buckets, err := manager.GetBuckets()
if err != nil {
t.Fatal("Unable to get all buckets: " + err.Error())
}
for _, bucket := range buckets {
if err := manager.RemoveBucket(bucket.Name); err != nil {
t.Fatalf("Error deleting bucket %s", bucket.Name)
}
}
}
示例14: IndexHandler
func IndexHandler(w http.ResponseWriter, r *http.Request) {
cluster, _ := gocb.Connect("couchbase://localhost")
bucket, _ := cluster.OpenBucket("default", "")
value := "test"
cas, _ := bucket.Insert("snake", &value, 0)
fmt.Printf("Inserted document CAS is `%08x`\n", cas)
snake := lib.Snake{
Points: lib.Points{
lib.Point{
X: 1,
Y: 2,
},
},
}
json.NewEncoder(w).Encode(snake)
}
示例15: GetCouchbaseBucketGoCB
// Creates a Bucket that talks to a real live Couchbase server.
func GetCouchbaseBucketGoCB(spec BucketSpec) (bucket Bucket, err error) {
// Only wrap the gocb logging when the log key is set, to avoid the overhead of a log keys
// map lookup for every gocb log call
logKeys := GetLogKeys()
if logKeys["gocb"] {
EnableGoCBLogging()
}
cluster, err := gocb.Connect(spec.Server)
if err != nil {
return nil, err
}
password := ""
if spec.Auth != nil {
_, password, _ = spec.Auth.GetCredentials()
}
goCBBucket, err := cluster.OpenBucket(spec.BucketName, password)
if err != nil {
return nil, err
}
spec.MaxNumRetries = 10
spec.InitialRetrySleepTimeMS = 5
// Define channels to limit the number of concurrent single and bulk operations,
// to avoid gocb queue overflow issues
bucket = CouchbaseBucketGoCB{
goCBBucket,
spec,
make(chan struct{}, MaxConcurrentSingleOps),
make(chan struct{}, MaxConcurrentBulkOps),
}
return bucket, err
}