版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、MongoDB 开发架构实践议程1.连接设置性能相关模型设计架构相关连接设置问题: 1个mongos 不可用,应用整体延迟增高,性能明显下降配置: connection string: mongodb:/mongos1:port,mongos2:port,mongos3:portmongodb version:3.4.13 driver :C 1.5.0连接设置原理:serverSelectionTimeoutMS 30slocalThresholdMS 15ms单线程模式C Drivers连接池模式议程1.连接设置性能相关模型设计架构相关索引索引的选择性索引索引的选择性索引前缀 a: 1,
2、b: 1, c: 1 a: 1 a: 1, b: 1 a: 1, b: 1, c: 1 filtersort. a: 1sort. a: 1, b: 1sort. a: 1, b: 1, c: 1 sort( a: 5 ).sort( b: 1, c: 1 )( a: $gt: 2 ).sort( c: 1 )索引索引的选择性索引前缀复合索引:等值 排序 范围db.restaurants.find( “,avgcost”: $lte: 300cuisine: Sushi).sort(stars: 1)db.restaurants.createIndex( “cuisine”: 1,“stars
3、”: 1,“)avgcost”: 1 等值排序范围索引索引的选择性索引前缀复合索引:等值 排序 范围索引创建foreground:快 锁库Background: 慢 mongoshell不会退出从节点启动到standalone模式,手工创建索引,再加入复制集索引索引的选择性索引前缀复合索引:等值 排序 范围 索引创建$indexStatsdb.collection.aggregate( $indexStats : , $project : key: 1, accesses.ops: 1 ).prettyCRUDupdatedb.foo.find()db.foo.update(a : 5, b
4、: 5, $set : c : 10, upsert : true) db.foo.find() _id : ObjectId(5a014bab2e7289371f61d474), a : 5, b : 5, c : 10 db.collection.update(, , )multi : 犬人falseCRUDupdate Bulk Writedb.collection.bulkWrite( , , . ,writeConcern : ,ordered : )order顺序插入数据,中间出现错误则退出Unorder并行插入,遇到错误不会退出CRUDupdate Bulk Write 写关注
5、w: , j: , wtimeout: w : 数据写入节点后向客户端确人w: 1 犬人w: 0majority”J : 确人写操作写入journalwtimeout: 写入超时时间,仅w大千1时有效CRUDupdate Bulk Write 写关注countdb.collection.count()db.collection.find( a: 5, b: 5 ).count()db.collection.aggregate( $match: , $count: myCount )CRUDupdate Bulk Write 写关注count$inc/post/171353301/using-m
6、ongodb-for-real-time-analytics议程1.连接设置性能相关模型设计架构相关模型设计内嵌引用富JSON、包含关系、对多更快的查询性能关联数据原子更新内嵌大星数据重复且查询无法受益多对多大的层级结构模型设计关注、粉丝信息内嵌在用户集合#users_id : Messi, fullname : LeoMessi, country : Argentina,followers : Neymar, C Ronaldo,following : Neymar, C Ronaldo结构清晰查询快速但是用户集合增长粉丝数星剧增(16M)数组操作代价高模型设计#followers“_id”
7、 : ”ObjectId(),”from : Neymar,”to : Messi“_id” : ”ObjectId(),”from : C Ronaldo,”to : Messi “_id” : ”ObjectId(),”from : Messi,”to : C Ronaldo“_id” : ”ObjectId(),”from : Messi,”to : Neymardb.followers.find( from : “Messi”,_id:0, to:1)挴西关注了谁:db.followers.find( to :“Messi”).count()#索引“v” : 1,“key : “fro
8、m” : 1, “to” : 1 , ”name : ”from_1_to_1 挴西有多少粉丝:#索引“v” : 1,“key : “to” : 1, “from” : 1 , ”name : ”to_1_from_1 模型设计分片#索引“v” : 1,“key : “from” : 1, “to” : 1 , ”name : ”from_1_to_1 “v” : 1,“key : “to” : 1, “from” : 1 , ”name : ”to_1_from_1 targeted to shard使用from分片某人关注了谁#followers“_id” : ”ObjectId(),”f
9、rom : Neymar,”to : Messi#following“_id” : ”ObjectId(),”from : Neymar,”to : Messi原则:平衡应用MongoDB机制 数据读取场景某人被谁关注了scatter-gather to all shards议程1.连接设置性能相关模型设计架构相关系统配置版本数据一致性网络安全硬件配置系统配置架构OSJournal配置认证与权限控制内存大小和WT Cache内核和文件系统选择复制集压缩和加密对硬件的要MongoDB脏读配置通讯加密求启用NTP分片集Driver写关注存储加密SSD和readahead禁用atime压缩算法选择网络监听禁用NUMAulimit配置防火墙SWAP空间禁用Huge Page审计RAID配置禁用SELinuxMongoDB独立账户远程文件系统TLS/SSL库https:/do/禁用服务器端脚本manual/administration/pro分散存储 otesduction-n内存过量(VMWare)https:/do/ma连nu接al池/tu大to小rial/TCP KeepAlive
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025车祸私了和解协议书
- (2024)人造刚玉项目可行性研究报告写作范本(一)
- 2024秋新沪科版物理八年级上册课件 第六章 熟悉而陌生的力 第1节 力及其描述
- 2023年体外循环管路项目筹资方案
- 平安夜圣诞节介绍活动方案215
- 电工(初级工)模拟习题含答案
- 山东省枣庄市2023-2024学年七年级上学期期末考试数学试卷(含解析)
- 养老院老人生活设施定期检查制度
- 养老院老人安全教育培训制度
- 《家庭心理咨询》课件
- 妊娠期贫血课件
- 文学创造的奥妙智慧树知到期末考试答案章节答案2024年山东师范大学
- 涯规未来智慧树知到期末考试答案章节答案2024年云南师范大学
- 青少版新概念3B-U21市公开课一等奖省赛课微课金奖课件
- 储能业务培训
- 2024届新高考物理冲刺复习:“正则动量”解决带电粒子在磁场中的运动问题
- 《印学话西泠》参考课件
- 普通话智慧树知到期末考试答案2024年
- (2024年)大学生考风考纪主题班会课件
- 科技创新专项规划编制工作方案
- 2024年国家粮食和物资储备局直属事业单位招聘笔试参考题库附带答案详解
评论
0/150
提交评论