1.redis
2.memcached
3.MongoDB
3.1 MongoDB下载及安装
3.2 mongo使用-客户端
3.3 mongo使用-java
3.4 mongo使用-spring
3.MongoDB
MongoDB是适用于海量数据,大量查询的业务场景-如评论等
要使用新技术如评论系统中MongoDB替换mysql,总要适应一段时间,总觉得用老技术稳定合理点。换个角度看,如果MongoDB比mysql先出现或同时出现,现在MongoDB与mysql的市场份额又是另一番景象了
MongoDB为非关系型数据库,其结构为数据库(dbs)-集合(collections)-文档(行记录)。既然mongoDb是非关系型数据,可不可按照在spring中连接池哪样连接mongodb,其开发模式可不可以按照mvc来设计呢
3.1 MongoDB下载及安装
https://www.mongodb.com/download-center#community
下载windows相应版本,并进行安装
complete安装成功后,在win7的C:\Program Files\MongoDB\Server\3.4(具体以本机系统为准)存在bin文件夹,复制到自己定义的位置,如D:\\service\\mongodb,并在该根目录下新建logs/mongodb.log和db文件夹
cmd进入根目录(如:D:\\service\\mongodb)运行:
D:\service\mongodb\bin>
mongod.exe --dbpath=d:\service\mongodb\db
最后一行表明启动成功,监听端口27017
3.2 mongo使用-客户端
进入根目录/bin:
>mongo
>use test
>db.foo.save({hello:1,world:2})
>db.foo.find()
D:\service\mongodb\bin>mongo
MongoDB shell version v3.4.4
connecting to: mongodb://127.0.0.1:27017
MongoDB server version: 3.4.4
Welcome to the MongoDB shell.
For interactive help, type "help".
For more comprehensive documentation, see
http://docs.mongodb.org/
Questions? Try the support group
http://groups.google.com/group/mongodb-user
Server has startup warnings:
2017-06-11T18:28:48.031+0800 I CONTROL [initandlisten]
2017-06-11T18:28:48.032+0800 I CONTROL [initandlisten] ** WARNING: Access contr
ol is not enabled for the database.
2017-06-11T18:28:48.032+0800 I CONTROL [initandlisten] ** Read and wri
te access to data and configuration is unrestricted.
2017-06-11T18:28:48.034+0800 I CONTROL [initandlisten]
2017-06-11T18:28:48.034+0800 I CONTROL [initandlisten] Hotfix KB2731284 or late
r update is not installed, will zero-out data files.
2017-06-11T18:28:48.035+0800 I CONTROL [initandlisten]
> use test
switched to db test
> db.foo.save({hello:1,world:2})
WriteResult({ "nInserted" : 1 })
> db.foo.find()
{ "_id" : ObjectId("593d1c630c25a36a368ddcfe"), "hello" : 1, "world" : 2 }
> exit
bye
D:\service\mongodb\bin>
#查询所有数据库
> show dbs
#显示当前使用的数据库
> db
#添加用户(类似数据库登录用户)
> use admin
> db.createUser({user:'sa',pwd:'sa',roles:['dbAdminAnyDatabase']})
老版本为db.addUser('sa','sa')
> db.auth("sa","sa")
具体角色:
Read:允许用户读取指定数据库
readWrite:允许用户读写指定数据库
dbAdmin:允许用户在指定数据库中执行管理函数,如索引创建、删除,查看统计或访问system.profile
userAdmin:允许用户向system.users集合写入,可以找指定数据库里创建、删除和管理用户
clusterAdmin:只在admin数据库中可用,赋予用户所有分片和复制集相关函数的管理权限。
readAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的读权限
readWriteAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的读写权限
userAdminAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的userAdmin权限
dbAdminAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的dbAdmin权限。
root:只在admin数据库中可用。超级账号,超级权限
创建用户后,需重启mongodb服务,才能使用授权机制:
mongod.exe --dbpath=d:\service\mongodb\db -auth
#删除用户
> db.system.users.remove({user:"sa"})
#查询所有表
> show collections
#查询所有用户
> db.system.users.find()
#停止数据库
> db.shutdownServer()
#创建集合(表)
> db.createCollection("table1")
#删除集合drop
> db.foo.drop()
#修改文档update
> db.foo.update({"hello":1},{"hello":"2"})
#表数据量统计
> db.foo.count()
#帮助
> db.user.help()
3.3 mongoDB使用-java
package com.byron.mongodb.client;
import java.util.ArrayList;
import java.util.List;
import org.bson.Document;
import com.mongodb.MongoClient;
import com.mongodb.MongoCredential;
import com.mongodb.ServerAddress;
import com.mongodb.client.MongoCollection;
import com.mongodb.client.MongoDatabase;
public class MongoDBClient {
public static void main(String[] args) {
MongoClient mongoClient = null;
try {
ServerAddress serverAddress = new ServerAddress("localhost",27017);
List<ServerAddress> addrs = new ArrayList<ServerAddress>();
addrs.add(serverAddress);
//MongoCredential.createScramSha1Credential()三个参数分别为 用户名 数据库名称 密码
// dba为数据库中创建的用户,角色为dbAdminAnyDatabase,只能在admin中使用
// db.createUser({user:'dba',pwd:'dba',roles:['dbAdminAnyDatabase']})
MongoCredential credential = MongoCredential.createScramSha1Credential("dba", "admin", "dba".toCharArray());
List<MongoCredential> credentials = new ArrayList<MongoCredential>();
credentials.add(credential);
//通过连接认证获取MongoDB连接
mongoClient = new MongoClient(addrs,credentials);
//连接到数据库
MongoDatabase db = mongoClient.getDatabase("sa");
System.out.println("Connect to database successfully");
//创建集合 参数为 “集合名称”
db.createCollection("t2");
System.out.println("Collection created successfully");
//获取集合 参数为“集合名称”
MongoCollection<Document> mongoCollection = db.getCollection("t2");
System.out.println("Collection mycol selected successfully");
//插入文档
Document document = new Document("title", "hello").
append("description", "world");
List<Document> documents = new ArrayList<Document>();
documents.add(document);
mongoCollection.insertMany(documents);
System.out.println("Document inserted successfully");
} catch (Exception e) {
System.err.println( e.getClass().getName() + ": " + e.getMessage() );
} finally{
if (null != mongoClient) {
try {
mongoClient.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
}
}
对mongoDB数据库操作其实类似java通过jdbc接口对关系型数据库的操作类似,只不过接口的名字不一样
3.4 mongodb使用-spring
参考:
MongoDB 3.X 用户权限控制
http://www.cnblogs.com/shiyiwen/p/5552750.html
Win7下MongoDB的安装和部署测试
http://jingyan.baidu.com/article/f3e34a12ac10cef5eb653583.html
Mongodb安装 for windows7 64位
http://www.cnblogs.com/ajunForNet/p/4517456.html
https://www.mongodb.com
- 大小: 24.2 KB
- 大小: 46.2 KB
分享到:
相关推荐
解压后使用,版本:logstash-input-mongodb-0.4.1 logstash离线包安装命令: Windows:logstash-plugin install file:///D:/logstash-7.5.0/logstash-input-mongodb/logstash-input-mongodb-0.4.1.zip Linux:...
Spring Data MongoDB项目是Spring框架的一部分,它提供了一个方便的API来操作MongoDB数据库,使得开发人员可以更高效地进行数据存储和检索。 **1. Spring Data MongoDB简介** Spring Data MongoDB提供了与MongoDB...
《Logstash-input-mongodb插件详解与应用》 在大数据处理和日志分析领域,Logstash以其强大的数据收集、处理和转发能力而被广泛应用。在本文中,我们将深入探讨一个关键组件——logstash-input-mongodb插件,以及...
总结来说,`node-red-contrib-mongodb2` 是 Node-RED 平台上用于与 MongoDB 交互的重要工具,它极大地简化了数据处理流程,并提供了丰富的 MongoDB 功能,适用于各种需要数据库集成的场景。通过熟练掌握和运用这个库...
Studio3T mac 加 data-man-mongodb-ent-2019.3.0.jar
(3) 修改logstash目录下的 Gemfile 文件 添加配置 gem "logstash-input-mongodb", :path => "./logstash-input-mongodb-master" (4) logstash bin目录下执行 logstash-plugin install --no-verify 命令安装 ...
percona-backup-mongodb-1.6.1-1.el7.x86_64.rpm、 percona-backup-mongodb-1.6.1-1.el8.x86_64.rpm、 percona-backup-mongodb-1.6.1-x86_64.tar.gz、 percona-backup-mongodb_1.6.1-1.bionic_amd64.deb、 percona-...
spring-data-mongodb增强工具包,简化 CRUD 操作,提供类mybatis plus的数据库操作。传统关系型数据库及围绕它们构建的orm在项目开发中有很多难用的痛点,而mongodb这种文档性数据库的出现,完美的解决了sql数据库在...
Spring集成MongoDB官方指定jar包:spring-data-mongodb-1.4.1.RELEASE.jar
Spring Data MongoDB 提供了高级抽象,使得开发人员能够以一种声明式的方式处理 MongoDB 数据存储,减少了对低级 API 的直接调用,从而提高了开发效率。 1. **核心概念** - **MongoTemplate**:这是 Spring Data ...
spring支持mongodb的jar包
spring-data-mongodb-referrence-docs-1.9.4
spring-data-mongodb-1.8.0.RELEASE.jar
Spring-data-mongodb的文档太少了,基本都是网页版,我把网页做成了chm方便开发人员查看,文档是英文原版,是从官网抓下来的
spring整合mongodb3.0的jar包,据说已经解决了最新用户验证的问题
Spring Data MongoDB 是 Spring Data 项目的一部分,旨在简化 MongoDB 数据访问,并提供一个一致的编程模型,该模型适用于 Spring Framework 中的所有数据存储技术。Spring Data MongoDB 1.5.4 版本为开发者提供了更...
Spring Data MongoDB 是一个为 MongoDB 文档数据库提供数据访问支持的框架,它属于 Spring Data 项目的一部分,目的是简化基于 Java 应用的数据访问层的编程工作。通过使用 Spring Data MongoDB,开发人员可以很容易...
在`krules-subjects-storage-mongodb`中,MongoDB被用作后端存储,可以提供高效的数据查询和操作能力。 **版本号0.8.5** 版本号0.8.5表示这是该模块的第8次重大更新后的第五个小版本。通常,版本号的增加意味着...
connect-mongodb-session, 轻量级MongoDB支持用于连接和表达的会话存储 connect-mongodb-session:用于连接的-backed会话存储和 Express 。 这意味着它是一个很好的维护和完全功能的模块,如连接 mongo 。 ...
Spring Data MongoDB是一个强大的Java库,它为开发人员提供了一种简单而有效的方式来集成Spring应用程序与...无论你是构建简单的单体应用还是复杂的分布式系统,这个库都能帮助你快速、高效地完成数据存储和检索任务。