溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

如何三步集成MongoDB + Spring Boot

發(fā)布時(shí)間:2021-09-29 09:37:32 來源:億速云 閱讀:225 作者:柒染 欄目:大數(shù)據(jù)

如何三步集成MongoDB + Spring Boot,很多新手對此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。

第一步 部署mongo數(shù)據(jù)庫

部署mongodb,具體就按自己的需要來,大致還是兩類吧,一類是直接下載安裝,無關(guān)windows,linux。另一類是容器啟動。

這里主要介紹使用docker啟動一個(gè)mongodb的容器。

docker里一共有二種方式。

一、是直接用命令拉取并啟動
docker run -d --network some-network --name some-mongo \
    -v /my/own/datadir:/data/db \
    -e MONGO_INITDB_ROOT_USERNAME=mongoadmin \
    -e MONGO_INITDB_ROOT_PASSWORD=secret \
    mongo

具體詳細(xì)的其他參數(shù)可以在網(wǎng)站https://hub.docker.com/_/mongo 里面找到。

二、使用yml配置文件啟動

下面附上我的yml文件,可供參考

version: "3.7"
services:
  mangodb:
    image: mongo:latest
    restart: always
    networks:
      - loc_net
    ports:
      - 27017:27017
    volumes:
      - /myPath/mongo/db:/data/db
    environment:
      MONGO_INITDB_ROOT_USERNAME: username
      MONGO_INITDB_ROOT_PASSWORD: password
    deploy:
      replicas: 1
      placement:
        constraints: [node.role == manager]
networks:
  loc_net:
    external: true

https://hub.docker.com/_/mongo 里也有更詳細(xì)的配置。

需要注意的一點(diǎn)是

如何三步集成MongoDB + Spring Boot 簡單的說,如果宿主機(jī)映射的目錄下已經(jīng)有數(shù)據(jù)庫數(shù)據(jù),那么初始化的用戶名和密碼將不生效。

關(guān)于mongo的配置文件的目錄:

如何三步集成MongoDB + Spring Boot

第二步 配置mongodb數(shù)據(jù)源

引入maven依賴

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-mongodb</artifactId>
</dependency>

在spring boot項(xiàng)目里配置

spring:
  data:
    mongodb:
    uri: mongodb://username:password@127.0.0.1:27017/test?authSource=admin&readPreference=primary&ssl=false

authSource:指定用戶身份認(rèn)證數(shù)據(jù)庫readPreference:設(shè)置讀優(yōu)先節(jié)點(diǎn)ssl:使用ssl連接

mysql差不多,這里是單數(shù)據(jù)源的配置,如果是多數(shù)據(jù)源的配置也很簡單,可以到https://docs.mongodb.com/manual/mongo/自行查看,包括所有的連接參數(shù)。

第三步 注入使用

單數(shù)據(jù)源,普通的使用,并不需要在spring工廠重新注入,直接使用即可。

@Autowired
private MongoTemplate mongoTemplate;

而且mongo的sdk本身已經(jīng)比較上層,直接使用很方便。 如何三步集成MongoDB + Spring Boot

對于mongo的CRUD操作,請到https://docs.mongodb.com/manual/crud/學(xué)習(xí)。
(1)關(guān)于內(nèi)存型數(shù)據(jù)庫的理解:

數(shù)據(jù)文件還是存儲磁盤中,但是在內(nèi)存中有他自己的數(shù)據(jù)庫緩存區(qū),對于需要讀取的數(shù)據(jù)會通過MMAP映射,讀入緩存區(qū),大大加快查詢數(shù)據(jù)。

(2)關(guān)于mongo和mysql的簡單對比:

一、主要區(qū)別,mongo是非關(guān)系型數(shù)據(jù)庫,mysql是關(guān)系型數(shù)據(jù)庫。

二、mysql不同的存儲引擎不同的存儲方式,大多還是磁盤IO為主。mongo是虛擬內(nèi)存加持久化,正如上面說的,利用了內(nèi)存讀取。內(nèi)存讀取數(shù)據(jù)遠(yuǎn)超磁盤IO,這也是mongo查詢遠(yuǎn)超mysql的原因。

三、mysql穩(wěn)定性更好。事務(wù)性很強(qiáng),而mongo事務(wù)支持不強(qiáng)。

四、關(guān)于mysql和mongo的插入和查詢的性能對比,推薦這篇文章https://www.cnblogs.com/liaocheng/p/4237091.html

五、在mongo中的主鍵是“_id”,不指定主鍵mongo會自己生成一個(gè),不指定主鍵插入的速度要比指定主鍵快。

看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識有進(jìn)一步的了解或閱讀更多相關(guān)文章,請關(guān)注億速云行業(yè)資訊頻道,感謝您對億速云的支持。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI