精华内容
下载资源
问答
  • 【Docker】解决创建Redis容器没有conf配置文件

    万次阅读 多人点赞 2019-09-08 23:33:49
    创建容器 2. 解读参数 -d:后台运行容器,并返回容器ID; -i:以交互模式运行容器,通常与 -t 同时使用; -p:端口映射,格式为:主机(宿主)端口:容器端口 -t:为容器重新分配一个伪输入终端,通常与 -i 同时...

    序言

    这篇文章没有什么知识点,只是为了新伙伴少踩点坑

    1. 问题重现

    1. 创建容器

    2. 解读参数

    -d: 后台运行容器,并返回容器ID;

    -i: 以交互模式运行容器,通常与 -t 同时使用;

    -p: 端口映射,格式为:主机(宿主)端口:容器端口

    -t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用;

    --ip: 为容器制定一个固定的ip

    --net: 指定网络模式

    3. 进入容器查看redis.conf文件

    发现是并没有redis.conf文件的,那么这个时候就是新手踩坑阶段了,因为没有系统的学习docker所以会花费很多时间

    2. 解决问题

    没有配置文件这件事呢!那是因为redis容器里边的配置文件是需要在创建容器时映射进来的

    那么就需要删除我们之前创建好的容器,在删除前需要先停止容器后才可以删除

    停止容器:docker container stop redis-test

    删除容器:docker container rm redis-test

    1. 开始重新创建redis容器

    docker run -itd  --name  redis-slave  -v /usr/local/redis/redis.conf:/etc/redis.conf -v /root/usr/local/redis/data:/data  --net mynetwork  -p 6381:6379  --ip 172.10.0.3  redis

    参数解释:

    -v /usr/local/redis/redis.conf:/etc/redis.conf:映射配置文件

    -v /root/usr/local/redis/data:/data:映射数据目录

    那么这个时候就有redis配置文件了

    搭建同意的挂载外部配置

    上边是在我宿主机有redis的情况下的,那么下来说宿主机没有redis的情况

    这里说的映射其实就是挂载外部配置和数据安装

    1. 创建docker统一的外部配置文件

    mkdir -p docker/redis/{conf,data}

    2. 在conf目录创建redis.conf的配置文件

    touch /docker/redis/conf/redis.conf

    3. redis.conf文件的内容需要自行去下载,网上很多

    4. 创建启动容器,加载配置文件并持久化数据

    docker run -d --privileged=true -p 6379:6379 -v /docker/redis/conf/redis.conf:/etc/redis/redis.conf -v /docker/redis/data:/data --name redis-test redis redis-server /etc/redis/redis.conf --appendonly yes

    参数说明:

    --privileged=true:容器内的root拥有真正root权限,否则容器内root只是外部普通用户权限

    -v /docker/redis/conf/redis.conf:/etc/redis/redis.conf:映射配置文件

    -v /docker/redis/data:/data:映射数据目录

    redis-server /etc/redis/redis.conf:指定配置文件启动redis-server进程

    --appendonly yes:开启数据持久化

    这里边还有一些概念新手可能会很模糊,后边会进行详解,先知道这么用就好了,深夜了,大家晚安!

    展开全文
  • rsyncd.conf配置文件

    千次阅读 2013-06-16 18:01:51
    rsyncd.conf配置文件  2011-06-16 22:18:44| 分类: 文件同步 | 标签:rsync的配置  |字号 订阅 1.rsyncd.conf配置文件  1.1 全局参数  在[moudle]之前的参数都是全局参数,也可以在...

    rsyncd.conf配置文件  

    2011-06-16 22:18:44|  分类: 文件同步 |  标签:rsync的配置   |字号 订阅

    1.rsyncd.conf配置文件
           1.1 全局参数
                在[moudle]之前的参数都是全局参数,也可以在全局参数下定义部分模块参数,这时该参数的值就是所有模块的默认值。

                 port:指定后台程序使用的端口号,默认是873

     


                 log file:指定rsync的日志文件,而不把日志发送给syslog

     


                 pid file:指定rsync的pid文件,通常指定为/var/run/rsyncd.pid

                 motd file:用来指定一个消息文件,当客户连接服务器时,将该文件内容显示给客户,默认是没有该文件的

           1.2模块参数
                 主要定义服务器哪个目录需要被同步。其格式必须为[moudle]形式,这个名字是在rsync客户端看到的名字,而服务器真正同步的数据是通过path来指定的,我们可以通过根据自己的需要,来指定多个模块,模块中可以定义以下参数:       

                  comment:给模块指定一个描述,该描述连同模块名在客户连接得到模块列表时显示给客户,默认是没有描述定义

                  path:指定该模块的供备份的目录树路径,该参数是必须指定的

        use chroot:如果“use chroot”指定为true,那么rsync在传输文件以前首先chroot到path参数所指定的目录下。这样做的原因是实现额外的安全防护,但是缺点是需要root权限,并且不能备份指向外部的符号连接所指向的目录文件,默认情况下chroot的值为true

     

        uid:该选项指定当该模块传输文件时守护进程应该具有的uid,配合gid选项使用可以确定哪些可以访问怎么样的文件权限,默认值是“nobody”

     

        gid:该选项指定当该模块传输文件时守护进程应该具有的gid,默认值是“nobody”

     

       max connections:指定该模块的最大并发连接数量以保护服务器,超过限制的连接请求被告知随后再试。默认值是0,也就是没有限制。

     

       list:该选项设定当客户请求可以使用的模块列表时,该模块是否应该被列出。如果该选项设置为false,可以创建隐藏的模块,默认值为true。

     

       read only:该选项设定是否允许客户上载文件,如果为true那么所有的上载请求都会失败,如果为false并且服务器目录读写权限允许那么上载是允许的,默认值为true。

     

       exclude:用来指定多个空格隔开的多个文件或目录(相对路径),并将其添加到exclude列表中,这等同于在客户端的命令中使用-exclude来指定模式,一个模块只能指定一个exclude选项,但是需要注意的一点是该选项有一定的安全性问题,客户很有可能绕过exclude列表,如果希望保持特定的文件不能被访问,那就最好结合uid/gid一起使用。

     

      exclude from:指定一个包含exclude模式的定义的文件名,服务器从该文件中读取exclude列表定义

     

    include :用来指定不排除符合要求的文件或目录,这等同于在客户端命令中使用-include来指定模式,结合include和exclude可以定义复杂的exclude/include规则

     

    include from:指定一个包含include模式的定义的文件名,服务器从该文件中读取include列表定义。

     

    auth users:该选项指定由空格或逗号分隔的用户列表,只有这些用户才允许连接该模块,这里的用户和系统用户没有任何关系,如果“auth users”被设置,那么客户端发出对该模块的连接请求以后会被rsync请求challenged进行验证身份,这里使用的challenge/response认证协议,用户的名和密码以明文方式存放在“secret file”选项指定的文件中,默认情况下无需密码就可以连接模块,也就是匿名模式

     

    secrets file:该选项指定一个包含定义用户名:密码对的文件,只有在“auth users”被定义的时候,该文件才有作用,文件每行包含一个username:passwd对。一般来说密码最好不要超过8个字符。没有默认的secures file名,需要限式指定一个(例如:/etc/rsyncd.passwd)。注意:该文件的权限一定要是600,否则客户端将不能连接服务器。

     

    stick modes:该选项指定是否监测密码文件的权限,如果该选项值为true,那么密码文件只能被rsync服务器运行身份的用户访问,其他任何用户不能访问该文件,默认值为true

     

               hosts allow: 该选项指定哪些IP的客户允许连接该模块。客户模式定义可以是以下形式:

        单个IP地址,例如:192.167.0.1

        整个网段,例如:192.168.0.0/24,也可以是192.168.0.0/255.255.255.0

      多个IP或网段需要用空格隔开,“*”则表示所有,默认是允许所有主机连接。 

     

    hosts deny: 指定不允许连接rsync服务器的机器,可以使用hosts allow的定义方式来进行定义。默认是没有hosts deny定义。

     

    ignore errors: 指定rsyncd在判断是否运行传输时的删除操作时忽略server上的IO错误,一般来说rsync在出现IO错误时将将跳过–delete操作,以防止因为暂时的资源不足或其它IO错误导致的严重问题。

     

    ignore nonreadable:指定rsync服务器完全忽略那些用户没有访问权限的文件,这对于在需要备份的目录中有些文件所不应该被备份者得到的情况下是有意义的

     

    lock file 指定支持max connections参数的锁文件,默认值是/var/run/rsyncd.lock。

     

    transfer logging 使rsync服务器使用ftp格式的文件来记录下载和上载操作在自己单独的日志中。

     

    timeout 通过该选项可以覆盖客户指定的IP超时时间。通过该选项可以确保rsync服务器不会永远等待一个崩溃的客户端。超时单位为秒钟,0表示没有超时定义,这也是默认值。对于匿名rsync服务器来说,一个理想的数字是600。

     

    refuse options 通过该选项可以定义一些不允许客户对该模块使用的命令参数列表。这里必须使用命令全名,而不能是简称。但发生拒绝某个命令的情况时服务器将报告错误信息然后退出。如果要防止使用压缩,应该是:” dont compress = *” 。

     

    dont compress 用来指定那些不进行压缩处理再传输的文件,默认值是*.gz *.tgz *.zip *.z *.rpm *.deb *.iso *.bz2 *.tbz

     

    2.Rsync命令
                     在对rsync服务器配置结束以后,下一步就需要在客户端发出rsync命令来实现将服务器端的文件备份到客户端来。rsync是一个功能非常强大的工具,其命令也有很多功能特色选项,我们下面就对它的选项一一进行分析说明。

                     Rsync的命令格式可以为以下六种:

      rsync [OPTION]… SRC DEST

      rsync [OPTION]… SRC [USER@]HOST:DEST

      rsync [OPTION]… [USER@]HOST:SRC DEST

      rsync [OPTION]… [USER@]HOST::SRC DEST

      rsync [OPTION]… SRC [USER@]HOST::DEST

      rsync [OPTION]… rsync://[USER@]HOST[:PORT]/SRC [DEST] 

            1)拷贝本地文件:当SRC和DEST路径信息都不包括单个冒好“:”分隔符时就启动这种工作模式,如:rsync -a /data /backup

            2)使用一个远程的shell程序(如rsh,ssh)来实现将本地机器的内容拷贝到远程机器。当DEST路径包括单个冒号“:”分隔符,就启动这种工作模式,如:rsync -avz *.c foo:src

            3)使用一个远程的shell程序(如rsh,ssh)来实现将远程机器的内容拷贝到本地机器。当SRC路径包含单个冒号“:” 分隔符,就器送这种工作模式,如:rsync -avz foo:src/bar /backup

            4)从远程rsync服务器中拷贝文件到本地机。当SRC路径信息包含” ::” 分隔符时启动该模式。如:rsync -av root@172.16.78.192::www /databack

            5)从本地机器拷贝文件到远程rsync服务器中。当DST路径信息包含” ::” 分隔符时启动该模式。如:rsync -av /databack root@172.16.78.192::www

            6)列远程机的文件列表。这类似于rsync传输,不过只要在命令中省略掉本地机信息即可。如:rsync -v rsync://172.16.78.192/www     

     

    rsync参数的具体解释如下:

      -v, –verbose 详细模式输出
      -q, –quiet 精简输出模式
      -c, –checksum 打开校验开关,强制对文件传输进行校验
      -a, –archive 归档模式,表示以递归方式传输文件,并保持所有文件属性,等于-rlptgoD
      -r, –recursive 对子目录以递归模式处理
      -R, –relative 使用相对路径信息
      -b, –backup 创建备份,也就是对于目的已经存在有同样的文件名时,将老的文件重新命名为~filename。可以使用–suffix选项来指定不同的备份文件前缀。
      –backup-dir 将备份文件(如~filename)存放在在目录下。
      -suffix=SUFFIX 定义备份文件前缀
      -u, –update 仅仅进行更新,也就是跳过所有已经存在于DST,并且文件时间晚于要备份的文件。(不覆盖更新的文件)
      -l, –links 保留软链结
      -L, –copy-links 想对待常规文件一样处理软链结
      –copy-unsafe-links 仅仅拷贝指向SRC路径目录树以外的链结
      –safe-links 忽略指向SRC路径目录树以外的链结
      -H, –hard-links 保留硬链结
      -p, –perms 保持文件权限
      -o, –owner 保持文件属主信息
      -g, –group 保持文件属组信息
      -D, –devices 保持设备文件信息
      -t, –times 保持文件时间信息
      -S, –sparse 对稀疏文件进行特殊处理以节省DST的空间
      -n, –dry-run现实哪些文件将被传输
      -W, –whole-file 拷贝文件,不进行增量检测
      -x, –one-file-system 不要跨越文件系统边界
      -B, –block-size=SIZE 检验算法使用的块尺寸,默认是700字节
      -e, –rsh=COMMAND 指定使用rsh、ssh方式进行数据同步
      –rsync-path=PATH 指定远程服务器上的rsync命令所在路径信息
      -C, –cvs-exclude 使用和CVS一样的方法自动忽略文件,用来排除那些不希望传输的文件
      –existing 仅仅更新那些已经存在于DST的文件,而不备份那些新创建的文件
      –delete 删除那些DST中SRC没有的文件
      –delete-excluded 同样删除接收端那些被该选项指定排除的文件
      –delete-after 传输结束以后再删除
      –ignore-errors 及时出现IO错误也进行删除
      –max-delete=NUM 最多删除NUM个文件
      –partial 保留那些因故没有完全传输的文件,以是加快随后的再次传输
      –force 强制删除目录,即使不为空
      –numeric-ids 不将数字的用户和组ID匹配为用户名和组名
      –timeout=TIME IP超时时间,单位为秒
      -I, –ignore-times 不跳过那些有同样的时间和长度的文件
      –size-only 当决定是否要备份文件时,仅仅察看文件大小而不考虑文件时间
      –modify-window=NUM 决定文件是否时间相同时使用的时间戳窗口,默认为0
      -T –temp-dir=DIR 在DIR中创建临时文件
      –compare-dest=DIR 同样比较DIR中的文件来决定是否需要备份
      -P 等同于 –partial
      –progress 显示备份过程
      -z, –compress 对备份的文件在传输时进行压缩处理
      –exclude=PATTERN 指定排除不需要传输的文件模式
      –include=PATTERN 指定不排除而需要传输的文件模式
      –exclude-from=FILE 排除FILE中指定模式的文件
      –include-from=FILE 不排除FILE指定模式匹配的文件
      –version 打印版本信息
      –address 绑定到特定的地址
      –config=FILE 指定其他的配置文件,不使用默认的rsyncd.conf文件
      –port=PORT 指定其他的rsync服务端口
      –blocking-io 对远程shell使用阻塞IO
      -stats 给出某些文件的传输状态
      –progress 在传输时现实传输过程
      –log-format=formAT 指定日志文件格式
      –password-file=FILE 从FILE中得到密码
      –bwlimit=KBPS 限制I/O带宽,KBytes per second
      -h, –help 显示帮助信息

    展开全文
  • 首先.conf配置文件可以放一些你想要访问/打开的文件路径,这样有变动直接在.conf文件改就可以了,不需要再去改代码 最简单的小例子: 先新建一个.conf配置文件和一个python文件 touch server.conf touch test.py ...
    1. 首先.conf配置文件可以放一些你想要访问/打开的文件路径,这样有变动直接在.conf文件改就可以了,不需要再去改代码
    2. 最简单的小例子:
      先新建一个.conf配置文件和一个python文件
    	touch server.conf
    	touch test.py
    

    在server.conf里放一个字典:

    {
    	"user" : "didi",
    	"age" : 5
    }
    

    接着打开test.py里应这样读取数据:

    with open("server.conf","r") as f:
    	info = f.read()
    dict_info = eval(info)
    

    eval是一个python自带的方法,可以自动识别改变文件类型,比如我们读取的info是一个string,但是这个info是用字典格式写的,eval(info)可以自动把info给我们转换成字典格式。

    在实际项目中,在访问一些特定的路径或者要给路径加前缀的时候就可以简单的运用到.conf了~

    展开全文
  • mongodb.conf配置文件详解

    万次阅读 2017-12-26 15:36:10
    启动MongoDB有2种方式,一是直接指定配置参数,二是指定配置文件。这里先介绍配置文件,启动方式如下: 1.mongod --config /etc/mongodb.conf 配置如下: verbose:日志信息冗余。默认false。提高内部报告...

    启动MongoDB有2种方式,一是直接指定配置参数,二是指定配置文件。这里先介绍配置文件,启动方式如下:

    1.mongod --config /etc/mongodb.conf

    配置如下:

    verbose:日志信息冗余。默认false。提高内部报告标准输出或记录到logpath配置的日志文件中。要启用verbose或启用verbosity 用vvvv参数,如:

    1.verbose = true
    2.vvvv = true

    ps:启动verbose冗长信息,它的级别有 vv~vvvvv,v越多级别越高,在日志文件中记录的信息越详细。

    port:端口。默认27017,MongoDB的默认服务TCP端口,监听客户端连接。要是端口设置小于1024,比如1021,则需要root权限启动,不能用mongodb帐号启动,(普通帐号即使是27017也起不来)否则报错:[mongo --port=1021 连接]

    1.ERROR: listen(): bind() failed errno:13 Permission denied for socket: 127.0.0.1:1021

    1.port = 27017

    bind_ip:绑定地址。默认127.0.0.1,只能通过本地连接。进程绑定和监听来自这个地址上的应用连接。要是需要给其他服务器连接,则需要注释掉这个或则把IP改成本机地址,如192.168.200.201[其他服务器用 mongo --host=192.168.200.201 连接] ,可以用一个逗号分隔的列表绑定多个IP地址。

    1.bind_ip = 127.0.0.1

    maxConns:最大连接数。默认值:取决于系统(即的ulimit和文件描述符)限制。MongoDB中不会限制其自身的连接。当设置大于系统的限制,则无效,以系统限制为准。这对于客户端创建很多“表”,允许连接超时而不关闭“表”的时候很有用。设置该值的高于连接池和总连接数的大小,以防止尖峰时候的连接。注意:不能设置该值大于20000。

    1.maxConns = 100

    objcheck:强制验证客户端请求。2.4的默认设置为objcheck成为true,在早期版本objcheck默认为false。因为它强制验证客户端请求,确保客户端绝不插入无效文件到数据库中。对于嵌套文档的对象,会有一点性能影响。设置noobjcheck 关闭。

    1.objcheck = true
    2.#noobjcheck = false

    noobjcheck:同上,默认关闭false。

    1.#noobjcheck = false

    logpath:指定日志文件,该文件将保存所有的日志记录、诊断信息。除非另有指定,mongod将所有的日志信息输出到标准输出。如果没有指定logappend,重启则日志会进行覆盖操作。

    1.logpath=/var/log/mongodb/mongodb.log

    logappend:写日志的模式:设置为true为追加。默认是覆盖。如果未指定此设置,启动时MongoDB的将覆盖现有的日志文件。

    1.logappend=true

    syslog:日志输出都发送到主机的syslog系统,而不是标准输出到logpath指定日志文件。syslog和logpath不能一起用,会报错:

    1.Cant use both a logpath and syslog

    1.syslog  = true

    pidfilepath:进程ID,没有指定则启动时候就没有PID文件。默认缺省。

    1.pidfilepath = /var/run/mongo.pid

    keyFile:指定存储身份验证信息的密钥文件的路径。默认缺省。详情见:"

    word-spacing: 0px; display: inline; white-space: normal; orphans: 2; widows: 2; font-size-adjust: none; font-stretch: normal; background-color: #ffffff; -webkit-text-size-adjust: auto; -webkit-text-stroke-width: 0px;">Replica Set Security" and “Replica Set Administration.”

    1.keyFile = /srv/mongodb/keyfile

    nounixsocket:套接字文件,默认为false,有生成socket文件。当设置为true时,不会生成socket文件。

    1.nounixsocket = false

    unixSocketPrefix:套接字文件路径,默认/tmp

    1.unixSocketPrefix = /tmp

    fork:是否后台运行,设置为true 启动 进程在后台运行的守护进程模式。默认false。

    1.fork = true

    auth:用户认证,默认false。不需要认证。当设置为true时候,进入数据库需要auth验证,当数据库里没有用户,则不需要验证也可以操作。直到创建了第一个用户,之后操作都需要验证。

    1.auth = true

    比如:通过db.addUser('sa','sa')  在admin库下面创建一个超级用户,只能在在admin库下面先认证完毕了:ab.auth('sa','sa') ,才能去别的库操作,不能在其他库验证。这样连接数据库也需要指定库:

    1.mongo -usa -psa admin     #sa 帐号连接admin

    1.mongo -uaa -paa test      #aa 帐号连接test

    noauth:禁止用户认证,默认true。同上

    1.noauth = true

    cpu:设置为true会强制mongodb每4s报告cpu利用率和io等待,把日志信息写到标准输出或日志文件。默认为false。

    1.cpu = true

    开启日志会出现:

    1.Mon Jun 10 10:21:42.241 [snapshotthread] cpu: elapsed:4000  writelock: 0%

    dbpath:数据存放目录。默认: word-spacing: 0px; white-space: normal; orphans: 2; widows: 2; font-size-adjust: none; font-stretch: normal; background-color: #ffffff; -webkit-text-size-adjust: auto; -webkit-text-stroke-width: 0px;">/data/db/

    1.dbpath=/var/lib/mongodb

    diaglog:创建一个非常详细的故障排除和各种错误的诊断日志记录。默认0。设置为1,为在dbpath目录里生成一个diaglog.开头的日志文件,他的值如下:

    1.Value    Setting
    2.0    off. No logging.       #关闭。没有记录。
    3.1    Log write operations.  #写操作
    4.2    Log read operations.   #读操作
    5.3    Log both read and write operations. #读写操作
    6.7    Log write and some read operations. #写和一些读操作

    设置不等于0,日志会每分钟flush 一次:

    1.Mon Jun 10 11:16:17.504 [DataFileSync] flushing diag log
    2.Mon Jun 10 11:17:17.442 [DataFileSync] flushing diag log

    产生的日志可以用mongosniff 来查看:要是mongosniff[类似于tcpdump的作为一个MongoDB的特定的TCP/ IP网络流量]出现报错和具体用法,请见这里,之前先执行:apt-get install libpcap-dev

    1.root@m3:/var/lib/mongodb# mongosniff --source DIAGLOG diaglog.51b542a9

    注意:当重新设置成0,会停止写入文件,但mongod还是继续保持打开该文件,即使它不再写入数据文件。如果你想重命名,移动或删除诊断日志,你必须完全关闭mongod实例。

    1.diaglog = 3

    directoryperdb:设置为true,修改数据目录存储模式,每个数据库的文件存储在DBPATH指定目录的不同的文件夹中。使用此选项,可以配置的MongoDB将数据存储在不同的磁盘设备上,以提高写入吞吐量或磁盘容量。默认为false。
    注意:要是在运行一段时间的数据库中,开启该参数,会导致原始的数据都会消失(注释参数则会回来)。因为数据目录都不同了,除非迁移现有的数据文件到directoryperdb产生的数据库目录中,如:
    root@m3:/var/lib/mongodb# mv test.* test/
    把test数据文件迁移到directoryperdb产生的数据库test目录中。 所以需要在规划好之后确定是否要开启。

    1.directoryperdb = ture

    01.原始数据结构:
    02.journal
    03.mongod.lock
    04.local.0
    05.local.1
    06.local.ns
    07.test.0
    08.test.1
    09.test.ns
    10.
    11.开启 directoryperdb,并把数据文件迁移到相关的数据目录后的结构:
    12.
    13.journal
    14.mongod.lock
    15.local/local.0
    16.local/local.1
    17.local/local.ns
    18.test/test.0
    19.test/test.1
    20.test/test.ns

    journal:日志,(redo log,更多的介绍请看这里和这里)
    默认值:(在64位系统)true。
    默认值:(32位系统)false。
    设置为true,启用操作日志,以确保写入持久性和数据的一致性,会在dbpath目录下创建journal目录。
    设置为false,以防止日志持久性的情况下,并不需要开销。为了减少磁盘上使用的日志的影响,您可以启用nojournal,并设置为true。
    注意:在64位系统上禁用日志必须使用带有nojournal的。

    1.#journal=true
    2.journal=false

    32位OS:

    1.Tue Jun 11 12:17:09.628 [initandlisten] ** NOTE: This is a 32 bit MongoDB binary.
    2.Tue Jun 11 12:17:09.628 [initandlisten] **       32 bit builds are limited to less than 2GB of data (or less with --journal).

    64位OS:

    1.Tue Jun 11 12:29:34 [initandlisten] journal dir=/var/lib/mongodb/journal
    2.Tue Jun 11 12:29:34 [initandlisten] recover : no journal files present, no recovery needed

    nojournal:禁止日志
    默认值:(在64位系统)false。
    默认值:(32位系统)true。
    设置nojournal为true关闭日志,64位,2.0版本后的mongodb默认是启用 journal日志。

    1.nojournal=true

    journalCommitInterval:刷写提交机制,默认是30ms或则100ms。较低的值,会更消耗磁盘的性能。
    此选项接受2和300毫秒之间的值:
    如果单块设备提供日志和数据文件,默认的日记提交时间间隔为100毫秒。
    如果不同的块设备提供的日志和数据文件,默认的日记提交的时间间隔为30毫秒。

    1.journalCommitInterval=100

    ipv6:是否支持ipv6,默认false。

    jsonp:是否允许JSONP访问通过一个HTTP接口,默认false。

    nohttpinterface:是否禁止http接口,即28017 端口开启的服务。默认false,支持。

    1.nohttpinterface = false

    noprealloc:预分配方式。
    默认false:使用预分配方式来保证写入性能的稳定,预分配在后台进行,并且每个预分配的文件都用0进行填充。这会让MongoDB始终保持额外的空间和空余的数据文件,从而避免了数据增长过快而带来的分配磁盘空间引起的阻塞。
    设置noprealloc= true来禁用预分配的数据文件,会缩短启动时间,但在正常操作过程中,可能会导致性能显著下降。

    1.noprealloc = false

    noscripting:是否禁止脚本引擎。默认是false:不禁止。ture:禁止
    要是设置成true:运行一些脚本的时候会出现:

    1.JavaScript execution failed: group command failed: { "ok" : 0, "errmsg" : "server-side JavaScript execution is disabled" }

    1.#noscripting = true     <====> noscripting = false

    notablescan:是否禁止表扫描操作。默认false:不禁止,ture:禁止

    禁止要是执行表扫描会出现:

    1.error: { "$err" : "table scans not allowed:test.emp", "code" : 10111 }

    可以动态修改设置:

    1.db.adminCommand({setParameter:1, notablescan:false})

    1.#notablescan = true  <====> notablescan = false

    nssize:命名空间的文件(即NS)的默认大小,默认16M,最大2G。
    所有新创建的默认大小命名空间的文件(即NS)。此选项不会影响现有的命名空间的文件的大小。默认值是16M字节,最大大小为2 GB。让小数据库不让浪费太多的磁盘空间,同时让大数据在磁盘上有连续的空间。

    1.-rwxrwxrwx 1 mongodb zhoujy  16M  6月 11 14:44 test.0
    2.-rwxrwxrwx 1 mongodb zhoujy  32M  6月  1 21:36 test.1
    3.-rwxrwxrwx 1 mongodb zhoujy  16M  6月 11 14:44 test.ns
    4.drwxr-xr-x 2 root    root   4.0K  6月 10 11:57 _tmp

    1.nssize  = 16

    profile:数据库分析等级设置。记录一些操作性能到标准输出或则指定的logpath的日志文件中,默认0:关闭。

    1.级别 设置
    2.0 关。无分析。
    3.1 开。仅包括慢操作。
    4.2 开。包括所有操作。

    控制 Profiling  的开关和级别:2种
    第一种是直接在启动参数里直接进行设置或则启动MongoDB时加上–profile=级别,其信息保存在 生成的system.profile 中。

    1.profile = 2

    第二种是在客户端用db.setProfilingLevel(级别)命令来实时配置,其信息保存在 生成的system.profile 中。

    1.[initandlisten] creating profile collection: local.system.profile

    1.> db.setProfilingLevel(2)
    2.{ "was" : 0, "slowms" : 100, "ok" : 1 }
    3.> db.getProfilingStatus()
    4.{ "was" : 2, "slowms" : 100 }

    默认情况下,mongod的禁用分析。数据库分析可以影响数据库的性能,因为分析器必须记录和处理所有的数据库操作。所以在需要的时候用动态修改就可以了。

    slowms:记录profile分析的慢查询的时间,默认是100毫秒。具体同上。

    1.slowms  = 200

    1.> db.getProfilingStatus()
    2.{ "was" : 2, "slowms" : 200 }

    quota:配额,默认false。是否开启配置每个数据库的最多文件数的限制。当为true则用quotaFiles来配置最多文件的数量。

    1.quota = true

    quotaFiles:配额数量。每个数据库的数据文件数量的限制。此选项需要quota为true。默认为8。

    1.quotaFiles = 8

    rest: 默认false,设置为true,使一个简单的 REST API。

    1.rest = true

    设置为true,开启后,在MongoDB默认会开启一个HTTP协议的端口提供REST的服务(nohttpinterface = false),这个端口是你Server端口加上1000,即28017,默认的HTTP端口是数据库状态页面,(开启后,web页面的Commands 行中的命令都可以点进去)。mongodb自带的REST,不支持 增、删、改,同时也不支持 权限认证。
    详细信息见这里和这里。
    repair:修复数据库操作,默认是false。
    设置为true时,启动后修复所有数据库,设置这个选项最好在命令行上,而不是在配置文件或控制脚本。如:
    命令行修复:

    1.> db.repairDatabase('xxx')
    2.{ "ok" : 1 }
    3.> db.repairDatabase()
    4.{ "ok" : 1 }

    启动时修复:

    1.repair = true

    1.root@m3:/var/log/mongodb# mongod --repair

    启动时修复,需要关闭journal,否则报错:

    1.Can't specify both --journal and --repair options.

    并且启动时,用控制文件指定参数和配置文件里指定参数的方式进行修复之后,(修复信息见log),需要再禁用repair参数才能启用mongodb。
    注意:mongod修复时,需要重写所有的数据库文件。如果在同一个帐号下不能运行修复,则需要运行chown修改数据库文件的权限。

    repairpath:修复路径,默认是在dbpath路径下的_tmp 目录。

    1.drwxr-xr-x 2 root    root   4.0K  6月 11 20:23 _tmp

    smallfiles:是否使用较小的默认文件。默认为false,不使用。
    设置为true,使用较小的默认数据文件大小。smallfiles减少数据文件的初始大小,并限制他们到512M,也减少了日志文件的大小,并限制他们到128M。
    如果数据库很大,各持有少量的数据,会导致mongodb创建很多文件,会影响性能。

    1.smallfiles = true

    syncdelay:刷写数据到日志的频率,通过fsync操作数据。默认60秒。

    1.syncdelay = 60

    默认就可以,不需要设置。不会对日志文件(journal files)有影响

    警告:如果设置为0,SYNCDELAY 不会同步到磁盘的内存映射文件。在生产系统上,不要设置这个值。

    sysinfo:系统信息,默认false。

    设置为true,mongod会诊断系统有关的页面大小,数量的物理页面,可用物理??页面的数量输出到标准输出。

    1.Tue Jun 11 21:07:15.031 sysinfo:
    2.Tue Jun 11 21:07:15.035   page size: 4096
    3.Tue Jun 11 21:07:15.035   _SC_PHYS_PAGES: 256318
    4.Tue Jun 11 21:07:15.035   _SC_AVPHYS_PAGES: 19895

    当开启sysinfo参数的时候,只会打印上面的信息,不会启动mongodb的程序。所以要关闭该参数,才能开启mongodb。

    upgrade:升级。默认为false。
    当设置为true,指定DBPATH,升级磁盘上的数据格式的文件到最新版本。会影响数据库操作,更新元数据。大部分情况下,不需要设置该值。

    traceExceptions:是否使用内部诊断。默认false。

    1.traceExceptions = false

    quiet:安静模式。

    1.quiet = true

    setParameter:2.4的新参数,指定启动选项配置。想设置多个选项则用一个setParameter选项指定,可以setParameter的参数请见这里,详情请见这里
    声明setParameter设置在这个文件中,使用下面的格式:

    1.setParameter = <parameter>=<value>

    如配置文件里设置syncdelay:

    1.setParameter = syncdelay= 55,notablescan = true,journalCommitInterval = 50,traceExceptions = true
    Replication Options  复制选项

    replSet:使用此设置来配置复制副本集。指定一个副本集名称作为参数,所有主机都必须有相同的名称作为同一个副本集。

    oplogSize:指定的复制操作日志(OPLOG)的最大大小。mongod创建一个OPLOG的大小基于最大可用空间量。对于64位系统,OPLOG通常是5%的可用磁盘空间。
    一旦mongod第一次创建OPLOG,改变oplogSize将不会影响OPLOG的大小。

    fastsync:默认为false。在副本集下,设置为true,从一个dbpath里启用从库复制服务,该dbpath的数据库是主库的快照,可用于快速启用同步,否则的mongod将尝试执行初始同步。注意:如果数据不完全同步,mongod指定fastsync开启,secondary或slave与主永久不同步,这可能会导致显着的一致性问题。

    replIndexPrefetch:2.2版本出现的新参数,默认是all。可以设置的值有:all, none, and _id_only。只能在副本集(replSet)中使用。默认情况下,secondary副本集的成员将加载所有索引到内存中(从OPLOG之前的操作有关的)。您可以修改此行为,使secondary只会加载_id索引。指定_id_或none,防止mongod的任何索引加载到内存。

    Master/Slave Replication:主从复制的相关设置

    master:默认为false,当设置为true,则配置当前实例作为主实例。

    1.master = true

    slave:默认为false,当设置为true,则配置当前实例作为从实例。

    1.slave = true

    source:默认为空,格式为:<host><:port>。用于从实例的复制:设置从的时候指定该选项会让从复制指定主的实例

    1.source = 127.0.0.1:30001

    only:默认为空,用于从选项,指定一个数据库进行复制。

    1.only = abc          #只同步abc集合(库)

    slavedelay:设置从库同步主库的延迟时间,用于从设置,默认为0。

    1.slavedelay = 60     #延迟60s同步主数据

    autoresync:默认为false,用于从设置。是否自动重新同步。设置为true,如果落后主超过10秒,会强制从自动重新同步。如果oplogSize太小,此设置可能有问题。如果OPLOG大小不足以存储主的变化状态和从的状态变化之间的差异,这种情况下强制重新同步是不必要的。当设置autoresync选项设置为false,10分钟内从不会进行大于1次的自动重新同步。

    1.autoresync = false

    展开全文
  • odoo.conf配置文件详解

    千次阅读 2018-07-28 11:00:19
    odoo配置文件之odoo.conf参数含义、功能详解 [options] addons_path = E:\GreenOdoo8.0\source\openerp\addons ;addons模块的查找路径 admin_passwd = admin ;管理员主控密码(用于创建、还原和备份数据库等...
  • SNMP--snmp.conf配置文件介绍

    千次阅读 2019-04-21 20:19:45
    snmp.conf是Net-SNMP应用的配置文件。 系统级配置文件: /etc/snmp/snmp.conf /etc/snmp/snmp.local.conf 用户级配置文件: $HOME/.snmp/snmp.conf $HOME/.snmp/snmp.local.conf 特定主机配置文件: /etc/snmp/hosts/...
  • 01 Nginx安装 nginx下部署项目,nginx conf配置文件修改,相关文件配置
  • linux conf配置文件(全)

    万次阅读 2017-09-22 15:52:22
    etcprofile bash_profile etcbashrc bashrc bash_logout 用户环境配置 bash_profilebashrc和...修改IP地址等网络相关的配置文件 etcsysconfignetwork-scriptsifcfg-eth etcsysconfignetwork 网关配置相关的配置文件 e
  • 更改默认 nginx.conf 配置文件位置

    万次阅读 2019-02-25 11:49:20
    nginx默认配置 安装时 nginx.conf所在位置为:/usr/local/nginx/conf/nginx.conf 本人需要将其移动到 /xxx/nginx 下   1、将原文件移动到自己需要更改的目录 mv /usr/local/nginx/conf/nginx.conf /xxx/nginx/...
  • linux的配置文件基本都是config格式的配置文件,所以专门查了一下python操作config的方法,总结记录一下(有时间在总结configobj模块的config格式文件操作方法) 一、ConfigParser模块 ConfigParser 是用来读取...
  • nova.conf配置文件说明

    千次阅读 2013-10-08 15:03:00
    #----------networking options----...#nova的dhcpbridge配置文件位置 --dhcpbridge_flagfile=/etc/nova/nova.conf --dhcpbridge=/usr/bin/nova-dhcpbridge #公共IP的网络主机 --routing_source_ip=192.168.1
  • strongswan--ipsec.conf配置文件分析

    千次阅读 2018-08-21 11:49:00
    ipsec.conf是stroke插件使用的配置文件,可以配置ike proposal、ike peer、ipsec proposal等属性。现对其中部分属性进行翻译/分析。 对conn的分析,来源:...
  • Centos7 Devstack [Rocky] local.conf配置文件

    千次阅读 2018-07-26 19:08:49
    在devstack目录下创建local.conf并赋权 #touch /home/devstack/local.conf &amp;&amp; chown stack:stack /home/devstack/local.conf [root@node01 ~]# cat /home/devstack/local.conf  [[local|localrc]...
  • spark-defaults.conf配置文件

    千次阅读 2017-01-16 22:14:35
    spark.master spark://master:7077spark.eventLog.enabled truespark.eventLog.dir hdfs://namenode:8021/directoryspark.serializer org.apache.spark.serializer.KryoSerializerspark.driver.memory 5gspark.execu
  • http.conf配置文件详解

    千次阅读 2008-11-22 21:11:00
    blanse 发表于 2008-1-25 19:10:00 Apache的基本设置主要交由httpd.conf来设定管理,我们要修改Apache的相关设定,主要还是通过修改httpd.cong来实现。下面让我们来看看httpd.conf的内容,它主要分成3大部分:...
  • 除了名为.s.PGSQL.nnnn的套接字文件本身之外,其中nnnn是服务器的端口号,将在每个unix_socket_directories目录中创建一个名为.s.PGSQL.nnnn.lock的普通文件。 这两个文件都不应该手动删除。 这个参数在Windows上...
  • apache配置文件:http.conf配置详解

    万次阅读 2008-11-23 09:14:00
    Apache的配置文件http.conf参数含义详解Apache的配置由httpd.conf文件配置,因此下面的配置指令都是在httpd.conf文件中修改。主站点的配置(基本配置)(1) 基本配置:ServerRoot "/mnt/software/apache2" #你的apache...
  • Netplan是 Ubuntu 17.10 中引入的一种新的命令行网络配置实用程序,用于在 Ubuntu 系统中轻松管理和配置网络设置。 它允许您使用YAML格式的描述文件来抽像化定义网络接口的相关信息。 Netplan可以使用...
  • nginx的nginx.conf配置文件修改

    万次阅读 2017-03-30 13:23:55
    nginx的nginx.conf配置文件修改提示: 1. user www; //需要在当前服务器下创建www的一个用户。 2. 需要在 /usr/local/nginx/logs下面同时存在,以下文件 access.log error.log nginx.pid www.log //===========...
  • 在apache的主配置文件/conf/http.conf 最下面添加 Include "D:\workspace_php\apache-php.conf" #文件路径可以任意 在D:\workspace_php文件下创建 apache-php.conf文件 它的具体内容为 # # PHP-Module setup ...
  • 比特币配置文件bitcoin.conf详解

    千次阅读 2019-04-28 11:03:21
    bitcoin.conf是比特币核心程序bitcoind的配置文件,本文将介绍bitcoin.conf的默认路径,并给出主要配置项的说明。 如果要快速掌握比特币的对接与应用开发,推荐汇智网的在线互动课程: Java比特币开发详解 Php比特...
  • mongodb配置文件config.conf详解

    万次阅读 2019-02-18 13:24:19
    配置文件在 /etc/mongod.conf文件里 启动方式 ./bin/mongod -f MongoDB.conf  会看到  about to fork child process, waiting until server is ready for connections. forked process: 2313 child process ...
  • Apache为网络管理员提供了丰富多彩的功能,包括目录索引、...也就是说,如果您在Linux Server上成功安装配置了Apache之后,您的计算机也将随着Apache的生效而摇身一变,成为一台名副其实的Web Server,这种变化的确是激
  • logstash的配置文件conf经常会涉及敏感信息,比如ES,mysql的账户密码等,以下使用logstash导入mysql为例子,加密隐藏mysql的密码。 1.先创建keystore,可以不设置keystore密码,直接选择y bin/logstash-keystore ...
  • samba配置文件smb.conf

    千次阅读 2017-03-01 12:27:40
    例如在windows上共享文件的话,只需右击要共享的文件夹然后选择...samba配置文件smb.conf 安装系统的时候大多会默认安装samba,如果没有安装,在CentOS上只需要运行这个命令安装即可: # yum install -y samba samba
  • resolv.conf文件配置

    千次阅读 2013-10-12 17:25:29
    resolv.conf是resolver类库使用的配置文件,每当一个程序需要通过域名来访问internet上面的其它主机时,需要利用该类库将域名转换成对应的IP,然后才可进行访问。      resolv.conf文件的配置选项不多,从man文档...
  • 首先没如果你是root用户,可以...2:然后创建nginx.conf文件, touch 文件名(可跟后缀) 3:讲之前备份的nginx.conf文件内容粘贴到新建的文件中。 4:到nginx的目录下重新加载nginx nginx -s reload 5:进行测试 ...
  • apache配置文件httpd.conf----小白福利

    万次阅读 2019-01-04 19:45:48
    安装apache 首先yum方式安装http2.2 # yum install httpd -y ... /etc/httpd/conf/httpd.conf配置文件 /etc/httpd/conf.d 子配置文件目录 /var/log/httpd/ 日志文件目录(access.log error.log) ...
  • docker下安装redis和配置文件redis.conf

    千次阅读 2017-07-07 22:40:00
    docker下安装redis和使用redis.conf配置文件 安装redis docker下查找镜像文件docker search redis 选择对应的镜像pull下来docker pull redis 启动Redis容器 创建已redis镜像模板的容器,并命名为redis...
  • 进程列表里 面找master进程,它的编号就是主进程号,每次修改完nginx文件都要重新加载配置文件linux命令,连接超时时间,1分钟,具体时间可以根据请求(例如后台导入)需要的时间来设置。对于来自 FastCGI Server 的 ...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 557,434
精华内容 222,973
关键字:

创建conf配置文件