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