文章目录
- 1.示意图
- 2.环境搭建
- 1.创建会员消费微服务模块
- 2.删除不必要的两个文件
- 3.检查父子模块的pom.xml文件
-
- 4.pom.xml 添加依赖(刷新)
- 5.application.yml 配置监听端口和服务名
- 6.com/sun/springcloud/MemberConsumerApplication.java 创建启动类测试
- 7.测试执行
- 1.发现80端口被占用
- 2.打开命令行输入 netstat -anb 查看是谁占用了80端口
- 3.只能更换端口,使用 netstat -aon | findstr :81 来查看81端口被没被占用
- 4.application.yml 更换端口和名字为81
- 5.再次测试运行,成功在81端口监听
- 6.浏览器请求测试
- 7.更换项目名称为81(这样直接就知道这个服务在81端口监听)
- 8.细节说明
- 1.如果报错说数据库有问题,可能就是在pom.xml中保留了mybatis的依赖
- 2.解决方案:启动类排除数据源自动配置
- 3.代码实现
- 1.com/sun/springcloud/entity/Member.java 创建entity与会员中心模块保持一致
- 2.com/sun/springcloud/util/Result.java 创建Result工具类
- 3.RestTemplate 基本介绍
- 4.com/sun/springcloud/config/CustomizationBean.java 配置类注入RestTemplate的bean对象
- 5.com/sun/springcloud/controller/MemberConsumerController.java 作为会员中心微服务 save接口的中转站
- 6.启动两个微服务进行测试
- 1.首先启动会员中心微服务
- 2.启动服务消费微服务
- 3.postman测试
- 4.数据库信息
- 7.注意事项
- 1.RestTemplate发送请求的细节
- 2.entity实体类需要实现Serializable接口实现可序列化
- 3.在这个案例中
- 8.com/sun/springcloud/controller/MemberConsumerController.java 新增方法
- 9.postman测试
- 10.注意事项和细节
- 1.开启Run Dashboard/Service
- 1.打开 .idea/workspace.xml
- 2.粘贴配置代码到这里
- 3.配置代码
- 4.重启项目
- 5.查看Services
- 6.可以在这启动项目
- 7.启动之后的效果
- 2.关于微服务的细节
-
- 4.创建一个共用模块
- 1.创建公共模块 e_commerce_center-common-api
- 2.检查父子的pom.xml
-
- 3.pom.xml 引入依赖(刷新)
- 4.抽取共用api
- 5.maven打成jar包
- 6.target目录生成jar包
- 7.package和install的区别(部署项目的时候打包使用package)
- 8.工程重构
- 1.删除两个模块的Member和Result类,此时会报错
- 2.两个模块的pom.xml都引入刚才的jar包
- 1.查找公共模块jar包的坐标
- 2.pom.xml分别引入jar包
- 3.重启两个模块进行测试
-
1.示意图
data:image/s3,"s3://crabby-images/394ca/394ca4041927c769d3abcb25d0b31e256b7e5ac2" alt="image-20240324133630813"
2.环境搭建
1.创建会员消费微服务模块
data:image/s3,"s3://crabby-images/3c5de/3c5de4bc88deea577eefe4e90d9da165a76a5507" alt="image-20240324134326276"
2.删除不必要的两个文件
data:image/s3,"s3://crabby-images/e7f5b/e7f5bfe29a777d9907ffbfac0938c9ace01adf53" alt="image-20240324134540398"
3.检查父子模块的pom.xml文件
1.子模块
data:image/s3,"s3://crabby-images/a6299/a62994ba94bf6476f3f513ea0ed1ee0a4e702a69" alt="image-20240324134701444"
2.父模块
data:image/s3,"s3://crabby-images/420ea/420ea14f8d73a185a884216f2a84ee160e407745" alt="image-20240324134801985"
4.pom.xml 添加依赖(刷新)
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
5.application.yml 配置监听端口和服务名
server:
port: 80
spring:
application:
name: member-service-consumer-80
6.com/sun/springcloud/MemberConsumerApplication.java 创建启动类测试
package com.sun.springcloud;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class MemberConsumerApplication {
public static void main(String[] args) {
SpringApplication.run(MemberConsumerApplication.class, args);
}
}
7.测试执行
1.发现80端口被占用
data:image/s3,"s3://crabby-images/7931a/7931a5fbb60a0c03d42edfd2383c00006f942264" alt="image-20240324140518987"
2.打开命令行输入 netstat -anb 查看是谁占用了80端口
data:image/s3,"s3://crabby-images/30c60/30c602d57f4d28de44d400a5d424d0980ecd1bae" alt="image-20240324140627236"
3.只能更换端口,使用 netstat -aon | findstr :81 来查看81端口被没被占用
data:image/s3,"s3://crabby-images/93c30/93c309aaa2936dd16102f04c735bb0a9e6199f71" alt="image-20240324140844982"
4.application.yml 更换端口和名字为81
server:
port: 81
spring:
application:
name: member-service-consumer-81
5.再次测试运行,成功在81端口监听
data:image/s3,"s3://crabby-images/1b1f9/1b1f9e2fe7ea852e0544168317be1efc798eafb4" alt="image-20240324141100526"
6.浏览器请求测试
data:image/s3,"s3://crabby-images/684eb/684ebbcd206248bad96644e736f7ddf4c5849f3d" alt="image-20240324141452102"
7.更换项目名称为81(这样直接就知道这个服务在81端口监听)
data:image/s3,"s3://crabby-images/a7c47/a7c4775771c12620bf9e9981052a8d52123f9481" alt="image-20240324141248037"
8.细节说明
1.如果报错说数据库有问题,可能就是在pom.xml中保留了mybatis的依赖
data:image/s3,"s3://crabby-images/163ff/163ffaa43a87c59e70e44c9478a0351b6bd4350f" alt="image-20240324141547734"
2.解决方案:启动类排除数据源自动配置
data:image/s3,"s3://crabby-images/9d92a/9d92aa5878a03899e4248ef5ab3d5f104c6131ac" alt="image-20240324141703928"
3.代码实现
1.com/sun/springcloud/entity/Member.java 创建entity与会员中心模块保持一致
- 因为需要使用这个实体类来接收信息,然后调用会员中心模块
package com.sun.springcloud.entity;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.io.Serializable;
@AllArgsConstructor
@NoArgsConstructor
@Data
public class Member implements Serializable {
private Long id;
private String name;
private String pwd;
private String mobile;
private String email;
private Integer gender;
}
2.com/sun/springcloud/util/Result.java 创建Result工具类
package com.sun.springcloud.util;
public class Result<T> {
private String code;
private String msg;
private T data;
public String getCode() {
return code;
}
public void setCode(String code) {
this.code = code;
}
public String getMsg() {
return msg;
}
public void setMsg(String msg) {
this.msg = msg;
}
public T getData() {
return data;
}
public void setData(T data) {
this.data = data;
}
public Result() {
}
public Result(T data) {
this.data = data;
}
public static Result success() {
Result result = new Result<>();
result.setCode("200");
result.setMsg("success");
return result;
}
public static <T> Result<T> success(T data) {
Result<T> result = new Result<>(data);
result.setCode("200");
result.setMsg("success");
return result;
}
public static <T> Result<T> success(String msg, T data) {
Result<T> result = new Result<>(data);
result.setCode("200");
result.setMsg(msg);
return result;
}
public static Result error(String code, String msg) {
Result result = new Result();
result.setCode(code);
result.setMsg(msg);
return result;
}
public static <T> Result<T> error(String code, String msg, T data) {
Result<T> result = new Result<>(data);
result.setCode(code);
result.setMsg(msg);
return result;
}
}
3.RestTemplate 基本介绍
data:image/s3,"s3://crabby-images/20fa3/20fa3cfbe730c5c80b18db5fdac6bf3319a06f26" alt="image-20240324142920033"
4.com/sun/springcloud/config/CustomizationBean.java 配置类注入RestTemplate的bean对象
package com.sun.springcloud.config;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.client.RestTemplate;
@Configuration
public class CustomizationBean {
@Bean
public RestTemplate restTemplate() {
return new RestTemplate();
}
}
5.com/sun/springcloud/controller/MemberConsumerController.java 作为会员中心微服务 save接口的中转站
package com.sun.springcloud.controller;
import com.sun.springcloud.entity.Member;
import com.sun.springcloud.util.Result;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;
import javax.annotation.Resource;
@RestController
public class MemberConsumerController {
public static final String MEMBER_SERVICE_PROVIDER_URL = "http://localhost:10001";
@Resource
private RestTemplate restTemplate;
@PostMapping("/member/consumer/save")
public Result save(Member member) {
return restTemplate.postForObject(MEMBER_SERVICE_PROVIDER_URL + "/member/save", member, Result.class);
}
}
6.启动两个微服务进行测试
1.首先启动会员中心微服务
data:image/s3,"s3://crabby-images/df3d0/df3d08f3807a8bf2e696a4d08a3b71a9a0eebc65" alt="image-20240324151439122"
2.启动服务消费微服务
data:image/s3,"s3://crabby-images/52e09/52e09a87266365fe8a23634b6b5c6b610ec8ead7" alt="image-20240324151459426"
3.postman测试
data:image/s3,"s3://crabby-images/ee25b/ee25b98dee6032ceed480865f008248509f91134" alt="image-20240324151540004"
4.数据库信息
data:image/s3,"s3://crabby-images/c3497/c3497e007d7b81d4025e4c0916a6edde65dfa62c" alt="image-20240324151621298"
7.注意事项
1.RestTemplate发送请求的细节
- 通过RestTemplate发送请求携带的参数会自动转换为json格式的数据
- 所以在接受RestTemplate的参数中必须要加@RequestBody注解
2.entity实体类需要实现Serializable接口实现可序列化
- 原因是使用RestTemplate传递参数时可能需要序列化
3.在这个案例中
- 参数并没有@RequestBody注解,所以需要通过表单传入数据
8.com/sun/springcloud/controller/MemberConsumerController.java 新增方法
@GetMapping("/member/consumer/get/{id}")
public Result getMemberById(@PathVariable("id") Long id) {
return restTemplate.getForObject(MEMBER_SERVICE_PROVIDER_URL + "/member/get/" + id, Result.class);
}
9.postman测试
data:image/s3,"s3://crabby-images/bc34e/bc34ef9bba3e193c1b51b2ac9bb8e564abf7ca63" alt="image-20240324154022333"
10.注意事项和细节
1.开启Run Dashboard/Service
1.打开 .idea/workspace.xml
data:image/s3,"s3://crabby-images/6d6ee/6d6ee9a10bfe373403e14f669f742c4f34f8f0a9" alt="image-20240324155027471"
2.粘贴配置代码到这里
data:image/s3,"s3://crabby-images/e8693/e8693d07c2969e2d560e6dc1d8e8db79e512e259" alt="image-20240324154605286"
3.配置代码
<component name="RunDashboard">
<option name="configurationTypes">
<set>
<option value="SpringBootApplicationConfigurationType" />
</set>
</option>
<option name="ruleStates">
<list>
<RuleState>
<option name="name" value="ConfigurationTypeDashboardGroupingRule" />
</RuleState>
<RuleState>
<option name="name" value="StatusDashboardGroupingRule" />
</RuleState>
</list>
</option>
</component>
4.重启项目
data:image/s3,"s3://crabby-images/6b4d2/6b4d2fb11aa7c96e2d94b82145528e6dd7eea331" alt="image-20240324155836039"
5.查看Services
data:image/s3,"s3://crabby-images/41fe4/41fe47d40b8e1a9127df55f6fc507b0bc9e17199" alt="image-20240324155755823"
6.可以在这启动项目
data:image/s3,"s3://crabby-images/6a8fa/6a8fa30171e26f68bc7eb3908b1189ed313901a0" alt="image-20240324155907673"
7.启动之后的效果
data:image/s3,"s3://crabby-images/2f492/2f4928d9ed821d9a088b44f8d741123b07ea5915" alt="image-20240324160051989"
2.关于微服务的细节
1.对微服务的理解
- 一个ip+端口就是一个微服务
- 访问微服务的方式是ip + 端口 + 上下文路径(可以是根目录)+ 资源路径
2.每个微服务接口的组成
4.创建一个共用模块
1.创建公共模块 e_commerce_center-common-api
data:image/s3,"s3://crabby-images/d2de0/d2de007dad20596eeba003c78ba293cfaf01bb12" alt="image-20240324161231001"
2.检查父子的pom.xml
1.子pom.xml
data:image/s3,"s3://crabby-images/4759a/4759a6b0cf6d2b3266ae6c04a9d7c09b5d72579e" alt="image-20240324161437500"
2.父pom.xml
data:image/s3,"s3://crabby-images/0be6b/0be6b891b53dd973908a1c6bb210e799ae63b7e8" alt="image-20240324161915002"
3.pom.xml 引入依赖(刷新)
<dependencies>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
</dependencies>
4.抽取共用api
data:image/s3,"s3://crabby-images/a33b9/a33b92be5a7c86a9bdebcb20244a88f2980acba5" alt="image-20240324163036287"
5.maven打成jar包
data:image/s3,"s3://crabby-images/0a9c0/0a9c0ffc116564d003871d1986eed7df36152678" alt="image-20240324163510145"
6.target目录生成jar包
data:image/s3,"s3://crabby-images/f4772/f4772f6ff2235581fe37dce6203a7e7be88e4c8a" alt="image-20240324163408187"
7.package和install的区别(部署项目的时候打包使用package)
package
命令主要用于项目的编译和打包,但不会将产物安装到本地仓库,主要用于构建过程的测试和验证。install
命令在执行package
的基础上,进一步将打包后的文件安装到本地Maven仓库,便于其他项目的依赖引用。
8.工程重构
1.删除两个模块的Member和Result类,此时会报错
data:image/s3,"s3://crabby-images/f4e41/f4e41f9a0b54eb3680df5459cc9b72691d657ee0" alt="image-20240324164248778"
2.两个模块的pom.xml都引入刚才的jar包
1.查找公共模块jar包的坐标
data:image/s3,"s3://crabby-images/30b3f/30b3f1db72c2e0236829ad9dfec89b4313943b1e" alt="image-20240324164407792"
2.pom.xml分别引入jar包
<dependency>
<groupId>org.example</groupId>
<artifactId>e_commerce_center-common-api</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
3.重启两个模块进行测试
1.重启
data:image/s3,"s3://crabby-images/6a972/6a972d95dc217ec213347fe9b8f30fb5363a0605" alt="image-20240324165126302"
2.测试
data:image/s3,"s3://crabby-images/b263e/b263e4239754bbff80605ac0f1e24d032605ae97" alt="image-20240324165146951"
data:image/s3,"s3://crabby-images/abd6e/abd6e371a3d3d18d85f95f92df04e1c30ca3428d" alt="image-20240324165306040"