MongoDB 是最先熱門非關係數據庫的之一,使用也比較廣泛,通常會用作離線數據分析來使用,放到內網的居多。因爲不少公司使用了雲服務,服務器默認都開放了外網地址,致使前一陣子大批 MongoDB 因配置漏洞被攻擊,數據被刪,引發了人們的注意,感興趣的能夠看看這篇文章:場屠戮MongoDB的盛宴反思:超33000個數據庫遭遇入侵勒索,同時也說明了不少公司生產中大量使用mongodb。html
MongoDB(來自於英文單詞「Humongous」,中文含義爲「龐大」)是能夠應用於各類規模的企業、各個行業以及各種應用程序的開源數據庫。基於分佈式文件存儲的數據庫。由C++語言編寫。旨在爲 WEB 應用提供可擴展的高性能數據存儲解決方案。MongoDB 是一個高性能,開源,無模式的文檔型數據庫,是當前 NoSql 數據庫中比較熱門的一種。java
MongoDB 是一個介於關係數據庫和非關係數據庫之間的產品,是非關係數據庫當中功能最豐富,最像關係數據庫的。他支持的數據結構很是鬆散,是相似 json 的 bjson 格式,所以能夠存儲比較複雜的數據類型。MongoDB 最大的特色是他支持的查詢語言很是強大,其語法有點相似於面向對象的查詢語言,幾乎能夠實現相似關係數據庫單表查詢的絕大部分功能,並且還支持對數據創建索引。git
傳統的關係數據庫通常由數據庫(database)、表(table)、記錄(record)三個層次概念組成,MongoDB 是由數據庫(database)、集合(collection)、文檔對象(document)三個層次組成。MongoDB 對於關係型數據庫裏的表,可是集合中沒有列、行和關係概念,這體現了模式自由的特色。github
MongoDB 中的一條記錄就是一個文檔,是一個數據結構,由字段和值對組成。MongoDB 文檔與 JSON 對象相似。字段的值有可能包括其它文檔、數組以及文檔數組。MongoDB 支持 OS X、Linux 及 Windows 等操做系統,並提供了 Python,PHP,Ruby,Java及 C++ 語言的驅動程序,社區中也提供了對 Erlang 及 .NET 等平臺的驅動程序。spring
MongoDB 的適合對大量或者無固定格式的數據進行存儲,好比:日誌、緩存等。對事物支持較弱,不適用複雜的多文檔(多表)的級聯查詢。文中演示 Mongodb 版本爲 3.5。mongodb
Spring Boot 對各類流行的數據源都進行了封裝,固然也包括了 Mongodb,下面給你們介紹如何在 Spring Boot 中使用 Mongodb:數據庫
pom 包裏面添加 spring-boot-starter-data-mongodb
包引用json
<dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-mongodb</artifactId> </dependency> </dependencies>
spring.data.mongodb.uri=mongodb://name:pass@localhost:27017/test
多個 IP 集羣能夠採用如下配置:數組
spring.data.mongodb.uri=mongodb://user:pwd@ip1:port1,ip2:port2/database
public class User implements Serializable { private static final long serialVersionUID = -3258839839160856613L; private Long id; private String userName; private String passWord; //getter、setter省略 }
Repository 層實現了 User 對象的增刪改查緩存
@Component public class UserRepositoryImpl implements UserRepository { @Autowired private MongoTemplate mongoTemplate; /** * 建立對象 * @param user */ @Override public void saveUser(User user) { mongoTemplate.save(user); } /** * 根據用戶名查詢對象 * @param userName * @return */ @Override public User findUserByUserName(String userName) { Query query=new Query(Criteria.where("userName").is(userName)); User user = mongoTemplate.findOne(query , User.class); return user; } /** * 更新對象 * @param user */ @Override public long updateUser(User user) { Query query=new Query(Criteria.where("id").is(user.getId())); Update update= new Update().set("userName", user.getUserName()).set("passWord", user.getPassWord()); //更新查詢返回結果集的第一條 UpdateResult result =mongoTemplate.updateFirst(query,update,User.class); //更新查詢返回結果集的全部 // mongoTemplate.updateMulti(query,update,UserEntity.class); if(result!=null) return result.getMatchedCount(); else return 0; } /** * 刪除對象 * @param id */ @Override public void deleteUserById(Long id) { Query query=new Query(Criteria.where("id").is(id)); mongoTemplate.remove(query,User.class); } }
@RunWith(SpringRunner.class) @SpringBootTest public class UserDaoTest { @Autowired private UserDao userDao; @Test public void testSaveUser() throws Exception { UserEntity user=new UserEntity(); user.setId(2l); user.setUserName("小明"); user.setPassWord("fffooo123"); userDao.saveUser(user); } @Test public void findUserByUserName(){ UserEntity user= userDao.findUserByUserName("小明"); System.out.println("user is "+user); } @Test public void updateUser(){ UserEntity user=new UserEntity(); user.setId(2l); user.setUserName("天空"); user.setPassWord("fffxxxx"); userDao.updateUser(user); } @Test public void deleteUserById(){ userDao.deleteUserById(1l); } }
可使用工具 MongoVUE 工具來鏈接後直接圖形化展現查看,也能夠登陸服務器用命令來查看
1.登陸 mongos
bin/mongo -host localhost -port 20000
二、切換到 test 庫
use test
三、查詢 user 集合數據
db.user.find()
根據3查詢的結果來觀察測試用例的執行是否正確。
到此 Spring Boot 對應 MongoDB 的增刪改查功能已經所有實現。
接下來實現 MongoDB 多數據源的使用
<dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-mongodb</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> </dependency> </dependencies>
mongodb.primary.uri=mongodb://192.168.0.75:20000 mongodb.primary.database=primary mongodb.secondary.uri=mongodb://192.168.0.75:20000 mongodb.secondary.database=secondary
封裝讀取以 Mongodb 開頭的兩個配置文件
@Data @ConfigurationProperties(prefix = "mongodb") public class MultipleMongoProperties { private MongoProperties primary = new MongoProperties(); private MongoProperties secondary = new MongoProperties(); }
配置不一樣包路徑下使用不一樣的數據源
第一個庫的封裝
@Configuration @EnableMongoRepositories(basePackages = "com.neo.model.repository.primary", mongoTemplateRef = PrimaryMongoConfig.MONGO_TEMPLATE) public class PrimaryMongoConfig { protected static final String MONGO_TEMPLATE = "primaryMongoTemplate"; }
第二個庫的封裝
@Configuration @EnableMongoRepositories(basePackages = "com.neo.model.repository.secondary", mongoTemplateRef = SecondaryMongoConfig.MONGO_TEMPLATE) public class SecondaryMongoConfig { protected static final String MONGO_TEMPLATE = "secondaryMongoTemplate"; }
讀取對應的配置信息而且構造對應的 MongoTemplate
@Configuration public class MultipleMongoConfig { @Autowired private MultipleMongoProperties mongoProperties; @Primary @Bean(name = PrimaryMongoConfig.MONGO_TEMPLATE) public MongoTemplate primaryMongoTemplate() throws Exception { return new MongoTemplate(primaryFactory(this.mongoProperties.getPrimary())); } @Bean @Qualifier(SecondaryMongoConfig.MONGO_TEMPLATE) public MongoTemplate secondaryMongoTemplate() throws Exception { return new MongoTemplate(secondaryFactory(this.mongoProperties.getSecondary())); } @Bean @Primary public MongoDbFactory primaryFactory(MongoProperties mongo) throws Exception { return new SimpleMongoDbFactory(new MongoClient(mongo.getHost(), mongo.getPort()), mongo.getDatabase()); } @Bean public MongoDbFactory secondaryFactory(MongoProperties mongo) throws Exception { return new SimpleMongoDbFactory(new MongoClient(mongo.getHost(), mongo.getPort()), mongo.getDatabase()); } }
兩個庫的配置信息已經完成。
對應能夠共用
public class User implements Serializable { private static final long serialVersionUID = -3258839839160856613L; private String id; private String userName; private String passWord; public User(String userName, String passWord) { this.userName = userName; this.passWord = passWord; } }
對應的 Repository
public interface PrimaryRepository extends MongoRepository<PrimaryMongoObject, String> { }
繼承了 MongoRepository 會默認實現不少基本的增刪改查,省了不少本身寫 Repository 層的代碼
Secondary 和上面的代碼相似就不貼出來了
@RunWith(SpringRunner.class) @SpringBootTest public class MuliDatabaseTest { @Autowired private PrimaryRepository primaryRepository; @Autowired private SecondaryRepository secondaryRepository; @Test public void TestSave() { System.out.println("************************************************************"); System.out.println("測試開始"); System.out.println("************************************************************"); this.primaryRepository .save(new PrimaryMongoObject(null, "第一個庫的對象")); this.secondaryRepository .save(new SecondaryMongoObject(null, "第二個庫的對象")); List<PrimaryMongoObject> primaries = this.primaryRepository.findAll(); for (PrimaryMongoObject primary : primaries) { System.out.println(primary.toString()); } List<SecondaryMongoObject> secondaries = this.secondaryRepository.findAll(); for (SecondaryMongoObject secondary : secondaries) { System.out.println(secondary.toString()); } System.out.println("************************************************************"); System.out.println("測試完成"); System.out.println("************************************************************"); } }
到此,MongoDB 多數據源的使用已經完成。
文章內容已經升級到 Spring Boot 2.x