首先创建微服务提供者模块cloud-provider-payment8001
打开cloud2020
项目创建maven项目cloud-provider-payment8001
然后
修改pom文件
<!--包含了sleuth+zipkin(后面用)-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-zipkin</artifactId>
</dependency>
<!-- eureka-client客户端(后面有)-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<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>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid-spring-boot-starter</artifactId>
<version>1.2.5</version>
</dependency>
<!--mysql-connector-java-->
<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>
<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>
在resources
目录下面新建配置文件application.yml
把下面的配置粘贴进去
server:
port: 8001
spring:
application:
name: cloud-payment-service
datasource:
type: com.alibaba.druid.pool.DruidDataSource # 当前数据源操作类型
driver-class-name: com.mysql.cj.jdbc.Driver # mysql驱动包 com.mysql.jdbc.Driver
url: jdbc:mysql://127.0.0.1:3306/springcloud2020?useUnicode=true&characterEncoding=utf-8&useSSL=NO&serverTimezone=Asia/Shanghai
username: root
password: 123456
mybatis:
mapperLocations: classpath:mapper/*.xml
type-aliases-package: com.zhubayi.springcloud.entities # 所有Entity别名类所在包
添加启动类PaymentMain8001
package com.zhubayi.springcloud;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
/**
* @author zhubayi
*/
@SpringBootApplication
@EnableEurekaClient
@EnableDiscoveryClient
public class PaymentMain8001 {
public static void main(String[] args) {
SpringApplication.run(PaymentMain8001.class,args);
}
}
创建数据库,和数据表
打开SQLyog,新建数据springcloud2020
进入springcloud2020
数据库,再创建表
若没有SQLyog这个软件,使用下面的sql语句创建表
/*
SQLyog Ultimate v13.1.1 (64 bit)
MySQL - 8.0.25 : Database - springcloud2020
*********************************************************************
*/
/*!40101 SET NAMES utf8 */;
/*!40101 SET SQL_MODE=''*/;
/*!40014 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */;
/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;
/*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='NO_AUTO_VALUE_ON_ZERO' */;
/*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;
CREATE DATABASE /*!32312 IF NOT EXISTS*/`springcloud2020` /*!40100 DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci */ /*!80016 DEFAULT ENCRYPTION='N' */;
USE `springcloud2020`;
/*Table structure for table `payment` */
DROP TABLE IF EXISTS `payment`;
CREATE TABLE `payment` (
`id` bigint NOT NULL AUTO_INCREMENT,
`serial` varchar(255) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;
/*Data for the table `payment` */
insert into `payment`(`id`,`serial`) values
(1,'测试'),
(2,'哈哈哈'),
(3,'嘿嘿嘿'),
(5,'java se'),
(6,'ssds');
/*!40101 SET SQL_MODE=@OLD_SQL_MODE */;
/*!40014 SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS */;
/*!40014 SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS */;
/*!40111 SET SQL_NOTES=@OLD_SQL_NOTES */;
然后创建实体类Payment
package com.zhubayi.springcloud.entities;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.io.Serializable;
/**
* @author zhubayi
*/
@Data
@AllArgsConstructor
@NoArgsConstructor
public class Payment implements Serializable {
private Long id;
private String serial;
}
注意实体类的属性最好与数据的字段保持一致
还有统一的结果返回类CommonResult
package com.zhubayi.springcloud.entities;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
/**
* @author zhubayi
*/
@Data
@NoArgsConstructor
@AllArgsConstructor
public class CommonResult<T> {
private Integer code;
private String message;
private T data;
public CommonResult(Integer code,String message){
this(code,message,null);
}
}
创建持久层dao
,在它下面创建接口PaymentDao
package com.zhubayi.springcloud.dao;
import com.zhubayi.springcloud.entities.Payment;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import java.util.List;
/**
* @author zhubayi
*/
@Mapper
public interface PaymentDao {
/**
* 创建
* @param payment
* @return
*/
int create(Payment payment);
Payment getPaymentById(@Param("id") Long id);
List<Payment> findAll();
}
然后在resoures下面创建mapper目录,在mapper目录下创建PaymentDao.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="com.zhubayi.springcloud.dao.PaymentDao">
<!-- 插入 -->
<insert id="create" parameterType="com.zhubayi.springcloud.entities.Payment" useGeneratedKeys="true" keyProperty="id">
insert into payment(serial) values (#{serial})
</insert>
<!-- 根据id查询-->
<select id="getPaymentById" parameterType="Long" resultMap="BaseResultMap">
select * from `payment` where id=#{id}
</select>
<!-- 查所有-->
<select id="findAll" resultType="com.zhubayi.springcloud.entities.Payment">
select * from `payment`
</select>
<resultMap id="BaseResultMap" type="com.zhubayi.springcloud.entities.Payment">
<id column="id" property="id" jdbcType="BIGINT"/>
<result column="serial" property="serial" jdbcType="VARCHAR"/>
</resultMap>
</mapper>
再创建service
业务层,在service
下面创建接口PaymentService
package com.zhubayi.springcloud.service;
import com.zhubayi.springcloud.entities.Payment;
import org.apache.ibatis.annotations.Param;
import java.util.List;
/**
* @author zhubayi
*/
public interface PaymentService {
int create(Payment payment);
Payment getPaymentById(Long id);
List<Payment> findAll();
}
再创建实现类PaymentServiceImpl
package com.zhubayi.springcloud.service.impl;
import com.zhubayi.springcloud.dao.PaymentDao;
import com.zhubayi.springcloud.entities.Payment;
import com.zhubayi.springcloud.service.PaymentService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.List;
/**
* @author zhubayi
*/
@Service
public class PaymentServiceImpl implements PaymentService {
@Autowired
private PaymentDao paymentDao;
@Override
public int create(Payment payment) {
return paymentDao.create(payment);
}
@Override
public Payment getPaymentById(Long id) {
return paymentDao.getPaymentById(id);
}
@Override
public List<Payment> findAll() {
return paymentDao.findAll();
}
}
最后创建controller
层,在controller下面创建PaymentController
package com.zhubayi.springcloud.controller;
import com.zhubayi.springcloud.entities.CommonResult;
import com.zhubayi.springcloud.entities.Payment;
import com.zhubayi.springcloud.service.PaymentService;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.cloud.client.ServiceInstance;
import org.springframework.cloud.client.discovery.DiscoveryClient;
import org.springframework.web.bind.annotation.*;
import java.util.List;
/**
* @author zhubayi
*/
@Slf4j
@RestController
@RequestMapping("payment")
public class PaymentController {
@Autowired
private PaymentService paymentService;
@Value("${server.port}")
private String serverPort;
@Autowired
private DiscoveryClient discoveryClient;
@GetMapping("list")
public CommonResult list(){
CommonResult<List<Payment>> commonResult = new CommonResult<>();
commonResult.setCode(200);
commonResult.setMessage("success"+serverPort);
commonResult.setData(paymentService.findAll());
return commonResult;
}
@PostMapping("create")
public CommonResult create(@RequestBody Payment payment){
int res = paymentService.create(payment);
log.info("***插入结果***{}",res);
if(res>0){
return new CommonResult(200,"插入成功,端口:"+serverPort);
}
return new CommonResult(444,"插入失败");
}
@GetMapping("get/{id}")
public CommonResult get(@PathVariable("id") Long id){
Payment payment= paymentService.getPaymentById(id);
if(payment!=null){
return new CommonResult(200,"查询成功,端口:"+serverPort,payment);
}
return new CommonResult(444,"查询失败,端口:"+serverPort);
}
}
以上都完成的目录样子
进行测试:
测试根据id查询: http://localhost:8001/payment/get/3
查询所有:
http://localhost:8001/payment/list
测试创建:
打开Postman
,新建请求,发送请求
地址http://127.0.0.1:8001/payment/create
添加成功!
主要步骤可概括为:
- 建module
- 改POM文件
- 修改
application.yml
配置文件 - 新建主启动
- 添加业务类
创建微服务提供者模块cloud-consumer-order80
点击右键new Module,选择maven
项目
修改pom
文件,添加下面的依赖
<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.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<scope>runtime</scope>
<optional>true</optional>
</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>
在resources
下面新建配置文件application.yml
文件
server:
port: 80
添加主启动类OrderMain80
package com.zhubayi.springcloud;
import com.zhubayi.myrule.MySelfRule;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.cloud.netflix.ribbon.RibbonClient;
/**
* @author zhubayi
*/
@EnableEurekaClient
@SpringBootApplication
public class OrderMain80 {
public static void main(String[] args) {
SpringApplication.run(OrderMain80.class,args);
}
}
添加实体类Payment
package com.zhubayi.springcloud.entities;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.io.Serializable;
/**
* @author zhubayi
*/
@Data
@AllArgsConstructor
@NoArgsConstructor
public class Payment implements Serializable {
private Long id;
private String serial;
}
统一返回类CommonResult
package com.zhubayi.springcloud.entities;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
/**
* @author zhubayi
*/
@Data
@NoArgsConstructor
@AllArgsConstructor
public class CommonResult<T> {
private Integer code;
private String message;
private T data;
public CommonResult(Integer code,String message){
this(code,message,null);
}
}
在项目中注入RestTemplate
交给Spring
容器管理
RestTemplate提供了多种便捷访问远程Http服务的方法,
是一种简单便捷的访问restful服务模板类,是Spring提供的用于访问Rest服务的客户端模板工具集
新建配置包config
,在它下面新建ApplicationContextConfig
配置类
package com.zhubayi.springcloud.config;
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.client.RestTemplate;
/**
* @author zhubayi
*/
@Configuration
public class ApplicationContextConfig {
@Bean
public RestTemplate restTemplate(){
return new RestTemplate();
}
}
新建controller
包,在它下面创建OrderController
类
package com.zhubayi.springcloud.controller;
import com.zhubayi.springcloud.entities.CommonResult;
import com.zhubayi.springcloud.entities.Payment;
import com.zhubayi.springcloud.lb.MyLoadBalancer;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.cloud.client.ServiceInstance;
import org.springframework.cloud.client.discovery.DiscoveryClient;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.client.RestTemplate;
import java.net.URI;
import java.util.List;
/**
* @author zhubayi
*/
@RestController
@RequestMapping("/consumer/order")
public class OrderController {
public static final String PaymentSrv_URL = "http://localhost:8001";
@Autowired
private RestTemplate restTemplate;
@GetMapping("create")
public CommonResult create(Payment payment){
return restTemplate.postForObject(PAYMENT_URL+"/payment/create",payment,CommonResult.class);
}
@GetMapping("/get/{id}")
public CommonResult get(@PathVariable("id")Long id){
return restTemplate.getForObject(PAYMENT_URL+"/payment/get/"+id,CommonResult.class);
}
}
完整的目录结构:圈起来的部分
,其他的是后面的相关
启动OrderMain80
进行测试:
http://localhost/consumer/order/get/1
测试添加http://localhost/consumer/order/create?serial=aaaaa1
由于cloud-consumer-order80
模块和cloud-provider-payment8001
有重复部分Payment
和CommonResult
,
我们可以抽取一个公共模块cloud-api-commons
,让cloud-consumer-order80
模块和cloud-provider-payment8001
都依赖它即可
新建cloud-api-commons
模块
创建类Payment
和CommonResult
Payment类
package com.zhubayi.springcloud.entities;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.io.Serializable;
/**
* @author zhubayi
*/
@Data
@AllArgsConstructor
@NoArgsConstructor
public class Payment implements Serializable {
private Long id;
private String serial;
}
CommonResult类
package com.zhubayi.springcloud.entities;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
/**
* @author zhubayi
*/
@Data
@NoArgsConstructor
@AllArgsConstructor
public class CommonResult<T> {
private Integer code;
private String message;
private T data;
public CommonResult(Integer code,String message){
this(code,message,null);
}
}
在cloud-consumer-order80
模块和cloud-provider-payment8001
的pom文件添加上:
<dependency>
<groupId>com.zhubayi.springcloud</groupId>
<artifactId>cloud-api-commons</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
完整的项目目录: