• 从零开始 MongoDB 集群(ReplSet)搭建 之一 MongoDB的安装


    从零开始 MongoDB 集群(ReplSet)搭建 之一 MongoDB的安装
    从零开始 MongoDB 集群(ReplSet)搭建 之二 群集搭建

    前言

    本文只是根据个人经验介绍在搭建集群过程中遇到的坑和需要理解的内容,经过多次尝试,总结的结论,可能这些结论也不一定是对的,但目前是好使的。如果有经验的高手看到了,欢迎指正。
    

    MongoDB的基本概念

    MongoDB 是非关系型数据库,所以在概念跟操作上有些跟传统的关系型数据库有区别。
    下面列一个表。来区分关系型跟非关系型的关系和区别:

    概念 关系型 非关系型
    数据库 database db
    table collection
    row document
    字段 field field

    MongoDB链接方式

    可以使用

        mongodb://[username:password@]host1[:port1][/[database][?options]]
        eg:
            mongodb://127.0.0.1:27021
            mongodb://root:123@127.0.0.1
            mongodb://root:123@127.0.0.1:30000/students
            mongodb://root:123@127.0.0.1:30000/students?connectTimeoutMS=3000
    
    

    options可以写的内容:

    选项 描述
    replicaSet=name 验证replica set的名称。 Impliesconnect=replicaSet.
    slaveOk=true or false true:在connect=direct模式下,驱动会连接第一台机器,即使这台服务器不是主。在connect=replicaSet模式下,驱动会发送所有的写请求到主并且把读取操作分布在其他从服务器。false: 在 connect=direct模式下,驱动会自动找寻主服务器. 在connect=replicaSet 模式下,驱动仅仅连接主服务器,并且所有的读写命令都连接到主服务器。
    safe=true or false true: 在执行更新操作之后,驱动都会发送getLastError命令来确保更新成功。(还要参考 wtimeoutMS). false: 在每次更新之后,驱动不会发送getLastError来确保更新成功。
    w=n 驱动添加 { w : n } 到getLastError命令. 应用于safe=true。
    wtimeoutMS=ms 驱动添加 { wtimeout : ms } 到 getlasterror 命令. 应用于 safe=true.
    fsync=true or false true: 驱动添加 { fsync : true } 到 getlasterror 命令.应用于 safe=true.false: 驱动不会添加到getLastError命令中。
    journal=true or false 如果设置为 true, 同步到 journal (在提交到数据库前写入到实体中). 应用于 safe=true
    connectTimeoutMS=ms 可以打开连接的时间。
    socketTimeoutMS=ms 发送和接受sockets的时间。

    安装MongoDB

    具体操作步骤可以参考:

    1. 请参考 Windows 平台安装 MongoDB
    2. 请参考 Linux平台安装MongoDB

    我用的是windows平台,运行MongoDB的方式有两种:

    1. 程序运行方式
    2. 服务运行方式 (个人倾向于服务方式安装)

    程序方式运行

        mongod --config arbiter.cfg
    

    结果如图:

    image

    光标会一直闪。
    arbiter.cfg 配置如下:

       #arbiter.conf    
       dbpath=D:\MongoDBCluster\Test\shard0_arbiter\data
       logpath=D:\MongoDBCluster\Test\shard0_arbiter\log\shard0_arbiter.log    
       pidfilepath=D:\MongoDBCluster\Test\shard0_arbiter\shard0_arbiter.pid    
       directoryperdb=true    
       logappend=true   
       port=27017   
       bind_ip=127.0.0.1
    

    通过 MongoDBCompass 链接测试,结果如图:

    image

    可以看到图中 CLUSTER : Standalone,后面会有对比。

    服务方式运行

    服务方式运行就是在系统中安装一个mongodb的服务,随着系统的启动,它会自动运行,以下面的代码为例:

        mongod --dbpath /var/lib/mongo --logpath /var/log/mongodb/mongod.log --fork
    

    这明显是linux 安装方式,这里指定了 dbpath 也就是数据存放路径,logpath 日志存放路径。 fork 守护进程的方式运行。等同于 windows 的:

        mongod --dbpath d:\mongodb\data --logpath d:\mongodb\log\mongodb_log.log --install
    

    这里需要重点强调的是logpath,dbpath 这里必须指定的是绝对路径,logpath 必须是文件名称而不是目录。
    不管是那种方式,程序都会根据我们设置的参数进行安装,所以了解参数很有必要。最后来看看配置文件:

        #数据库文件路径
        dbpath=d:/MongoDBCluster/primary/Data
        #日志文件路径,日志文件不需要先创建
        logpath=d:/MongoDBCluster/primary/Log/primary.log    
        #pid文件路径
        pidfilepath=d:/MongoDBCluster/primary/primary.pid     
        #这个还没搞清楚
        directoryperdb=true    
        # 日志是否追加写入,如果不追加,则会创建多个日志文件。
        logappend=true    
        # 集群名称
        #replSet=testrs
        #端口    
        port=27018
        #IP地址   
        bind_ip=127.0.0.1
    

    这些配置文件,无论你放在什么地方都可以,但建议放到 Bin目录上一级目录下。后缀名称为cfg,实际上你命名为ini,txt,conf都可以。
    如果文件创建好了可以使用,以下命令安装服务:

        mongod --config d:\mongodb\primary.cfg --install
    

    当然还可以指定服务名称,如:

        mongod --config d:\mongodb\primary.cfg --servceName "mongodb_replset_shard01" --serviceDisplayName "mgonodb replset shard 01" --install
    

    这里指定了 serviceNameserviceDisplayName 其作用可以到服务管理器去看看就明白了

    以上这些参数都放到了配置文件中,也可以以命令参数的形式运行,转换过来就是:

    mongod --port 27018 --bind_ip 127.0.0.1 --dbpath d:\mongodb\data --logpath d:\mongodb\log\mongodb_log.log --pidfilepath d:/MongoDBCluster/primary/primary.pid --logappend --serviceDisplayName "mgonodb replset shard 01" --install
    

    logappend 的值是true 和false 这里直接把参数打出来就是true了否则就是false。

    服务安装成功后,可以打开服务管理器,看到新建的服务。

    启动服务即可。

  • 相关阅读:
    Web Storage
    You don't know js
    vue—你必须知道的
    js数据类型
    Python基础 — Matplotlib
    Python基础 — Pandas
    MySQL基础 — 常用命令
    MySQL基础 — 详细安装
    Python机器学习算法 — 支持向量机(SVM)
    Python机器学习算法 — 逻辑回归(Logistic Regression)
  • 原文地址:https://www.cnblogs.com/LearningC/p/16017843.html
Copyright © 2020-2023  润新知