duanpuchen3142 2017-05-26 07:36
浏览 76
已采纳

是否可以使用mgo驱动程序运行mongo复制集命令?

Is it possible to run replica set commands like rs.initiate() and rs.add() using mgo driver from a golang application?

If yes, how??

  • 写回答

2条回答 默认 最新

  • dongtaihui5131 2017-06-03 09:20
    关注

    Thanks to @alex-blex's answer which gave me the start. But this is what finally worked for me:

    session, err := mgo.Dial("rs1.example.net?connect=direct")
    if err != nil {
        panic(err)
    }
    defer session.Close()
    session.SetMode(mgo.Monotonic, true)
    
    config := bson.M{
        "_id": "my_replica_set",
        "members": []bson.M{
            {"_id": 0, "host": "rs1.example.net:27017"},
            {"_id": 1, "host": "rs2.example.net:27017", "priority": 2},
            {"_id": 2, "host": "rs3.example.net", "arbiterOnly": true},
        },
    }
    result := bson.M{}
    if err := session.Run(bson.M{"replSetInitiate": config}, &result); err != nil {
        panic(err)
    }
    

    Notice the following:

    1. ?connect=direct in the connection string.

      If not specified, the connection will timeout, probably because the replica set has not been initialized yet.

    2. session.SetMode(mgo.Monotonic, true)

      Session mode should be monotonic as the default session used by mgo is primary which performs all operations on primary. Since the replica set has not been initialized yet, there wont be a primary and the operation (in this case, replSetInitiate) will just timeout

    3. "_id": "my_replica_set" in the config

      For this to work, the mongo servers will have to be started with the replica set name my_replica_set. One way of doing that would be:

      mongod --replSet my_replica_set
      
    4. As per Mgo docs use session.Run() for commands on the "admin" database
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码