首先在/etc/yum.repos.d/下面创建仓库文件。这里是安装4.0
[root@izuf693wyms6h7ot360phcz yum.repos.d]# vim mongodb-org-4.0.repo
[mongodb-org-4.0]
name=MongoDB Repository
baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/4.0/x86_64/
gpgcheck=0
enabled=1
gpgkey=https://www.mongodb.org/static/pgp/server-4.0.asc
~
然后 yum install
[root@izuf693wyms6h7ot360phcz yum.repos.d]# yum install mongodb-org
启动,停止,查看状态:
启动mongodb :systemctl start mongod.service
停止mongodb :systemctl stop mongod.service
查到mongodb的状态:systemctl status mongod.service
默认端口 27017
golang 访问mongodb
import (
"context"
"github.com/mongodb/mongo-go-driver/mongo"
"net/url"
"fmt"
)
func main(){
connectString := "mongodb://127.0.0.1/test"
dbUrl, err := url.Parse(connectString)
if err != nil {
panic(err)
}
//认证参数设置,否则连不上
opts := &options.ClientOptions{}
opts.SetAuth(options.Credential{
AuthMechanism:"SCRAM-SHA-1",
AuthSource:"test",
Username:"test",
Password:"123456"})
client, err = mongo.Connect(context.Background(), connectString,opts)
if err != nil {
panic(err)
}
db := client.Database(dbUrl.Path[1:])
ctx := context.Background()
defer db.Client().Disconnect(ctx)
col := db.Collection("test")
//先在事务外写一条id为“111”的记录
_,err = col.InsertOne(ctx, bson.M{"_id": "111", "name": "ddd", "age": 50})
if(err != nil){
fmt.Println(err)
return
}
//第一个事务:成功执行
db.Client().UseSession(ctx, func(sessionContext mongo.SessionContext) error {
err = sessionContext.StartTransaction()
if(err != nil){
fmt.Println(err)
return err
}
//在事务内写一条id为“222”的记录
_, err = col.InsertOne(sessionContext, bson.M{"_id": "222", "name": "ddd", "age": 50})
if(err != nil){
fmt.Println(err)
return err
}
//在事务内写一条id为“333”的记录
_, err = col.InsertOne(sessionContext, bson.M{"_id": "333", "name": "ddd", "age": 50})
if err != nil {
sessionContext.AbortTransaction(sessionContext)
return err
}else {
sessionContext.CommitTransaction(sessionContext)
}
return nil
})
//第二个事务:执行失败,事务没提交,因最后插入了一条重复id "111",
err = db.Client().UseSession(ctx, func(sessionContext mongo.SessionContext) error {
err := sessionContext.StartTransaction()
if(err != nil){
fmt.Println(err)
return err
}
//在事务内写一条id为“222”的记录
_, err = col.InsertOne(sessionContext, bson.M{"_id": "444", "name": "ddd", "age": 50})
if(err != nil){
fmt.Println(err)
return err
}
//写重复id
_, err = col.InsertOne(sessionContext, bson.M{"_id": "111", "name": "ddd", "age": 50})
if err != nil {
sessionContext.AbortTransaction(sessionContext)
return err
}else {
sessionContext.CommitTransaction(sessionContext)
}
return nil
})
}
//最终数据只有 "111","222","333" 三条,事务测试成功。
---------------------
作者:sdghchj
来源:CSDN
原文:https://blog.csdn.net/sdghchj/article/details/85249392
版权声明:本文为博主原创文章,转载请附上博文链接!
网友评论