`
rsljdkt
  • 浏览: 454366 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

MongoDB初探

    博客分类:
  • DB
阅读更多

概述

MongoDB是一个高性能、分布式、无模式的开源数据库数据库支持类似关型数据库的主从结构,文档以二进制Json形式存储,无锁,无事务,有索引。 C++语言编写。旨在为WEB应用提供可护展的高性能数据存储解决方案。 

它的特点是高性能、易部署、易使用,存储数据非常方便。

一、主要功能特性

面向集合存储。易存储对象类型的数据及JSON形式的数据。 

模式自由

动态查询。支持丰富的查询表达式。查询指令使用JSON形式的标记,可轻易查询文档中内嵌的对象及数组。

完全索引。 

复制和自动故障转移Mongo数据库支持服务器之间的数据复制,支持主-从模式及服务器之间的相互复制。复制的主要目标是提供冗余及自动故障转移。  使用高效的二进制数据存储,包括大型对象(如视频等)。

自动处理碎片,以支持云计算层次的扩展性

支持RUBYPYTHONJAVAC#C++PHP等多种语言。

文件存储格式为BSON(一种JSON的扩展)

可通过网络访 


面向集合Collenction-Orented),意思是数据被分组存储在数据集中,被称为一个集合(Collenction)。每个集合在数据库中都有一个唯一的标识名,并且可以包含无限数目的文档。集合的概念类似关系型数据库(RDBMS)里的表(table),不同的是它不需要定义任何模式(schema)
模式自由schema-free),意味着对于存储在mongodb数据库中的文件,我们不需要知道它的任何结构定义。如果需要的话,你完全可以把不同结构的文件存储在同一个数据库里。 文档存储在集合中,被存储为键-值对的形式。键用于唯一标识一个文档,为字符串类型,而值则可以是各中复杂的文件类型。我们称这种存储形式为BSONBinary Serialized dOcument Format)。

二、应用范围和限制

MongoDB的主要目标是在键/值存储方式(提供了高性能和高度伸缩性)以及传统的RDBMS系统(丰富的功能)架起一座桥梁,集两者的优势于一身。根据官方网站的描述,Mongo适合用于以下场景:

网站数据:Mongo非常适合实时的插入,更新与查询,并具备网站实时数据存储所需的复制及高度伸缩性。

缓存:由于性能很高,Mongo也适合作为信息基础设施的缓存层。在系统重启之后,由Mongo搭建的持久化缓存层可以避免下层的数据源过载。

大尺寸,低价值的数据:使用传统的关系型数据库存储一些数据时可能会比较昂贵,在此之前,很多时候程序员往往会选择传统的文件进行存储。

高伸缩性的场景:Mongo非常适合由数十或数百台服务器组成的数据库。Mongo的路线图中已经包含对MapReduce引擎的内置支持。

用于对象及JSON数据的存储:MongoBSON数据格式非常适合文档化格式的存储及查询。

自然,MongoDB的使用也会有一些限制,例如它不适合:

高度事务性的系统:例如银行或会计系统。传统的关系型数据库目前还是更适用于需要大量原子性复杂事务的应用程序。

传统的商业智能应用:针对特定问题的BI数据库会对产生高度优化的查询方式。对于此类应用,数据仓库可能是更合适的选择。

需要SQL的问题

MongoDB支持OS XLinuxWindows等操作系统,并提供了PythonPHPRubyJavaC++语言的驱动程序,社区中也提供了对Erlang.NET等平台的驱动程序。

三、运行环境

MongoDB服务端可运行在LinuxWindowsOS X平台,支持32位和64位应用,默认端口为27017。推荐运行在64位平台,因为MongoDB32位模式运行时支持的最大文件尺寸为2GB

四、参考推荐

迁移案例:

1. WordnikMongoDB使用经验http://www.infoq.com/cn/news/2010/11/wordnik-mongodb 

2. 视觉中国的NoSQL之路:从MySQLMongoDBhttp://www.programmer.com.cn/4199/

3. Choosing a non-relational database; why we migrated from MySQL to MongoDB

http://blog.boxedice.com/2009/07/25/choosing-a-non-relational-database-why-we-migrated-from-mysql-to-mongodb/ 

4. David Mytton为什么从MySQL迁移到MongoDB数据库  http://www.iteye.com/topic/748322 

性能评测:

1. MongoDBHandlerSocketMySQL性能测试及其结果分析http://blog.nosqlfan.com/html/1329.html 

2. MySQLMongoDB的性能测试http://www.oschina.net/bbs/thread/10930 

3. mongodb有关的研究http://www.cnblogs.com/lovecindywang/archive/2010/05/16/1736934.html 

MongoDB安装与启动

测试环境:Win2008R2 x64 + MongoDB1.8

推荐下载版本1.8x86_64

下载链接:http://downloads.mongodb.org/win32/mongodb-win32-x86_64-1.8.0.zip

安装:

1. 将下在的压缩包解压到磁盘某路径下(如D:\mongo)。

2. 创建D:\mongo\data目录(用于存放数据库文件)

启动:

方式一(CMD方式):

打开CMD窗口,D:\mongo\mongod.exe -dbpath D:\mongo\data

注意,此CMD窗口不要关闭

方式二(Windows服务方式)

打开CMD窗口,D:\mongo\bin\mongod.exe -dbpath D:\mongo\data -install

以后就不需要每次使用CMD打开服务了

测试

打开CMD窗口,

D:\mongodb\bin>mongo.exe 

D:\A\mongodb\bin>mongo.exe

MongoDB shell version: 1.8.0

connecting to: test

> db.foo.save({foo:'bar',hello:'world'})

> db.foo.find()

{ "_id" : ObjectId("4d843f4574cc3f74d85eee36"), "foo" : "bar", "hello" : "world"

 }

>

说明:

启动服务时,可以使用-port参数指定服务端口,默认是27017

启动服务时,可以使用-logpath参数指定日志文件,默认控制台输出

启动服务时,可以使用-logappend参数指定日志模式为追加,默认覆盖

 

MongoDB数据访问(C#版)

测试环境:Win2008R2 x64 + MongoDB1.8 + VS2010

首先下个C#的驱动,MongodB提供了各种语言的驱动

C# 驱动下载地址:https://github.com/mongodb/mongo-csharp-driver/downloads 

C# 驱动教程:http://www.mongodb.org/display/DOCS/CSharp+Driver+Tutorial 

下载后,将MongoDB.Bson.dllMongodB.Driver.dll添加到项目引用中

 

 

Mongo连接字符串:

mongodb://[username:password@][hostname1[:port1], ...][/[database][?options]] 

该字符串可以指定用户登录认证和主机列表

MongoServer 创建:

  MongoServer Create()   如果只是连接本机,并且本机只启动了一个服务,直  接调用这个方法,完全不需要连接串
  MongoServer Create(MongoConnectionStringBuilder builder)
  MongoServer Create(MongoUrl url)
  MongoServer Create(string connectionString)
  MongoServer Create(Uri uri)

代码如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

using MongoDB.Bson;
using MongoDB.Driver;

namespace MongoDBStart
{
    class Program
    {
        static void Main(string[] args)
        {
            string ConnStr = "mongodb://localhost";//数据库连接字符串
            MongoServer m = MongoServer.Create(ConnStr);
            MongoDatabase db = m.GetDatabase("db_test");//获得数据库db_test,没有则创建
            MongoCollection c = db.GetCollection("students");//获得集合students,没有则创建
            c.CreateIndex(new string[] { "NO" });//在NO上创建索引
            //创建学生
            BsonDocument student = new BsonDocument
            {
                {"NO","1000"},
                {"Name","Name1"}
            };
            c.Insert(student);//插入到集合中
            BsonDocument Res = c.FindOneAs<BsonDocument>();//返回第一个文档
            Console.WriteLine("学号:{0},姓名:{1}", Res["NO"].AsString, Res["Name"].AsString);
            m.Disconnect();
            Console.ReadKey();
        }
    }
}

 

 

 

2
4
分享到:
评论

相关推荐

    MongoDB初探(二)----使用spring-data配置mongodb

    在本篇“MongoDB初探(二)----使用spring-data配置mongodb”中,我们将深入探讨如何利用Spring Data框架来集成和操作MongoDB数据库。Spring Data是Spring生态系统的一个重要组成部分,它提供了与各种数据存储系统...

    mongodb初体验

    这篇文章将带你初探MongoDB的世界,了解其基本概念、安装过程以及如何进行基本操作。 1. **MongoDB的基本概念** - **文档数据库**:MongoDB以JSON格式的文档存储数据,这种格式允许嵌套结构,更接近于程序员的工作...

    NoSql数据库初探-mongoDB环境搭建

    【MongoDB概述】 MongoDB是一种流行的NoSQL数据库系统,它以文档存储为核心,采用BSON(Binary JSON)格式存储数据,具有高度灵活性和扩展性。MongoDB的主要特点是面向文档存储,支持全索引,具备高效的同步机制和...

    Node.js后端技术初探.pdf

    "Node.js后端技术初探" Node.js 是一个基于JavaScript 的服务器端运行时环境,允许开发者使用JavaScript语言来编写服务器端代码。Node.js 的出现改变了传统的服务器端开发模式,提供了一个高效、灵活的服务器端...

    pring初探共18页.pdf.zip

    6. **数据访问**:Spring对各种持久化技术的支持,如JDBC、ORM框架(Hibernate、MyBatis),以及Spring Data JPA和Spring Data MongoDB等。 7. **Spring Boot**:现代Spring应用的快速启动框架,介绍其特性,如自动...

    Node-express-mongoose-Blog:使用node+express+mongoDB实现的个人博客系统用户登录注册模板

    Node开发个人博客系统初探,目前实现了登录注册功能,后续将继续更新博文展示、内容预览、评论以及后台的管理功能,欢迎关注~ 功能 前台登录注册/切换 Mongodb数据库的使用 用户注册逻辑 基于数据库的注册验证和...

    Spring Boot 初探 | 第一篇:第一个Spring Boot程序(示例程序)

    **Spring Boot 初探:构建你的第一个应用** Spring Boot 是由 Pivotal 团队提供的全新框架,旨在简化 Spring 应用程序的初始搭建以及开发过程。它集成了大量常用的第三方库配置,如 JDBC、MongoDB、JPA、RabbitMQ、...

    php笔记之:初探PHPcms模块开发介绍

    由于工作关系,只能暂时放弃对mongodb的研究了 .开始研究PHPcms . 目前为止我已经基本完成了模块的开发.趁着周末来这里做个总结.我发现phpcms写的还不错,不过文档什么的确实不多. 不说废话了.对于phpcms的模块开发....

    BigDataProject:这是我的大数据类项目

    大数据生态链初探。 目录 因配置环境只需要一篇文档,这里把配置环境的说明统一文件放到Documentations文件夹下。 环境安装与Hello-World DEMO 核心环境搭建 ---依赖[0] ---依赖[1] ---依赖[1] ---依赖[3] spark探索...

    腾讯微博实现一

    例如,为了处理用户发布的大量微博,腾讯可能采用了分布式数据库系统,如HBase或MongoDB,以实现数据的快速写入和读取。同时,为了提高访问速度,可能会利用Redis等内存数据库进行数据缓存。 其次,消息推送是微博...

    2013年中国数据库大会PPT第一部分

    12.MongoDB at Qihoo 360.pdf 13.MySQL Cluster实战初探 .pdf 14.SAP HANA深度剖析.pdf 15.eXtremeDB内存数据库性能提升方案分享.pdf 16.运用之妙 存乎一心—— Oracle优化器案例与算法解析.pdf 17.DM7 MPP架构——...

    simpleToDoApp

    【简易待办事项应用——初探全栈开发与基础技术】 在编程世界中,全栈开发者是指能够处理从客户端到服务器端所有层面的开发者。在这个名为"simpleToDoApp"的项目中,我们可以看到一个初学者如何通过实践来掌握全栈...

    2013中国数据库大会ppt(1)

    MongoDB at Qihoo 360.pdf MySQL Cluster实战初探 .pdf SAP HANA深度剖析.pdf eXtremeDB内存数据库性能提升方案分享.pdf 运用之妙 存乎一心—— Oracle优化器案例与算法解析.pdf DM7 MPP架构——同时满足OLAP与OLTP...

    2013中国数据大会ppt(2)

    MongoDB at Qihoo 360.pdf MySQL Cluster实战初探 .pdf SAP HANA深度剖析.pdf eXtremeDB内存数据库性能提升方案分享.pdf 运用之妙 存乎一心—— Oracle优化器案例与算法解析.pdf DM7 MPP架构——同时满足OLAP与OLTP...

    2013中国数据库大会ppt(3)

    MongoDB at Qihoo 360.pdf MySQL Cluster实战初探 .pdf SAP HANA深度剖析.pdf eXtremeDB内存数据库性能提升方案分享.pdf 运用之妙 存乎一心—— Oracle优化器案例与算法解析.pdf DM7 MPP架构——同时满足OLAP与OLTP...

    spring 课件下载

    1. **Spring初探** 在这一章中,我们将从Spring框架的基础出发,介绍其诞生背景和主要目标。我们会讲解Spring如何简化Java应用的开发,以及它提供的依赖注入(Dependency Injection, DI)机制,这是Spring的核心...

    Postgresql中国用户大会 2016(PG大象会)所有PPT汇总.zip

    张友东-阿里云-MongoDB分布式架构演进.pdf 兰海-武汉大学-从PostgreSQL实现Flashback谈如何内核开发.pdf 赵振平-太阳塔科技-工业大数据初探.pdf 李跃森-腾讯科技-PGXZ在微信支付中的应用.pdf 钟勇-上海宝存...

    HR原型系统 自己做的

    《HR原型系统设计初探》 在信息化管理日益重要的今天,人力资源(HR)管理系统作为企业运营的核心组成部分,其设计与实现对于提升企业效率、优化人力资源配置具有重要意义。本篇文章将围绕一个由个人独立完成的“HR...

Global site tag (gtag.js) - Google Analytics