微服务拆分-拆分商品服务

复制hm-service模块pom.xml文件里面的依赖到item-service模块pom.xml文件。

需要准备的依赖

java 复制代码
<dependencies>
        <!--common-->
        <dependency>
            <groupId>com.heima</groupId>
            <artifactId>hm-common</artifactId>
            <version>1.0.0</version>
        </dependency>
        <!--web-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!--数据库-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>
        <!--mybatis-->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
        </dependency>
    </dependencies>
    <build>
        <finalName>${project.artifactId}</finalName>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

新建一个包

准备以下的包

准备一个启动类,或者拷贝hm-service模块里面的启动类进行修改。

将hm-service模块里面的配置文件拷贝到item-service模块进行修改。

我们每一个微服务都要做到独立,将来独立部署还要做到数据独立,也就是要做到自己有自己独立的数据库。我们需要去创建一个新的MySQL的实例,利用Docker重写创建一个,然后这个微服务独享一台MySQL,那么ip地址端口可能都会变化。但是这样的话成本太高了,假如说需要10个服务,就需要10台MySQL。我们采用了折中方案,我们不可能再用原来的这张表这个库了,我们用一台MySQL然后在这里面去创建不同的database,每个微服务创建一个database来做数据隔离。

把准备好的sql 放到MySQL里面去运行。

将 hm-service模块里面有关商品的类拷贝到item-service模块里面去。

将报错的包删掉让它重新导入。

ALT+8所有的启动类都在这里,如果没有出现启动类就刷新Maven。

启动成功

·测试

所有的服务都配置了Swagger所以我们可以直接访问localhost:8081/doc.html。

商品微服务的拆分完成。

相关推荐
YangYang9YangYan几秒前
数据科学与大数据技术专业学习数据分析的价值
大数据·学习·数据分析
charlie1145141913 分钟前
通用GUI编程技术——图形渲染实战(五十)——命中测试与鼠标事件路由:精确交互
c++·windows·架构·交互·图形渲染
惜缘破军5 分钟前
基于 Spring Boot 3 和 Spring Cloud 2023 的微服务基础框架 hdfk7-boot
spring boot·后端·微服务
布朗克1686 分钟前
33 设计模式精讲
java·单例模式·设计模式
70asunflower7 分钟前
【Day1-2】部署&运行 Gemma4 大模型 - Datawhale AI学习
人工智能·学习·datawhale·amdev
San813_LDD9 分钟前
[深度学习]量化研究_ML_Lesson3
笔记
码语智行20 分钟前
基于word模板导出人员信息
java
San813_LDD25 分钟前
[深度学习]量化研究_ML_Lesson1
笔记
“码”力全开27 分钟前
解耦安防黑盒:基于 Docker 容器化与 GB28181/RTSP 双协议架构的 AI 边缘计算视频平台(全源码交付)
人工智能·docker·架构
西凉的悲伤28 分钟前
redis和数据库实现分布式锁
java·数据库·redis·分布式