目录
详细演示user-service的搭建过程,user-consume的搭建过程类似,只说明有区别的部分。
这两个项目没有构成完整的微服务demo,完整的需要去看主文章。
一个Module就是一个项目,一个微服务。
选择Spring Initializr,JDK1.8及以上,Default URL(访问这个URL:https://start.spring.io也可以在页面上选择模块构建并下载工程)
填写Group和Artifact信息
选择模块
由于我们要提供接口,查询并返回数据,所以需要Web和SQL的相应模块。
点Next->Finish完成。
项目结构如图所示:
除了自动生成的部分,我还添加了三个依赖
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.5.RELEASE</version>
<relativePath/>
</parent>
<groupId>com.vplus.demo</groupId>
<artifactId>user-service</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>user-service</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.0.1</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<!--*******************自己添加的依赖开始*****************-->
<dependency>
<groupId>javax.persistence</groupId>
<artifactId>javax.persistence-api</artifactId>
<version>2.2</version>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.8</version>
</dependency>
<dependency>
<groupId>tk.mybatis</groupId>
<artifactId>mapper-spring-boot-starter</artifactId>
<version>2.0.2</version>
</dependency>
<!--*******************自己添加的依赖结束*****************-->
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC
来解决时区和乱码问题。server:
port: 8081
spring:
datasource:
url: jdbc:mysql://localhost:3306/你的数据库名?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC
username: 你的数据库用户名
password: 你的数据库用户密码
hikari:
maximum-pool-size: 20
minimum-idle: 10
mybatis:
type-aliases-package: com.vplus.demo.userservice.pojo
@RestController注解相当于@Controller注解外加给所有方法加上@ResponseBody注解。表现为:每个方法返回的都是json字符串。
@RestController
@RequestMapping("user")
public class UserController {
@Autowired
private UserService userService;
@GetMapping("/{id}")
public User queryById(@PathVariable("id") Long id) {
return this.userService.queryById(id);
}
}
为了简便,不再写service接口和Impl实现了,直接合成一个Service类。
@Service
public class UserService {
@Autowired
private UserMapper userMapper;
public User queryById(Long id) {
return this.userMapper.selectByPrimaryKey(id);
}
}
继承通用Mapper,由于@Mapper注解的存在,和通用Mapper重名,因此通用Mapper写成全类名tk.mybatis.mapper.common.Mapper<User>
@Mapper
public interface UserMapper extends tk.mybatis.mapper.common.Mapper<User>{
}
启动UserServiceApplication
的main函数,访问http://localhost:8081/user/20即可查到ID为20的用户。
至此user-service模块搭建完成
搭建流程和创建user-service模块一致,需要注意一点:选择依赖时只选Web模块,不需要SQL模块。因为数据是从user-service提供的接口里面读的。
添加第二个模块后,Idea会提示你是否显示Run DashBoard,要选择显示。
省略......
</dependencies>
省略.......
<!--添加OKhttp支持-->
<dependency>
<groupId>com.squareup.okhttp3</groupId>
<artifactId>okhttp</artifactId>
<version>3.9.0</version>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
</dependencies>
省略......
配置项目的tomcat端口为8082
server:
port: 8082
注册RestTemplate
@SpringBootApplication
public class UserConsumeApplication {
@Bean
public RestTemplate restTemplate() {
return new RestTemplate(new OkHttp3ClientHttpRequestFactory());
}
public static void main(String[] args) {
SpringApplication.run(UserConsumeApplication.class, args);
}
}
这个项目还需要User类来承载数据,但不需要关联数据表了,所以@Table
注解就不用写了
@Data
public class User implements Serializable {
private static final long serialVersionUID = 1L;
private Long id;
private String username;
private String phone;
}
@RestController
@RequestMapping("consume")
public class ConsumerController {
@Autowired
private UserService userService;
@GetMapping
public List<User> consume(@RequestParam("ids") List<Long> ids) {
return this.userService.queryUserByIds(ids);
}
}
@Service
public class UserService {
@Autowired
private UserDao userDao;
public List<User> queryUserByIds(List<Long> ids){
List<User> users = new ArrayList<>();
for (Long id : ids) {
User user = this.userDao.queryUserById(id);
users.add(user);
}
return users;
}
}
这里的Dao并不是“真正的Dao”,不是从数据库查询数据,而是使用RestTemplate
访问远程的rest接口。
@Component
public class UserDao {
@Autowired
private RestTemplate restTemplate;
public User queryUserById(Long id){
String url = "http://localhost:8081/user/" + id;
return this.restTemplate.getForObject(url, User.class);
}
}
从Run DashBoard中依次启动两个项目。访问:http://localhost:8082/consume?ids=20,21即可查询id=20和21的两个用户的信息
原文:https://www.cnblogs.com/qianbixin/p/10936464.html