mongo rundocker run commandd 和其他的区别

MongoDB学习日记 - java代码(七):runCommand & BasicDBObject
这里的示例代码都是简要代码,详细代码可以参考我打包好的代码,地址:百度云 mongo-demo.rar ,这部分代码在other中runCommandMongoClient client = new MongoClient();
MongoDatabase database = client.getDatabase("mydb");
// buildInfo 版本信息
// Document{{version=3.0.6,
gitVersion=1ef45a23a4c5e3480ac919b28afcba3c615488f2,
targetMinOS=Windows 7/Windows Server 2008 R2,
OpenSSLVersion=OpenSSL 1.0.1p-fips 9 Jul 2015,
sysInfo=windows sys.getwindowsversion(major=6,
minor=1, build=7601, platform=2, service_pack='Service Pack 1')
Document buildInfo = database.runCommand(new Document("buildInfo", 1));
System.out.println(buildInfo);
client.close();语法解释:db.runCommand( { "buildInfo" : 1 } )BasicDBObject注:这是一个用来查询的类MongoClient client = new MongoClient();
MongoDatabase database = client.getDatabase("mydb");// Pass BasicDBObject.class as the second argumentMongoCollection&BasicDBObject& collection = database.getCollection("mycoll", BasicDBObject.class);// insert a documentBasicDBObject document = new BasicDBObject("x", 1);collection.insertOne(document);document.append("x", 2).append("y", 3);// replace a documentcollection.replaceOne(Filters.eq("_id", document.get("_id")), document);// find documentsList&BasicDBObject& foundDocument = collection.find().into(new ArrayList&BasicDBObject&());for (BasicDBObject basicDBObject : foundDocument) {
System.out.println(basicDBObject);}client.close();这里都是比较简单的例子,仅供学习使用,不喜勿喷。如果以后开发需要,我会继续拓展博客。
最新教程周点击榜
微信扫一扫mongo简介——BSON数据类型与它们的编号和比较顺序
Binary data
Regular Expression
JavaScript
JavaScript (with scope)
32-bit integer
64-bit integer
两个不同类型的值相比较时,按照如下顺序决定大小
MinKey (internal type)
Numbers (ints, longs, doubles)
Symbol, String
Date, Timestamp
Regular Expression
MaxKey (internal type)
当使用$type判断某个文档属性是否是MinKey时,不应使用255,应使用-1
ORACLEDATE和TIMESTAMP数据类型的比较(一)
DATE数据类型   这个数据类型我们实在是太熟悉了,当我们需要表示日期和时间的话都会想到date类型。它可以存储月,年,日,世 纪,时,分和秒。它典型地用来表示什么时候事情已经发生或将要发生。DATE数据类型的问题在于它表示两个事件发生时间间隔的度量粒度是秒。这个问题将在 文章稍后讨论timestamp的时候被解决。可以使用TO_
ORACLE DATE和TIMESTAMP数据类型的比较(转)
DATE数据类型      这个数据类型我们实在是太熟悉了,当我们需要表示日期和时间的话都会想到date类型。它可以存储月,年,日,世纪,时,分和秒。它典型地用来表示什么时候事情已经发生或将要发生。DATE数据类型的问题在于它表示两个事件发生时间间隔的度量粒度是秒。这个问题将在文章稍后讨论timestamp的时候被解决。可以使用TO
mongodb 学习笔记 (五) Mongo的数据类型
mongo的文档类型类似于json,他支持键值对的数据组织方式,同时mongo也有自己的数据类型。 1. null
用于表示空值或者未定义的字段。 2. 布尔
true、false 3. 32位整型
sql server 、oracle和mysql 三大数据库数据类型的比较
各大数据的数据库类型:
Sql server 2008 的数据类型:type
数据库各个版本都一样 为对象分配数据类型时可以为对象定义四个属性: & 对象包含的数据种类
hibernate 数据类型和java,db数据类型
Java数据类型,Hibernate数据类型,标准sql数据类型之间的对应表&n
Oracle --- 数据类型
一)数据类型的分类
Oracle支持的数据类型可以分为四个基本种类:字符数据类型、数字数据类型、日期数据类型以及表示其它数据的数据类型。
属于字符数据类型的有: char/varchar/varchar2/nvarchar/nvarchar2/long
orcale中各个数据类型和java中各个数据类型的对应关系
Mysql Oracle Java BIGINT NUMBER(19,0) java.lang.Long BIT RAW byte[] BLOB BLOB RAW byte[] CHAR CHAR java.lang.String DATE DATE java.s
oracle学习笔记--数据类型和简单的表管理
工作中要用到oracle数据库,刚刚开始学习,我在看韩顺平老师的视频学习,做了一点简单的笔记,oracle数据类型和简单的表管理。
ORACLE的最重点的内容: 1,表查询(各种查询)2,存储过程 3,触发器
oracle数据类型:比较少,简单 char 定长 最大2000字符,不够的空间被空格占用,效率高,查询速度快
hsqldb数据类型与java类型对照
编号 数据库类型&n
Oracle DB 隐式和显示数据类型转换
除了Oracle 数据类型,还可以使用美国国家标准协会(ANSI) 、DB2 和SQL/DS 数据类型 定义Oracle DB 中表的列。但是,Oracle Server 会在内部将这些数据类型转换为Oracle 数据类型。
在某些情况下,Oracle Server &nbs
mongo简介——mongo的主要特性
从今天开始每天一篇关于mongo的小文章。 开始之前首先介绍一些规范。 1)除函数名和关键字以外,所有数据库名、集合名、字段名等一律用加粗的大写字母和下划线表示,以示醒目;所有名称不以下划线开头,下划线只用来分割单词。 2)所有需要在代码中以字面值或变量出现的,在文章中一律以下划线开头且以下划线分割的的大写英文单词表示,绝不出现字面值或变量定义。比如,要
Java数据类型 Hibernate数据类型 标准SQL数据类型(PS:对于不同的DB可能有所差异)
byte、java.lang.Byte byte TINYINT
short、java.lang.Short short SMALLINT
int、java.lang.Integer integer INGEGER
long、java.lang.Long long BIGINT
Oracle 数据类型及存储方式
it's from/topic/220760
Oracle 数据类型及存储方式 袁光东 原创 概述 通过实例,全面而深入的分析oralce的基本数据类型及它们的存储方式。以ORACLE 10G为基础,介绍oralce 10g引入的新的数据类型。让你对oracle数据类型有一个全新的认
1.SQL SERVER的数据类型
  数据类弄是数据的一种属性,表示数据所表示信息的类型。任何一种计算机语言都定义了自己的数据类型。当然,不同的程序语言都具有不同的特点,所定义的数据类型的各类和名称都或多或少有些不同。SQLServer 提供了 25 种数据类型:
