没有合适的资源?快使用搜索试试~ 我知道了~
温馨提示
试读
5页
1 非正常关闭服务或关机后 mongod服务无法正常启动 在使用中发现mongodb 的服务很容易因为非正常关闭而启动不了,不过解决也很容易 删除data目录下的 *.lock文件,再运行下 /mongodb_binpath/mongod -repair -f config文件路径 再启动即可 也可以在/etc/init.d/mongod 服务启动的文件中加入 启动前删除该文件 如下: start() { rm -f /usr/mongodb/data/master/mongod.lock /usr/mongodb/bin/mongod --config /usr/mongodb/conf
资源详情
资源评论
资源推荐
mongodb 常见问题处理方法收集常见问题处理方法收集
1 非正常关闭服务或关机后非正常关闭服务或关机后 mongod服务无法正常启动服务无法正常启动
在使用中发现mongodb 的服务很容易因为非正常关闭而启动不了,不过解决也很容易
删除data目录下的 *.lock文件,再运行下 /mongodb_binpath/mongod -repair -f config文件路径 再启动即可
也可以在/etc/init.d/mongod 服务启动的文件中加入 启动前删除该文件 如下:
start() {
rm -f /usr/mongodb/data/master/mongod.lock
/usr/mongodb/bin/mongod --config /usr/mongodb/config/master.conf
}
2、、server-side JavaScript execution is disabled
完整信息:JavaScript execution failed: group command failed: { “ok” : 0, “errmsg” : “server-side JavaScript execution is
disabled” }
解决方法:mongod.conf 这个配置文件里 noscripting:false 如果true 就是禁止
3、、 Decimal转换成转换成BsonValue值异常值异常
BsonValue 暂不支持 Decimal类型,转换前强制转换类型,
if (type==typeof(Decimal))
{
return Convert.ToDouble(value);
}
如果用MongoDB,最好不要用decimal类型,否则在序列化的时候也有问题,可用double
4、、MONGO Replica 频繁插入大数据的问题频繁插入大数据的问题
MONGO Replica 频繁插入大数据的问题,当在复制集中频繁插入大数据时有可能出现 “error RS102 too stale to catch up”出现
这个错误的原因是SECONDARY即副节点的复制速度跟不上了,当需要批量频繁向副本集中写入数据时最好先移除副本节
点,待插入完后重新同步。
5 Mongo集群没有集群没有primary但有但有secondary时连接不上且不能读数据时连接不上且不能读数据
#mongodb默认是从主节点读写数据的,副本节点上不允许读,需要设置副本节点可以读。
shell
1 repset:SECONDARY> db.getMongo().setSlaveOk(); #要在primary上执行
2 rs.slaveOk()
其他客户端
从secondary 读数据
如果应用程序没有设置相应的ReadReference也可能不能进行读取操作
MongoClientSettings set = new MongoClientSettings();
List<MongoServerAddress> servers = new List<MongoServerAddress>();
servers.Add(new MongoServerAddress(“192.168.129.129”, 37017));
servers.Add(new MongoServerAddress(“192.168.129.129”, 37018));
servers.Add(new MongoServerAddress(“192.168.129.129”, 37019));
set.Servers = servers;
//设置副本集名称
set.ReplicaSetName = “rs0”;
//设置超时时间为3秒
set.ConnectTimeout = new TimeSpan(0, 0, 0, 3, 0);
MongoClient client = new MongoClient(set);
MongoServer server = client.GetServer();
MongoDatabase db = server.GetDatabase(“test”);
MongoCollection coll = db.GetCollection(“test”);
注:设置驱动的ReadReference也可以通过MongoDB连接字符串配置:
mongodb://example1.com,example2.com,example3.com/?readPreference=secondary。通过连接字符串指定的read
preference是针对整个连接。
set.ReadPreference = new ReadPreference(ReadPreferenceMode.PrimaryPreferred);
将ReadPreferenceMode设置成Secondary或SecondaryPreferred
付出余切
- 粉丝: 200
- 资源: 912
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功
评论0