# SpringBoot 整合 MangoDB **Repository Path**: xxacker/mango-db ## Basic Information - **Project Name**: SpringBoot 整合 MangoDB - **Description**: No description available - **Primary Language**: SQL - **License**: Apache-2.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 2 - **Forks**: 0 - **Created**: 2021-04-17 - **Last Updated**: 2021-10-19 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README
所有代码都通过测试,并且真实有效
------ ## 简介 本仓库整合了一些工作中经常用到的一些技术。目前深度较浅,但会持续更新,并且会慢慢加深。 ## 文档 * 数据库相关 * SpringBoot 整合 MyBatis-Plus * [SpringBoot 整合 Redis](https://gitee.com/xxacker/springboot-case/tree/master/redis-demo) * [SpringBoot 整合 MongoDB](https://gitee.com/xxacker/mango-db) * [SpringBoot 整合 Flyway]() * 中间件相关 * [SpringBoot 整合 Dubbo]() * [SpringBoot 整合 ActiveMQ](https://gitee.com/xxacker/springboot-case/tree/master/rabbitmq-demo) * [SpringBoot 整合 Kafka]() * 定时任务相关 * [SpringBoot - Scheduling]() * API 文档相关 * [SpringBoot 整合 Swagger]() * ... ### 结构 **最外层目录:** * xxx-commons:公用工程,用来引入公共的依赖,编写默认初始的配置信息,对应的工具类,以及统一返回实体类等等能抽取出来的一切公用代码。比如当项目中需要使用`Redis`做缓存,这时首先会在此工程中引入`Redis`的依赖`spring-boot-starter-data-redis`;其次编写`Redis`默认的最大连接数,连接超时时间等这些配置信息;然后考虑到兼容还需要统一解决序列化问题;最后把一些频繁使用的`Redis`操作封装到工具类中来简化调用。 * xxx-service:聚合服务工程,用来指定`SpringBoot`版本信息,配置部署信息,以及包含所需的所有子模块。也就是说这个父工程是没有其他代码的,主要就只有一个`pom.xml`文件。 **xxx-service:** * 包含各种模块,比如**用户模块**,**订单模块**等等 * 从当前的SpringBoot 整合各类框架和应用中的服务之间调用使用`Dubbo`,到后来的 简单了解微服务 中的服务之间调用使用`服务注册与发现`,项目结构都是 **xxx-commons** + **xxx-service** **xxx-service-api:** * 每个模块中的“接口”工程 * 使用`Dubbo`技术调用服务时,需要先把对外提供的接口在内部实现了,然后再对外暴露并被引入到调用者的工程中,这时为了解耦合,会只把对外暴露的接口单独写在一个工程里,也就是当前的 **xxx-service-api** 工程;在 SpringBoot 整合各类框架和应用 中对应的目录结构如下 ``` - api ## 对外暴露的接口 - constant ## 常量 - dto ## 扩展实体类 ``` * 使用`服务注册与发现`技术调用服务时,而是使用的 **服务名** + **请求的完整签名** 来实现的,所以到 简单了解微服务 时目录结构变成了这样 ``` - constant ## 常量 - dto ## 扩展实体类 ``` **xxx-service-core:** * 每个模块的“核心”工程 * 而此时两种架构的基础结构都有如下 ``` - controller ## 前端控制器 - domain ## 基础实体类 - mapper ## mapper 接口 - xml ## mapper.xml 文件 - service ## 处理业务逻辑 ``` * 如果是使用`Dubbo`技术,那么,要在自己内部实现对外暴露的接口,所有就有 ``` - api ## 这里与 xxx-service-api 工程的包名统一 - impl ## 对外暴露接口的实现类 ``` * 如果是使用`服务注册与发现`技术,那么,写远程调用的类就在 ``` - feign ## 远程调用 - fallback ## 熔断方法 ``` * 甚至,使用`服务注册与发现`技术时,可能还会把给其他服务调用的方法专门放在一个统一的包下管理 ``` - api ## 被其他服务远程调用 ``` - 启用项目,调用接口 注:调用接口时需打开 MongoDB 本地服务,要不然会报错 - 端口:8081(具体可以根据自己的喜好,在 application.properties 配置文件中配置 server.port) - 添加一个集合接口:http://localhost:8081/user/createCollection - 添加数据接口:http://localhost:8081/user/add - 删除数据接口:http://localhost:8081/user/delete - 更新数据接口:http://localhost:8081/user/update - 查询全部数据接口:http://localhost:8081/user/getAll - 根据条件查询数据接口:http://localhost:8081/user/get ## 联系我 * Email: 18735816507@163.com ## 关于我 * CSDN:https://blog.csdn.net/Xxacker