Binary [(n)]
Varbinary [(n)]
Char [(n)]
Varchar[(n)]
oracle数据类型和对应的java类型
转自: http://otndnld.oracle.co.jp/document/products/oracle10g/102/doc_cd/java.102/B19275-03/datacc.htm#BHCJBJCC
SQL数据类型 JDBC类型代码 标准的Java类型 Oracle扩展的Java类型
oracle 所有的数据类型
ORACLE的数据类型-- ORACLE的数据类型常用的数据库字段类型如下:字段类型 中文说明 限制条件其它说明CHAR 固定长度字符串 最大长度2000 bytesVARCHAR2 可变长度的字符串 最大长度4000 bytes 可做索引的最大长度749NCHAR 根据字符集而定的固定长度字符串 最大长度2000 bytes&n
spring的jdbctemplate返回数据类型为List
spring的jdbctemplate返回数据类型为List 用 jdbctemplate queryForList
学习操作oracle.sql.Blob数据类型,向数据库插入Blob数据类型的数据
* @author cqw
* 向数据库插入Blob类型数据,数据库表 SSDATAFILE(SSDATAFILEID,STRFILENAME,STRTIMETICK
下面的表格中列出了已经学习过的数据类型,也是python的核心数据类型之一部分,这些都被称之为内置对象。 对象,就是你面对的所有东西都是对象,看官要逐渐熟悉这个称呼。所有的数据类型,就是一种对象。英文单词是object,直接的汉语意思是物体,这就好像我们在现实中一样,把很多我们看到和用到的都可以统称为“东西”一样。“东西”就是“对象”,就是object。在编程中,那个所谓面向对象,也可以说成“面向
Oracle 数据类型及存储方式(一)字符类型
Oracle 数据类型及存储方式 概述 通过实例,全面而深入的分析oralce的基本数据类型及它们的存储方式。以ORACLE 10G为基础,介绍oralce 10g引入的新的数据类型。让你对oracle数据类型有一个全新的认识。揭示一些不为人知的秘密和被忽略的盲点。从实用和优化的角度出发,讨论每种数据 类型的特点。从这里开始oracle之旅! 第
mongo简介——数据库与集合
至于安装过程将要放到后面的某个时候单独再说。 本文说明一下数据库与集合的创建、删除,还有集合的种类。
创建数据库 connection.DATABASE_NAME; //如果这个DATABASE_NAME还不存在,在向这个数据库插入第一条记录时就会自动创建
删除数据库 useDATABASE_NAME; db.dropDa
mongo简介——数据库与集合
至于安装过程将要放到后面的某个时候单独再说。 本文说明一下数据库与集合的创建、删除,还有集合的种类。
创建数据库 connection.DATABASE_NAME; //如果这个DATABASE_NAME还不存在,在向这个数据库插入第一条记录时就会自动创建
删除数据库 useDATABASE_NAME; db.dropDa
oracle 数据类型详解---日期型(转载)
oracle 数据类型详解---日期型
oracle数据类型看起来非常简单,但用起来会发现有许多知识点,本文是我对ORACLE日期数据类型的一些整理,都是开发入门资料,与大家分享: 注:由于INTERVAL及TIME ZONE实际用得比较少,所以本文内容未涉及这两个方面。
2.3 iPhone开发之OC变量和基本数据类型2 (视频)
核心内容 1. 基本数据类型类别 2. 基本数据类型的格式化说明符 3. 基本数据类型的初始值
视频地址: iPhone开发之OC变量和基本数据类型2
无论是在小得可怜的免费数据库空间或是大型电子商务网站,合理的设计表结构、充分利用空间是十分必要的。这就要求我们对数据库系统的常用数据类型有充分的认识。下面我就将我的一点心得写出来跟大家分享。
一、数字类型
Windows 数据类型 Delphi 数据类型 描述
LPSTR PAnsiChar 字符串指针
LPCSTR PAnsiChar 字符串指针
DWORD LongWord 整数
BOOL LongBool 布尔型
PBOOL ^BOOL 指向布尔值的指针
PByte ^Byte 指向字节值的指针
PINT ^Integ
mongo简介——聚合group
这一篇将简单介绍下数据的聚合。 不得不说mongo是一个强大的数据库,它为数据分析提供了很多有用的工具。 很多公司也在使用mongo做数据分析,而且取得了不错的性能。
首先说下RDBMS里面常用的聚合函数在mongo的世界里面是怎么回事。 在RDBMS的世界里常用的聚合函数有max min avg sum count,不过现在我们到了mongo的
oracle数据类型-3
9、TIMESTAMP WITH TIME ZONE 包含 TIMESTAMP 数据类型中的所有域,除此之外,还包含两个额外的域:timezone_hour 和 timezone_minute。这个数据类型包含支持时区的相关信息。这个数据类型可以在 Oracle9i 数据库及其更新的版本中使用。 10、TIMESTAMP WITH LOCAL TIME ZONE 除了在
一、javascript的数据 javascript的数据分为两种:简单数据和复杂数据。简单数据包含number,string,boolean,undefined和null这五种;复杂数据只有一种即object。【此处友情鸣谢李战老师,&&悟透JavaScript&&写得太传神,印象太深刻了】
二、javascript的数据类型检测 1、万能的typeof 我们先测试一
在mysql中timestamp数据类型是一个比较特殊的数据类型,他可以自动在你不使用程序更新情况下只要你更新了记录timestamp会自动更新时间 通常表中会有一个Create date 创建日期的字段,其它数据库均有默认值的选项。MySQL也有默认值timestamp,但在MySQL中,不仅是插入就算是修改也会更新timestamp的值! 这样一来,就不是创建日期了,当作更新日期来使用比较好!
自定义数据类型的数据库映射方案
基础数据类型,如String、Integer、Date、Boolean等它们可以很方便的映射到数据库:
import grails.persistence.Entity @Entity class MyEntity { String code String name static constraints = { code(unique: true, minS
自定义数据类型的数据库映射方案
基础数据类型,如String、Integer、Date、Boolean等它们可以很方便的映射到数据库:
import grails.persistence.Entity @Entity class MyEntity { String code String name static constraints = { code(unique: true, minSiz
mybatis常用jdbcType数据类型
MyBatis通过包含的jdbcType类型 BITFLOATCHAR&n
PHP共有8中数据类型:
类型名称 类型表示 取值
bool 布尔型 true,false
integer 整型 --
string 字符串型 字符串长度取决于机器内存
float 浮点型 最大值1.8e308
object 对象 通过new实例化 $obj=new person();
array 数组类型 $arr=arr
SQL Server 提供系统数据类型集,定义了可与 SQL Server 一起使用的所有数据类型。下面列出系统提供的数据类型集。
可以定义用户定义的数据类型,其是系统提供的数据类型的别名。有关用户定义的数据类型的更多信息,请参见 sp_addtype 和创建用户定义的数据类型。 当两个具有不同数据类型、排序规则、精度、小数位数或长度的表达式通过运算符进行组合时: 通过将数据类型的优先顺序规则应
选择优化的数据类型 (一)基本原则
最基本的原则: 一。更小通常更好 更小的数据类型通常更快,因为它们使用了更少的磁盘空间,内存和CPU缓存,而且需要的CPU周期也更少。 但是要确保不会低估要保存的值。 二。简单就好 越简单的数据结构,需要的CPU周期就越少。例如:比较整数的代价小于比较字符,因为字符集和排序规则使字符比较复杂。这有两个例子,一是应该使用mysql内建的类型来保存日期和时间,而不
Oracle 常用数据类型
a)数值类型 Number(19,0) b)字符类型charvarchar2longclob(存文章) c)时间日期DataTimeStamp d)大对象:rawlongrawblob(2进制的)&nb
oracle的基本数据类型
VARCHAR2(size) 可变长度的字符串,其最大长度为size个字节;size的最大值是4000,而最小值是1;你必须指定一个VARCHAR2的 NVARCHAR2(size) 可变长度的字符串,依据所选的国家字符集,其最大长度为size个字符或字节; size的最大值取决于储存每个字符所需的字节数,其上限为4000;你必须指定一个
Redis数据类型--string
五种数据类型:string, list, set, zset, hash
1). string类型
String是最简单的类型,一个key对应一个value,string类型是二进制安全的。Redis的string可以包含任何数据,比如jpg图片或者序列化的对象(PHP中对象序列化函数
NSString转化为UInt16的数据类型 我定义一个UITextField *string,然后需要把string.text的内容(一个整数)赋值给类型为UInt16的数value,string.text的数据类型应该是NSString类型,也就是把NSString类型的数转化为UInt16类型的数,求指教~
------解决方案--------------------首页 & oracle/mysql/mongodb/sqlservermongodb备份与恢复 mongodb是目前最流行的nosql数据库,其自身也提供了备份与恢复命令 。具体程序为mongodump和mongorestore 。 一、mongodump备份 mongodump的具体用法可以查看帮助:[root@web20 ~]# /App/mongodb/bin/mongodump
ERROR: required parameter is missing in 'host'
Export MongoDB data to BSON files.
produce help message
-v [ --verbose ]
be more verbose (include multiple times for more
verbosity e.g. -vvvvv)
print the program's version and exit
-h [ --host ] arg
mongo host to connect to ( &set name&/s1,s2 for
--port arg
server port. Can also use --host hostname:port
enable IPv6 support (disabled by default)
-u [ --username ] arg
-p [ --password ] arg
--dbpath arg
directly access mongod database files in the given
path, instead of connecting to a mongod
needs to lock the data directory, so cannot be used
if a mongod is currently accessing the same path
--directoryperdb
if dbpath specified, each db is in a separate
enable journaling
-d [ --db ] arg
database to use
-c [ --collection ] arg
collection to use (some commands)
-o [ --out ] arg (=dump) output directory or "-" for stdout
-q [ --query ] arg
json query
Use oplog for point-in-time snapshotting
try to recover a crashed database
--forceTableScan
force a table scan (do not use $snapshot) 帮助信息上已经写的很明了了 ,具体导出备份命令为:mongodump -h dbhost -d dbname -o dbdirectory -h 表示mongodb server地址, -d 表示需要备份的数据名 -o 为备份数据存放的路径 如果设置了用户名密码还要使用-u和-p参数 ,如果想要导出单独库下的一个表,再增加-c参数 。具体用法同mysqldump有类似之处 。 注:如现在导出的库名为361way ,导出的路径为/opt ,则导出后会在/opt目录下有一个361way命名的目录 ,里面是由表名命名的json和bson文件 ,具体组成类似于表结构和表数据 。而导出的内容和mysql 略有不同,mysqldump导出的是一个sql文件而不是目录 。 二、mongorestore恢复 mongorestore具体用法类以于mongodump,不过参数上略有差异,具体用法为:usage: ./mongorestore [options] [directory or filename to restore from]
produce help message
-v [ --verbose ]
be more verbose (include multiple times for more
verbosity e.g. -vvvvv)
print the program's version and exit
-h [ --host ] arg
mongo host to connect to ( &set name&/s1,s2 for sets)
--port arg
server port. Can also use --host hostname:port
enable IPv6 support (disabled by default)
-u [ --username ] arg
-p [ --password ] arg
--dbpath arg
directly access mongod database files in the given
path, instead of connecting to a mongod
needs to lock the data directory, so cannot be used
if a mongod is currently accessing the same path
--directoryperdb
if dbpath specified, each db is in a separate
enable journaling
-d [ --db ] arg
database to use
-c [ --collection ] arg collection to use (some commands)
--objcheck
validate object before inserting
--filter arg
filter to apply before inserting
drop each collection before import
--oplogReplay
replay oplog for point-in-time restore
--oplogLimit arg
exclude oplog entries newer than provided timestamp
(epoch[:ordinal])
--keepIndexVersion
don't upgrade indexes to newest version
--noOptionsRestore
don't restore collection options
--noIndexRestore
don't restore indexes
--w arg (=1)
minimum number of replicas per write 一般用法为:mongorestore -h dbhost -d dbname --directoryperdb dbdirectory --directoryperdb:备份数据所在位置 ,例如上例中,我们将361way库备份到了 /opt 下,这里恢复的时候使用的就是/opt/361way ,此处是和备份略有区别的 。 --drop:恢复的时候,先删除当前数据,然后恢复备份的数据 三、与其他备份恢复工具的对比 mongodb自带的备份工具还有bsondump、mongoexport,恢复工具还有mongoimport ,几者之间的具体区别是: bsondump、mongoexport、mongodump备份工具的对比: 1、bsondump可以指定备份的格式为json和debug模式,这个命令虽然附带,但很少用到 ; 2、mongoexport 可以导出json或csv格式的文件,可以指定查询过滤器或指定输出的域,不过此工具导出的json,csv可能对某些数据类型不兼容,因此可能不能全部数据导出,mongodump就可以全部兼容 ; 3、mongodump支持过滤 ,而且在导出速度和压缩率方面mongodump是最快最好的 。所以,若无csv或debug等特殊格式的备份需求,一般都使用 mongodump 作为备份工具 。 mongorestore与mongoimport 恢复工具的对比: 1、 mongoimport 可以接受json,csv,tsv格式的文件,每行为一个对象 。同mongoexport一样,其在恢复过程中同样存在兼容性的问题,所以有恢复不完整的概率 ; 2、mongorestore,速度较慢,比mongoimport慢2.5倍左右,但是根据mongodump导出的数据,可以完整导入数据。在restore过程中,索引根据之前dump的结果重新创造。
本站的发展离不开您的资助,金额随意,欢迎来赏!
分类: oracle/mysql/mongodb/sqlserver mongodb您可能也喜欢Crawl a website with scrapy PHP添加MongoDB扩展 mongodb的慢查询 mongodb强制一个成员为主 mongo内存管理 捐助本站
如您感觉本博客有用,可扫码向本博客捐赠近期文章 利用sshpass获取多台主机的信息 smokeping告警配置 nginx+smokeping安装配置 修改CPAN mirror的默认源 更换主板后waiting for device to appear无法启动文章归档 文章归档 选择月份 2016年五月 &(4) 2016年四月 &(5) 2016年三月 &(2) 2016年二月 &(2) 2016年一月 &(4) 2015年十二月 &(7) 2015年十一月 &(9) 2015年十月 &(6) 2015年九月 &(7) 2015年八月 &(22) 2015年七月 &(10) 2015年六月 &(15) 2015年五月 &(23) 2015年四月 &(13) 2015年三月 &(22) 2015年二月 &(15) 2015年一月 &(24) 2014年十二月 &(12) 2014年十一月 &(15) 2014年十月 &(19) 2014年九月 &(18) 2014年八月 &(18) 2014年七月 &(20) 2014年六月 &(21) 2014年五月 &(24) 2014年四月 &(12) 2014年三月 &(29) 2014年二月 &(22) 2014年一月 &(22) 2013年十二月 &(24) 2013年十一月 &(20) 2013年十月 &(18) 2013年九月 &(13) 2013年八月 &(15) 2013年七月 &(20) 2013年六月 &(21) 2013年五月 &(19) 2013年四月 &(17) 2013年三月 &(21) 2013年二月 &(17) 2013年一月 &(18) 2012年十二月 &(24) 2012年十一月 &(18) 2012年十月 &(17) 2012年九月 &(17) 2012年八月 &(18) 2012年七月 &(25) 2012年六月 &(36) 2012年五月 &(36) 2012年四月 &(28) 2012年三月 &(46) 2012年二月 &(23) 2012年一月 &(14) 2011年十二月 &(27) 2011年十一月 &(59) 2011年十月 &(19) 2011年九月 &(15) 2011年八月 &(46)出处:http://blog.csdn.net
主要介绍了日常运行维护的管理工具
MongoDB的日常维护包括使用配置文件,设置访问控制,Shell交互,系统监控和管理,数据库日常备份和恢复
启动和停止MongoDB
启动后可以通过数据库的IP加端口号访问Web形式数据库。
通过使用拂去配置文件的方式启动数据库实例,在bin文件夹下创建并编辑mongodb.config(名字可以随意)
事例加上 dbpath =/data/db/
启动时加上 --f 参数,并且指向配置文件即可。
使用Daemon方式启动
为什么我们使用Daemon方式?当我们关闭数据库服务的session端口的时候,MongoDB的服务也随之终止,这样是十分不安全的。通过守护进程的方式,启动即可。
添加 --fork 参数,这里必须指定存储日志的文件,即为启动 --logpath 参数。
./mongod.exe --dbpath = D:\MongoDB
--logpath = D:\MongoDB\log\mongodb50.log
常见的mongod的参数说明
dbpath:数据文件存放路径
logpath: 存放的日志文件
bind_ip :对外的服务绑定IP,一般为空,面对所有的IP开放
port: fork 以后台Daemon的形式启动该服务,web管理端在其上加1000
journal: 开启日志功能,通过保存操作日志来降低单机故障的恢复时间,
config :当参数行十分多的时候,使用这个参数来设定参数文件的位置
关闭数据库
直接使用Control+C来中断
在connect连接状态下,可以切换到admin数据,后直接在库中发送db.shutdownServer()指令终止MongoDB实例。
Unix下发送Kill -2 PID 或者 Kill -15 PID来终止进程
ps aux|grep mongod
kill -2 (yourPID)
ps aux|grep mongod
注意:不能使用kill -9 PID 杀死进程,这样可能导致MongoDB数据库损坏。
访问数据库
绑定iP地址 ——bind_ip
//MongoDB 可以限制只允许某一特定IP 来访问,只要在启动时加一个参数bind_ip 即可,如下:
[root@mongodb01 /home/mongo/mongodb-2.0.2/bin]$ ./mongod --bind_ip 192.168.1.61
设置监听端口 ——port
//将服务端监听端口修改为27018:
[root@mongodb01 /home/mongo/mongodb-2.0.2/bin]$ ./mongod --bind_ip 192.168.1.61 --port 27018
//(报错代码)端户访问时不指定端口,会连接到默认端口27017,对于本例会报错,代码如下:
[root@mongodb01 /home/mongo/mongodb-2.0.2/bin]$ ./mongo 192.168.1.50
MongoDB shell version: 2.0.2
connecting to: 192.168.1.61/test
Sun Apr 14 21:45:26 Error: couldn&t connect to server 192.168.1.50 shell/mongo.js:81 exception: connect failed
使用用户名和密码登陆 ——启动时使用--auth参数
//先启用系统的登录验证模块, 只需在启动时指定 auth 参数即可,代码如下:
[root@mongodb01 /home/mongo/mongodb-2.0.2/bin]$ ./mongod --auth
默认有个admin数据库,在admin.system.users中保存的用户比其他的数据库设置的用户权限更大。在未添加admin.system.users用户的权限的的情况下, 客户端无需任何认证就可以连接到数据库,并且可以对数据库进行任何操作,只有在admin.system.users添加了用户,启动--auth参数才会起作用。
1.建立系统root用户
&db.addUser(&root&,&123456&)
&db.auth(&root&,&123456&)
2.建立只读权限用户
&db.addUser(&user_reader&,&1234567&,true)
添加只读权限的用户只需添加第三个参数,true。
使用命令行操作
MongoDB不仅可以交互,还可以执行指定的JavaScript文件,执行指定的命令片段,使用Linux Shell。
1.通过eval参数执行指定的语句
查询test库的t1集合的记录有多少:
db.t1.find()
{ &_id& : ObjectId(&4f8ac746be2cafbb&), &num& : 1 }
{ &_id& : ObjectId(&4f8ac74cbe2cafbc&), &num& : 2 }
{ &_id& : ObjectId(&4f8ac74ebe2cafbd&), &num& : 3 }
{ &_id& : ObjectId(&4f8ac751be2cafbe&), &num& : 4 }
{ &_id& : ObjectId(&4f8ac755be2cafbf&), &num& : 5 }
db.t1.count()
通过使用--eval参数直接执行ti的集合中的数
$./mongo.exe
&printjson(db.t1.count())&
MongoDB shell version: 2.0.2
connecting to: test
2.使用js文件执行文件内容
$cat t1_count.js
var count = db.t1.count();
printjson(&count of t1 is: &+count);
$./mongo t1_count.js
MongoDB shell version: 2.0.2
connecting to: test
&count of t1 is: 5&
Tips:通过--quiet参数屏蔽部分登陆信息,使结果更清晰
$ ./mongo --quiet t1_count.js
&count of t1 is: 5&
查看活动进程
& db.currentOp()
&db.$cmd.sys.inprog.findOne()
//$cmd调用外部函数
显示如下:
& db.currentOp()
&inprog& : [
&opid& : 630385,
&active& : true,
&lockType& : &read&,
&waitingForLock& : false,
&secs_running& : 0,
&op& : &query&,
&ns& : &test&,
&query& : {
&count& : &t1&,
&query& : {
&fields& : {
&client& : &127.0.0.1:51324&,
&desc& : &conn&,
&threadId& : &0x7f&,
&connectionId& : 7,
&numYields& : 0
代码解释:
opid:操作进程号
op: 操作类型(query ,update ,etc)
ns: 命名空间(namespace),操作对象
query :显示操作的具体内容
lockType: 锁的类型,指明是写锁还是读锁
& db.killOp(630385)
{ &info& : &attempting to kill op& }
我们查看下:
& db.currentOp()
{ &inprog& : [ ] }
监控系统的状态和性能
使用serverStatus命令可以获取到运行中的MongoDB服务器统计信息,下面我们来执行命令,查看MongoDB服务器的统计信息(不同平台或不同版本的键会有所不同),代码如下:
& db.runCommand({&serverStatus&:1})
&host& : &lindenpatservermongodb01&,
&version& : &2.0.2&,
&process& : &mongod&,
&uptime& : 6003,
&uptimeEstimate& : 5926,
&localTime& : ISODate(&T11:02:21.795Z&),
&globalLock& : {
&totalTime& : ,
&lockTime& : 24867,
&ratio& : 0.,
&currentQueue& : {
&total& : 0,
&readers& : 0,
&writers& : 0
&activeClients& : {
&total& : 0,
&readers& : 0,
&writers& : 0
&bits& : 64,
&resident& : 52,
&virtual& : 1175,
&supported& : true,
&mapped& : 160,
&mappedWithJournal& : 320
&connections& : {
&current& : 1,
&available& : 818
&extra_info& : {
&note& : &fields vary by platform&,
&heap_usage_bytes& : 341808,
&page_faults& : 14
&indexCounters& : {
&btree& : {
&accesses& : 1,
&hits& : 1,
&misses& : 0,
&resets& : 0,
&missRatio& : 0
&backgroundFlushing& : {
&flushes& : 100,
&total_ms& : 13,
&average_ms& : 0.13,
&last_ms& : 1,
&last_finished& : ISODate(&T11:02:19.010Z&)
&cursors& : {
&totalOpen& : 0,
&clientCursors_size& : 0,
&timedOut& : 0
&network& : {
&bytesIn& : ,
&bytesOut& : ,
&numRequests& :
&opcounters& : {
&insert& : 5,
&query& : 8,
&update& : 0,
&delete& : 0,
&getmore& : 0,
&command& :
&asserts& : {
&regular& : 0,
&warning& : 0,
&msg& : 0,
&user& : 0,
&rollovers& : 0
&writeBacksQueued& : false,
&commits& : 30,
&journaledMB& : 0,
&writeToDataFilesMB& : 0,
&compression& : 0,
&commitsInWriteLock& : 0,
&earlyCommits& : 0,
&timeMs& : {
&dt& : 3073,
&prepLogBuffer& : 0,
&writeToJournal& : 0,
&writeToDataFiles& : 0,
&remapPrivateView& : 0
数据导出与导入
mongoexport和
mongoinport
使用mongoexport导出数据
先看数据:
& db.t1.find()
{ &_id& : ObjectId(&4f8ac746be2cafbb&), &num& : 1 }
{ &_id& : ObjectId(&4f8ac74cbe2cafbc&), &num& : 2 }
{ &_id& : ObjectId(&4f8ac74ebe2cafbd&), &num& : 3 }
{ &_id& : ObjectId(&4f8ac751be2cafbe&), &num& : 4 }
{ &_id& : ObjectId(&4f8ac755be2cafbf&), &num& : 5 }
使用代码:
./mongoexport.exe -d test -c t1 -o t1.dat
connected to: 127.0.0.1
exported 5 records
[root@mongodb01 /home/mongo/mongodb-2.0.2/bin]$ ls
mongoimport
mongosniff
t1_count.js
mongoexport
mongorestore
mongofiles
testfiles.txt
[root@mongodb01 /home/mongo/mongodb-2.0.2/bin]$ cat t1.dat
{ &_id& : ObjectId(&4f8ac746be2cafbb&), &num& : 1 }
{ &_id& : ObjectId(&4f8ac74cbe2cafbc&), &num& : 2 }
{ &_id& : ObjectId(&4f8ac74ebe2cafbd&), &num& : 3 }
{ &_id& : ObjectId(&4f8ac751be2cafbe&), &num& : 4 }
{ &_id& : ObjectId(&4f8ac755be2cafbf&), &num& : 5 }
./mongoexport.exe -d test -c t1 -o t1.dat 使用参数说明
-d: 指明使用的数据库
-c: 指明导出的集合,这里是t1
-o: 导出的数据名,这里的数据名默认使用相对路径,也可以使用绝对路径。
导出的数据格式的是JSON方式,也可导出csv格式;
导出为CSV格式代码文件如下:
./mongoexport -d test -c t1 -csv -f num -o t1.dat
-csv:指明了要导出的是CSV格式
-f: 指明需要导出的是哪些例子
数据导入 mongoimport
现将ti删除:
& db.t1.drop()
& show collections
system.indexes
system.users
再导入数据,这里导入的是csv数据:
./mongoimport -d test -c t1 --type csv --headerline -file /home/t1.dat
connected to: 127.0.0.1
看看导入的数据是不是一样:
& db.t1.find()
{ &_id& : ObjectId(&4f8ac746be2cafbb&), &num& : 1 }
{ &_id& : ObjectId(&4f8ac74cbe2cafbc&), &num& : 2 }
{ &_id& : ObjectId(&4f8ac74ebe2cafbd&), &num& : 3 }
{ &_id& : ObjectId(&4f8ac751be2cafbe&), &num& : 4 }
{ &_id& : ObjectId(&4f8ac755be2cafbf&), &num& : 5 }
--type csv 导入的数据格式为CSV,为什么导入CSV格式:CSV对各大主流的数据库支持更良好,而JSON作为轻量级的数据格式,还有些弊端。
--file 指明导入的文件路径
数据备份和恢复
使用 数据备份 mongodump
./mongodump -d test -o /home/dump
-o:表示输出的备份路径,如果没有使用这个选项的话,MongoDB会自动创建dump文件夹并将备份文件放于其内。
使用数据恢复 mongorestore
mongorestore获取mongodump的输出结果,并将备份的数据插入到运行的MongoDB中。
./mongorestore -d test dump/*
connected to: 127.0.0.1
Thu Apr 19 18:16:12 dump/test/system.users.bson
Thu Apr 19 18:16:12
going into namespace [test.system.users]
2 objects found
Thu Apr 19 18:16:12 dump/test/t1.bson
Thu Apr 19 18:16:12
going into namespace [test.t1]
5 objects found
Thu Apr 19 18:16:12 dump/test/system.indexes.bson
Thu Apr 19 18:16:12
going into namespace [test.system.indexes]
Thu Apr 19 18:16:12 { key: { _id: 1 }, ns: &test.system.users&, name: &_id_& }
Thu Apr 19 18:16:13 { key: { _id: 1 }, ns: &test.t1&, name: &_id_& }
2 objects found
作者:u 发表于 22:54:43
阅读:128 评论:0
相关 [mongodb 管理] 推荐:
- Wang Dong - BlogJava-首页技术区
不知不觉房产系统已经使用MongoDB一年多了,记得一年多以前,正是NOSQL被热炒时,MongoDB更是作为NOSQL中的佼佼者,被炒得火烫,也应该就在当时被这股火烫着了,所以义无反顾的选择了MongoDB,现在想想当时确实有些冲动了,当时MongoDB的资料还是比较少,更别说中文资料了,后来还出现使用MongoDB成功应用的范例Foursquare的宕机事件.
- CSDN博客数据库推荐文章
主要介绍了日常运行维护的管理工具. MongoDB的日常维护包括使用配置文件,设置访问控制,Shell交互,系统监控和管理,数据库日常备份和恢复. 启动后可以通过数据库的IP加端口号访问Web形式数据库. 通过使用拂去配置文件的方式启动数据库实例,在bin文件夹下创建并编辑mongodb.config(名字可以随意).
- 数据库 - ITeye博客
//实例化Mongo对象,连接27017端口.
//连接名为yourdb的数据库,假如数据库不存在的话,mongodb会自动建立. //从Mongodb中获得名为yourColleection的数据集合,如果该数据集合不存在,Mongodb会为其新建立.
- CSDN博客推荐文章
对于数据库而言,无非就是增删改查,通常我们在项目应用中,READ操作又占50%以上的操作,客户往往对此也比较敏感,如果在这方面,效率上处理不好,往往是要遭后人唾弃的. 所以这时就需要索引来发挥作用了,下面我们先看一下索引给我们带来的感官上的区别,然后我们再详细说说mongodb的索引操作. 一、首先,我们向数据库中插入10万条数据:.
- CSDN博客数据库推荐文章
在mysql数据库中,慢查询日志经常作为优化数据库的依据, mongodb中依然有类似的功能. Mongodb自带的profiler,可以方便地记录所有耗时的操作,以便于调优;. 一、开始profiler功能. 开启profier功能有两种:. 第一种就是直接在启动参数里面进行设置,就在茄冬mongodb时候添加-profile=级别.
- Lianhui Wang - NoSQLFan
前两天本站刚刚分享了wordnik使用MongoDB经验的文章:《Wordnik 的 MongoDB 使用经历》,今天又看到一位朋友对这方面做的总结,分享在这里,供大家参考. 赋闲以后很长没有更新博客了,说忙完全是借口,多半因为没有兴致所致. 今天凌晨比赛多多,趁着比赛的前奏和间隙,遂浏览些技术文章.
- 高春辉 - 火丁笔记
但凡初次接触MongoDB的人,无不惊讶于它对内存的贪得无厌,至于个中缘由,我先讲讲Linux是如何管理内存的,再说说MongoDB是如何使用内存的,答案自然就清楚了. 据说带着问题学习更有效,那就先看一个MongoDB服务器的top命令结果:. 这台MongoDB服务器有没有性能问题. 先讲讲Linux是如何管理内存的.
- Ease - 江边潮未尽,枫红一季秋
按照官方的说法,MongoDB是一种可扩展的高性能的开源的面向文档(document-oriented )的数据库,采用C++开发. 注意mongo不是mango(芒果),这个词是从humongous中截取出来的,其野心不言而明,直指海量数据存储. 和其他很多NoSQL不太一样,MongoDB背后有一个专门的商业公司在提供支持和推广,有点类似MySQL AB的模式.
- 博客园_首页
索引是用来加快查询的,数据库索引与数据的索引类似,有了索引就不需要翻遍整本书,数据库可以直接在索引中查找,. 使得查询速度很快,在索引中找到条目后,就可以直接跳转到目标文档的位置.. 要掌握如何为查询配置最佳索引会有些难度.. MongoDB索引几乎和关系型数据库的索引一样.绝大数优化关系型数据库索引的技巧同样适用于MongoDB..
坚持分享优质有趣的原创文章,并保留作者信息和版权声明,任何问题请联系:@。

我要回帖

更多关于 docker run command 的文章

 

随机推荐