新建父工程项目springcloud,切记Packageing是pom模式
主要是定义POM文件,将后续各个子模块公用的jar包等统一提取出来,类似一个抽象父类
pom.xml
4.0.0 com.haust springcloud 1.0-SNAPSHOT springcloud-api springcloud-provider-dept-8001 springcloud-consumer-dept-80 springcloud-eureka-7001 springcloud-eureka-7002 springcloud-eureka-7003 springcloud-provider-dept-8002 springcloud-provider-dept-8003 springcloud-consumer-dept-feign springcloud-provider-dept-hystrix-8001 springcloud-consumer-hystrix-dashboard springcloud-zuul-9527 springcloud-config-server-3344 springcloud-config-client-3355 springcloud-config-eureka-7001 springcloud-config-dept-8001 pom UTF-8 1.8 1.8 4.12 1.2.17 1.16.18 org.springframework.cloud spring-cloud-alibaba-dependencies 0.2.0.RELEASE pom import org.springframework.cloud spring-cloud-dependencies Greenwich.SR1 pom import org.springframework.boot spring-boot-dependencies 2.1.4.RELEASE pom import mysql mysql-connector-java 5.1.47 com.alibaba druid 1.1.10 org.mybatis.spring.boot mybatis-spring-boot-starter 1.3.2 ch.qos.logback logback-core 1.2.3 junit junit ${junit.version} log4j log4j ${log4j.version} org.projectlombok lombok ${lombok.version}
父工程为springcloud,其下有多个子mudule,详情参考完整代码了解
springcloud-consumer-dept-80访问springcloud-provider-dept-8001下的controller使用REST方式
如DeptConsumerController.java
@RestController
public class DeptConsumerController {
@Autowired
private RestTemplate restTemplate;
private static final String REST_URL_PREFIX = "http://localhost:8001";
//private static final String REST_URL_PREFIX = "http://SPRINGCLOUD-PROVIDER-DEPT";
@RequestMapping("/consumer/dept/add")
public boolean add(Dept dept) {
// postForObject(服务提供方地址(接口),参数实体,返回类型.class)
return restTemplate.postForObject(REST_URL_PREFIX + "/dept/add", dept, Boolean.class);
}
@RequestMapping("/consumer/dept/get/{id}")
public Dept get(@PathVariable("id") Long id) {
// getForObject(服务提供方地址(接口),返回类型.class)
return restTemplate.getForObject(REST_URL_PREFIX + "/dept/get/" + id, Dept.class);
}
@RequestMapping("/consumer/dept/list")
public List list() {
return restTemplate.getForObject(REST_URL_PREFIX + "/dept/list", List.class);
}
}
使用RestTemplete先需要放入Spring容器中
ConfigBean.java
@Configuration
public class ConfigBean {
//@Configuration -- spring applicationContext.xml
//配置负载均衡实现RestTemplate
// IRule
// RoundRobinRule 轮询
// RandomRule 随机
// AvailabilityFilteringRule : 会先过滤掉,跳闸,访问故障的服务~,对剩下的进行轮询~
// RetryRule : 会先按照轮询获取服务~,如果服务获取失败,则会在指定的时间内进行,重试
@Bean
public RestTemplate getRestTemplate(){
return new RestTemplate();
}
}
springcloud-provider-dept-8001的dao接口调用springcloud-api模块下的pojo,可使用在springcloud-provider-dept-8001的pom文件导入springcloud-api模块依赖的方式:
com.haust
springcloud-api
1.0-SNAPSHOT
springcloud-consumer-dept-80和springcloud-provider-dept-8001的pom.xml和父工程下的依赖基本一样,直接看完整代码即可,不再添加重复笔记。



