data:image/s3,"s3://crabby-images/9a146/9a146a032cac1eaa77fabe9878c7781502e48b60" alt=""
data:image/s3,"s3://crabby-images/39494/39494c3590f7af884baef18a3fda9c81805c0294" alt=""
data:image/s3,"s3://crabby-images/76504/76504832b80c936ff2919ea2bee285fb1dd5b287" alt=""
data:image/s3,"s3://crabby-images/4b09d/4b09dad9bee002d63a99b3de1b7895894dd10af1" alt=""
data:image/s3,"s3://crabby-images/dfdad/dfdadd99154987293fafda2f6504fd4ad49c8751" alt=""
data:image/s3,"s3://crabby-images/0db3e/0db3e139b2d43428edc22e13f6e6217dde227f13" alt=""
2.1.3 增加依赖
<!--添加依赖-->
<dependencies>
<!--Eureka Server-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
<!--增加公共方法-->
<dependency>
<groupId>cn.bdqn</groupId>
<artifactId>springcloud-api-commons</artifactId>
<version>${project.version}</version>
</dependency>
<!--web-->
<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.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<scope>runtime</scope>
<optional>true</optional>
</dependency>
<!--测试-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
data:image/s3,"s3://crabby-images/bb929/bb929c19edbdb5fe2f87fe11ead094730db0c78b" alt=""
2.1.4 yml
server:
port: 7001
eureka:
instance:
hostname: localhost #eureka服务器端的
client:
#false 表示不向注册中心注册自己
register-with-eureka: false
#false 表示自己端就是注册中心,我的职责就是维护服务实例,并不需要去检索服务
fetch-register: false
server-url:
#设置与Eureka server交互的地址查询服务和注册服务都需要依赖这个地址
defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
2.1.5编写主启动类
@EnableEurekaServer
@SpringBootApplication
public class EurakeServer7001Application {
public static void main(String[] args) {
SpringApplication.run(EurakeSever7001Application.class,args);
}
}
data:image/s3,"s3://crabby-images/dc3fd/dc3fd26da824e8d0178ce74c3159660b725d154e" alt=""
data:image/s3,"s3://crabby-images/2b3f2/2b3f267cbe07301fb341ea2209f9192b71620745" alt=""
data:image/s3,"s3://crabby-images/ee222/ee2220847a745ffb7ae86ac1cbfcb6db5bd072f6" alt=""
2.2.2修改pom添加依赖
<!--添加Eureka client -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
2.2.3修改yml:添加Eureka的配置
eureka:
client:
#表示是否将自己注册进EurekaServer默认为true
register-with-eureka: true
#是否从EurekaServer抓取已有的注册信息,默认为true 单节点无所谓,集群必须设置true 才能配合ribbon 使用负载均衡
fetch-registry: true
service-url:
defaultZone: http://localhost:7001/eureka
instance:
prefer-ip-address: true #使用ip地址注册
data:image/s3,"s3://crabby-images/ff998/ff998570547275983cc06ac51a14d2d11c2eb68d" alt=""
2.2.4修改主启动类:标注Eureka客户端
@SpringBootApplication
@EnableEurekaClient
public class PaymentApplication {
public static void main(String[] args) {
SpringApplication.run(PaymentApplication.class,args);
}
}
data:image/s3,"s3://crabby-images/f4eb3/f4eb3d87a5820f75df7fd773eaf26dd156a5ae89" alt=""
2.3.2修改pom添加依赖
<!--eureka client-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
2.3.3 修改yml:添加Eureka的配置
eureka:
client:
#表示是否将自己注册进EurekaServer默认为true
register-with-eureka: true
#是否从EurekaServer抓取已有的注册信息,默认为true 单节点无所谓,集群必须设置true 才能配合ribbon 使用负载均衡
fetch-registry: true
server-url:
defaultZone: http://localhost:7001/eureka
instance:
prefer-ip-address: true #使用ip地址注册
2.3.4修改启动类 标注Eureka客户端
@SpringBootApplication
@EnableEurekaClient
public class OrderApplication {
public static void main(String[] args) {
SpringApplication.run(OrderApplication.class,args);
}
}
data:image/s3,"s3://crabby-images/abde4/abde408a588061e1e423dba95495950e7f1126ec" alt=""
data:image/s3,"s3://crabby-images/55a66/55a6622e0bc0f8424234b77e9a037a2d4ab06f3f" alt=""
data:image/s3,"s3://crabby-images/af271/af2715c3c1275472d855068225feb8c8282ce960" alt=""
data:image/s3,"s3://crabby-images/2070e/2070e2488e72d2bf57bd656473b15f4206d5e402" alt=""
2.3.4修改主启动类 标注为Eureka客户端
data:image/s3,"s3://crabby-images/d84df/d84df9295027164c2b628080bd482b6a16373663" alt=""
2.3.6补充
// private static final String PAYMENT_URL="http://localhost:8001";
@Autowired
private RestTemplate restTemplate;
@Autowired
private DiscoveryClient discoveryClient;
//根据id查询
@GetMapping("/consumer/payment/get/{id}")
public ResponseResult queryById(@PathVariable("id") Integer id){
List<ServiceInstance> serviceInstances = discoveryClient.getInstances("SPRINGCLOUD-PAYMENT-PROVIDER-SERVICE");
ServiceInstance instance = serviceInstances.get(0);
ResponseResult rs = restTemplate.getForObject("http://"+instance.getHost()+instance.getPort()+"/payment/get/"+id,ResponseResult.class);
// ResponseResult rs =restTemplate.getForObject(PAYMENT_URL+"/payment/get/"+id,ResponseResult.class);
return rs;
}
//创建订单
@GetMapping("/consumer/payment/save")
public ResponseResult save(Payment payment){
// ResponseResult rs =restTemplate.postForObject(PAYMENT_URL+"/payment/save", payment,ResponseResult.class);
List<ServiceInstance> serviceInstances = discoveryClient.getInstances("SPRINGCLOUD-PAYMENT-PROVIDER-SERVICE");
ServiceInstance instance = serviceInstances.get(0);
ResponseResult rs = restTemplate.postForObject("http://"+instance.getHost()+instance.getPort()+"/payment/save",payment,ResponseResult.class);
return rs;
}
}
data:image/s3,"s3://crabby-images/2f010/2f0101afdce58d278d3aa4ae24e3ee57046aa14e" alt=""
data:image/s3,"s3://crabby-images/9ec92/9ec920b836de3fe7449ff7880a9c332a50152ac1" alt=""
data:image/s3,"s3://crabby-images/1d442/1d442af702e16602ec0bf3645ad21f4c9bba383e" alt=""
data:image/s3,"s3://crabby-images/90141/90141246d6b5947a4d9e752402531c6afe61c0e0" alt=""
data:image/s3,"s3://crabby-images/ccce8/ccce83a6920e43beba42976861f7bf5683051827" alt=""
data:image/s3,"s3://crabby-images/0eec3/0eec316ddf167d9bb0946ed6424994cc1b7f8e84" alt=""
data:image/s3,"s3://crabby-images/05f80/05f808467c37a1f03aff818017f71b31fca7a971" alt=""
data:image/s3,"s3://crabby-images/b9cb6/b9cb6ce81c5de55ea9bbc579ac16be4b59ee3e04" alt=""
3.2.1修改pom添加依赖
<!--依赖-->
<dependencies>
<!--eureka server-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
<!--公共方法-->
<dependency>
<groupId>cn.bdqn</groupId>
<artifactId>springcloud-api-commons</artifactId>
<version>${project.version}</version>
</dependency>
<!--web-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!--热部署工具-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
</dependency>
<!--测试-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
3.2.2编写yml
server:
port: 7002
eureka:
instance:
hostname: eureka7002.com #eureka服务器端的
client:
#false 表示不向注册中心注册自己
register-with-eureka: false
#false 表示自己端就是注册中心,我的职责就是维护服务实例,并不需要去检索服务
fetch-registry: false
service-url:
#设置与Eureka server交互的地址查询服务和注册服务都需要依赖这个地址
defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
data:image/s3,"s3://crabby-images/dd63f/dd63f1c455188b79bf5268b63ce2b831549b4ce0" alt=""
3.2.5 编写启动类
@SpringBootApplication
@EnableEurekaServer
public class EurekaServer7002Application {
public static void main(String[] args) {
SpringApplication.run(EurekaServer7002Application.class,args);
}
}
data:image/s3,"s3://crabby-images/5a179/5a179ec14f0003be4fdb7674222986087c6b5805" alt=""
data:image/s3,"s3://crabby-images/3d9e9/3d9e90f92d21fb4687e835b3cc107ba8461d5036" alt=""
data:image/s3,"s3://crabby-images/9a2e4/9a2e4f43dcc1f862ae1cdccffe9f057236dbfd28" alt=""
data:image/s3,"s3://crabby-images/63626/63626e1b45d56d584faac94216d6a6c095a5af05" alt=""
3.3.3修改pom添加依赖
<dependencies>
<!--eureka server-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
<!--公共类-->
<dependency>
<groupId>cn.bdqn</groupId>
<artifactId>springcloud-api-commons</artifactId>
<version>${project.version}</version>
</dependency>
<!--web-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!--热部署-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
</dependency>
<!--测试-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
data:image/s3,"s3://crabby-images/80ddf/80ddf58568f6e2339f25a0f9db7cc0ef1bd7a5d1" alt=""
3.3.4编写yml
server:
port: 7003
eureka:
instance:
hostname: eureka7003.com #eureka服务器端的
client:
#false 表示不向注册中心注册自己
register-with-eureka: false
#false 表示自己端就是注册中心,我的职责就是维护服务实例,并不需要去检索服务
fetch-registry: false
service-url:
#设置与Eureka server交互的地址查询服务和注册服务都需要依赖这个地址
defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
data:image/s3,"s3://crabby-images/6e21c/6e21c7cedeb1c8f80826e5c6f2b1a01453bed2d8" alt=""
3.3.5编写启动类
@SpringBootApplication
@EnableEurekaServer
public class EurekaServer7003Application {
public static void main(String[] args) {
SpringApplication.run(EurekaServer7003Application.class,args);
}
}
data:image/s3,"s3://crabby-images/ee912/ee91205abb7499208f307321b074e011683bc8eb" alt=""
data:image/s3,"s3://crabby-images/4ea94/4ea94c5678e8b059f7f5e0f501d71fabe799a3c5" alt=""
data:image/s3,"s3://crabby-images/37be1/37be10f206dbaedf00966c464f1da8d7c99ed2e8" alt=""
data:image/s3,"s3://crabby-images/f288b/f288b18679bb0284f2d30ad962afa0873ca93313" alt=""
data:image/s3,"s3://crabby-images/f56c5/f56c5dee13445bd77d771c9ddf60b317b6cbadfe" alt=""
3.4.2 修改后的配置文件
springcloud-eureka-sever-7001
server:
port: 7001
eureka:
instance:
hostname: eureka7001.com #eureka服务器端的
client:
#false 表示不向注册中心注册自己
register-with-eureka: false
#false 表示自己端就是注册中心,我的职责就是维护服务实例,并不需要去检索服务
fetch-register: false
service-url:
#设置与Eureka server交互的地址查询服务和注册服务都需要依赖这个地址
# defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
defaultZone: http://eureka7001.com:7002/eureka/,http://eureka7003.com:7002/eureka/
springcloud-eureka-sever-7001
server:
port: 7002
eureka:
instance:
hostname: eureka7002.com #eureka服务器端的
client:
#false 表示不向注册中心注册自己
register-with-eureka: false
#false 表示自己端就是注册中心,我的职责就是维护服务实例,并不需要去检索服务
fetch-registry: false
service-url:
#设置与Eureka server交互的地址查询服务和注册服务都需要依赖这个地址
# defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
defaultZone: http://eureka7001.com:7001/eureka/,http://eureka7003.com:7003/eureka/
data:image/s3,"s3://crabby-images/9eeeb/9eeeb321a558e4511155f51e296cf20a24ca2058" alt=""
springcloud-eureka-sever003
server:
port: 7003
eureka:
instance:
hostname: eureka7003.com #eureka服务器端的
client:
#false 表示不向注册中心注册自己
register-with-eureka: false
#false 表示自己端就是注册中心,我的职责就是维护服务实例,并不需要去检索服务
fetch-registry: false
service-url:
#设置与Eureka server交互的地址查询服务和注册服务都需要依赖这个地址
# defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
defaultZone: http://eureka7002.com:7002/eureka/,http://eureka7001.com:7001/eureka/
data:image/s3,"s3://crabby-images/86966/86966fc7f1620ca5279333212cf42e32eeca8512" alt=""
data:image/s3,"s3://crabby-images/c75de/c75de644d02310b8a8a57832beed569dec115e81" alt=""
data:image/s3,"s3://crabby-images/ebb54/ebb54e849d05d76cc83599643044e7df9bb296aa" alt=""
4.1支付微服务发布到 Eureka Sever中
server:
port: 8001
spring:
application:
name: springcloud-payment-provider-service
datasource:
type: com.alibaba.druid.pool.DruidDataSource
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://127.0.0.1:3306/springcloud_db?useUnicode=true&characterEncoding=utf-8&useSSL=true&serverTimezone=GMT
username: root
password: xiaoduo456new
mybatis:
mapper-locations: classpath:mapper/*.xml
type-aliases-package: cn.bdqn.domain # 所有Entity别名类所在包
eureka:
client:
#表示是否将自己注册进EurekaServer默认为true
register-with-eureka: true
#是否从EurekaServer抓取已有的注册信息,默认为true 单节点无所谓,集群必须设置true 才能配合ribbon 使用负载均衡
fetch-registry: true
service-url:
#defaultZone: http://localhost:7001/eureka
defaultZone: http://eureka7001.com:7001/eureka,
http://eureka7002.com:7002/eureka,
http://eureka7003.com:7003/eureka,
instance:
prefer-ip-address: true #使用ip地址注册
data:image/s3,"s3://crabby-images/e1fb3/e1fb3bc4f8a4fa39e8aa72998c9690e5c4c927d9" alt=""
data:image/s3,"s3://crabby-images/a2f63/a2f6392e154261b480bf3eed58a92cb573e78a49" alt=""
4.2订单微服务发布到Eureka Server中
server:
port: 8001
spring:
application:
name: springcloud-payment-provider-service
datasource:
type: com.alibaba.druid.pool.DruidDataSource
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://127.0.0.1:3306/springcloud_db?useUnicode=true&characterEncoding=utf-8&useSSL=true&serverTimezone=GMT
username: root
password: xiaoduo456new
mybatis:
mapper-locations: classpath:mapper/*.xml
type-aliases-package: cn.bdqn.domain # 所有Entity别名类所在包
eureka:
client:
#表示是否将自己注册进EurekaServer默认为true
register-with-eureka: true
#是否从EurekaServer抓取已有的注册信息,默认为true 单节点无所谓,集群必须设置true 才能配合ribbon 使用负载均衡
fetch-registry: true
service-url:
#defaultZone: http://localhost:7001/eureka
defaultZone: http://eureka7001.com:7001/eureka,
http://eureka7002.com:7002/eureka,
http://eureka7003.com:7003/eureka,
instance:
prefer-ip-address: true #使用ip地址注册
data:image/s3,"s3://crabby-images/2b59e/2b59eb00c4ac76c2f43901f8bbab9b7a4b65e54f" alt=""
data:image/s3,"s3://crabby-images/3f551/3f55149befa71dfc7e5a3b83a05251d6087e7cee" alt=""
data:image/s3,"s3://crabby-images/8cd5f/8cd5f6b39d415d97c20352a96d883f45f6136cb9" alt=""
5.2.2修改pom 添加依赖
<!--依懒-->
<dependencies>
<!--添加Eureka client -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<!--公共的部分-->
<dependency>
<groupId>cn.bdqn</groupId>
<artifactId>springcloud-api-commons</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
<!--web-->
<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.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.0.0</version>
</dependency>
<!--阿里云数据源-->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid-spring-boot-starter</artifactId>
</dependency>
<!--驱动-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
<!--jdbc-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<!--热部署-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<scope>runtime</scope>
<optional>true</optional>
</dependency>
<!--lombok-->
<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>
data:image/s3,"s3://crabby-images/61de8/61de82c9929033967b8cba6921d913271a305e82" alt=""
5.2.3编辑yml
server:
port: 8002
spring:
application:
name: springcloud-payment-provider-service
datasource:
type: com.alibaba.druid.pool.DruidDataSource
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://127.0.0.1:3306/springcloud_db?useUnicode=true&characterEncoding=utf-8&useSSL=true&serverTimezone=GMT
username: root
password: xiaoduo456new
mybatis:
mapper-locations: classpath:mapper/*.xml
type-aliases-package: cn.bdqn.domain
eureka:
client:
#表示是否将自己注册进EurekaServer默认为true
register-with-eureka: true
#是否从EurekaServer抓取已有的注册信息,默认为true 单节点无所谓,集群必须设置true 才能配合ribbon 使用负载均衡
fetch-registry: true
service-url:
defaultZone: http://eureka7001.com:7001/eureka,
http://eureka7002.com:7002/eureka,
http://eureka7003.com:7003/eureka,
instance:
prefer-ip-address: true #使用ip地址注册
5.24编写启动类
@SpringBootApplication
@EnableEurekaClient
public class Payment8002Application {
public static void main(String[] args) {
SpringApplication.run(Payment8002Application.class,args);
}
}
5.25编写PaymentMapper接口
@Mapper
public interface PaymentMapper {
//保存一个支付流水
public void insert(Payment payment);
//根据id获取具体的支付信息
public Payment selectById(@Param("id") Integer id);
}
data:image/s3,"s3://crabby-images/ce6ed/ce6ed12e2711be4a76dd8faf94df674a56a013b9" alt=""
5.2.6编写PaymentMapper.xml映射文件
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
PUBLIC "--//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="cn.bdqn.Mapper.PaymentMapper">
<resultMap id="PaymentResultMap" type="cn.bdqn.domain.Payment">
<id column="id" property="id"></id>
<id column="flow_number" property="flowNumber"></id>
</resultMap>
<insert id="insert" parameterType="cn.bdqn.Mapper.PaymentMapper">
insert into t_payment(flow_number) values(#{flowNumber})
</insert>
<select id="selectById" resultMap="PaymentResultMap">
select id,flow_number from t_payment where id=#{id};
</select>
</mapper>
5.
5.2.7编写payment业务接口以及实现类
public interface PaymentServer {
//保存一个支付流水
public void save(Payment payment);
//根据id获取具体的支付信息
public Payment queryById(Integer id);
}
@Service
public class PaymentServerImpl implements PaymentServer {
@Autowired
private PaymentMapper paymentMapper;
@Override
public Payment queryById(Integer id) {
return paymentMapper.selectById(id);
}
@Override
public void save(Payment payment) {
paymentMapper.insert(payment);
}
}
data:image/s3,"s3://crabby-images/62ce3/62ce373823e81b9aee8802c373a5643741eff9b4" alt=""
data:image/s3,"s3://crabby-images/3aacc/3aaccd37861508cb77a635cc5b32fb86ba55ec19" alt=""
5.2.8 编写paymentController控制器
@RestController
public class PaymentConroller {
@Autowired
private PaymentServerImpl paymentServer;
@GetMapping("/payment/id/{id}")
public ResponseResult queryById(@PathVariable(name="id") Integer id){
Payment payment = paymentServer.queryById(id);
if(payment!=null) {
return new ResponseResult(200,"成功",payment);
}else{
return new ResponseResult(404,"没有对应的记录,查询id"+id,null);
}
}
@PostMapping("/payment/save")
public ResponseResult save(@RequestBody Payment payment){
try {
paymentServer.save(payment);
return new ResponseResult(200,"插入成功",null);
}catch (Exception e){
e.printStackTrace();
return new ResponseResult(200,"插入失败",null);
}
}
}
data:image/s3,"s3://crabby-images/d6741/d674142d7d1725259cb8bf2d3a963ebc8c05f95c" alt=""
data:image/s3,"s3://crabby-images/44a61/44a6177a6effadb497f2a0c728e2b78dabedee07" alt=""