#以服务方式启动mongodb,要求验证
/elain
/apps
/mongodb
/bin
/mongod
--fork
--port
27001
--auth
--dbpath
/elain
/data
/mongodb
/db
/
--logpath
/elain
/logs
/mongodb
/mongodb.log
#注:参数中用到的目录需创建
#停止
kill
-2
`
ps
-ef
|
grep mongod
|
grep
-v
grep
|
awk
''
{print
$2
}
''
`
#验证启动
[root
@md01 ~
]
# netstat -ln
Active Internet connections
(only servers
)
Proto Recv-Q Send-Q Local Address Foreign Address State
tcp
0
0 0.0.0.0:
28001 0.0.0.0:
* LISTEN
tcp
0
0 0.0.0.0:
27001 0.0.0.0:
* LISTEN
还可以通过访问:http://ip:28001/ 浏览
#远程登录:
mongo
--host serverip:
27001
#本机登录:
[root
@md01 ~
]
# mongo --host localhost:27001
MongoDB shell version: 2.0.0
connecting to: localhost:
27001
/
test
>
#获取MongoDB服务器统计信息
> db.runCommand
(
{
"serverStatus" :
1
}
)
#使用实时监控工具
mongostat
-h localhost:
27001
#查看版本
用户管理:
> db.addUser
(
"root",
"123456"
);
#添加管理员root
> use
test
switched to db
test
> db.addUser
(
"test_w",
"123456"
);
#为TEST库添加普通用户test_w
> use
test
switched to db
test
> db.addUser
(
"test_r",
"123456",
true
);
#为TEST库添加只读用户test_r
> db.system.users.remove
(
{
"user":
"test_w"
}
);
#删除名为test_w的用户
> db.auth
(
"test_w",
"123456"
);
#验证并切换用户身份
> db.system.users.find
(
);
#查看当前库的所有用户
> show
users;
#查看当前库的所有用户
> use admin
> db.runCommand
(
{
"buildInfo":
1
}
)
#查看系统信息与mongodb版本
数据管理:
>use elain
#建库
>db.elain.insert
(
{name:
''elain
''
}
);
#数据插入
>db.elain.remove
(
{name:
''elain
''
}
);
#数据删除
>db.elain.remove
(
{name:
''elain
''
}
);
#数据删除(永久删除)
>show dbs;
#显示数据库
>show collections;
#显示表
>db.elain.find
(
);
#数据查询
>db.elain.findOne
(
);
#只查一行
>db
#查看当前所在库
>db.collection.count
(
);
#统计colleciton的数量
>db.collection.drop
(
);
#删除此colleciton
>db.foo.find
(
).count
#某个数据的数量
>db.deliver_status.dataSize
(
);
#查看collection数据的大小
>db.deliver_status.stats
(
);
#查看colleciont状态
>db.deliver_status.totalIndexSize
(
);
#查询所有索引的大小
#删除数据库
use elain;
db.dropDatabase
(
);
#修复数据库
#删除表
#查看profiling
>db.test.find
(
{
},
{
"_id":
0
}
);
#不显示id列
>db.test.find
(
{
''name
'':
/mp
/i
}
);
#正则查找忽略大小写
db.elain.ensureIndex
(
{
"name":
1
}
);
#建立索引
db.elain.dropIndex
(
{
"name":
1
}
);
#删除索引
db.elain.find
(
{
"name":
"elain"
}
).explain
(
);
#查看索引
—————————————
"$lt"
<
"$lte"
<=
"$gt"
>
"$gte"
>=
"$ne"
<
>
"$in" 一个键匹配多个值
"$nin" 一个键不匹配多个值
$not 不匹配
$all 匹配数组全值
$size 数组长度
$slice 返子集合
{
"$slice”:10} -10 [10,20]
. 内嵌文档 {“name.first”:“xxx”}
$where *通常情况下不建议使用
—————————————–
备份恢复:
数据导出:
/elain
/apps
/mongodb
/bin
/mongoexport
-h 127.0.0.1:
27001
-uroot
-p
-d elain
-c
-o elain elain_con.csv
数据导入:
/elain
/apps
/mongodb
/bin
/mongoimport
-h 127.0.0.1:
27001
-uroot
-p
-d elain
-c elain elain_con.csv
备份数据库:
mongodump
-h 127.0.0.1:
27001
-uroot
-p
-d elain
-o
/elain
/backup
/mongodb
恢复数据库:
mongorestore
-h 127.0.0.1:
27001
-uroot
-p
-d elain
/elain
/backup
/mongodb
/elain
恢复数据库(恢复前清除已有数据):
mongorestore
-h 127.0.0.1:
27001
-uroot
-p
-d elain
--drop
/elain
/backup
/mongodb
/elain
性能测试:
备份方面:mongodump的速度和压缩率都最好,每秒125M的数据,压缩率达28%
恢复方面:
mongoimport速度较快,但不保证数据完整导入
mongorestore,速度较慢,比mongoimport慢2.5倍左右,但是根据mongodump导出的数据,可以完整导入数据。
转载自:http://www.elain.org/?p=614