我们先不去使用SpringCloud,我们先去模仿一个微服务场景,
然后再将SpringColud的组件一个个加进去或用SpringCloud的组件来改造项目。
模仿微服务场景,我们要搭建 服务提供方 、服务调用方。
搭建服务提供方
我们先新建一个Module。
这次使用Spring的脚手架快速搭建一个项目。(过程需要联网)
然后下一步,勾选需要的依赖:
我们项目就快速搭建起来了
注意,这个时候idea右下角会有一个提示:
我们点开,然后点击 show......
这个是干嘛的呢?你之后,你会发现,左下角多了一些东西:
这些是项目里的引导类,这样我们就可以在这里快速启动了。不用点到引导类里去启动了。很方便。
如果一不小心把那个提示关掉了,怎么办呢?(我第一次就不小心关了。。。)
不要担心,按照下面的方法,也可以打开:
1.打开项目所在的工作空间里的.idea文件
2.打开workspace.xml文件,搜索Rundashboard
3.在Component中添加下面的代码,然后保存。
<option name="configurationTypes">
<set>
<option value="SpringBootApplicationConfigurationType" />
</set>
</option>
这样就可以显示了。
然后我们继续回到项目:
项目快速搭建起来了
但是还需要自己加一个通用mapper的依赖,因为Spring没有收录这个依赖:
当然可以自己搭建,这里提供pom.xml文件
<?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>
<groupId>cn.yuanxion.service</groupId>
<artifactId>yuanxion-service-provider</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>yuanxion-service-provider</name>
<description>Demo project for Spring Boot</description>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.6.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<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>1.3.2</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>
<!-- 需要手动引入通用mapper的启动器,spring没有收录该依赖 -->
<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>
然后我们来配置一些东西。
这一次我们不用application.properties,我们使用一下application.yml,
只需要将默认生成的application.properties 重命名为 application.yml 即可:
然后就可以和application.properties一样的用了。
我们来改一下默认端口试试:
我们发现,会有提示,选择之后,会自动生成一个格式
我们将端口改成8081:
再配置数据源,和 mybatis
server:
port: 8081
spring:
datasource:
url: jdbc:mysql:///yuanxion
username: root
password: 1024
mybatis:
type-aliases-package: cn.yuanxion.service.pojo
将别名扫描的包 cn.yuanxion.service.pojo 创建出来,并且将之前用过的那个User类加进去:
@Table(name = "tbuser1")
public class User {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
private String userName;
private String password;
private String name;
private Integer age;
private Integer sex;
private Date birthday;
private Date created;
private Date updated;
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public String getUserName() {
return userName;
}
public void setUserName(String userName) {
this.userName = userName;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
public Integer getSex() {
return sex;
}
public void setSex(Integer sex) {
this.sex = sex;
}
public Date getBirthday() {
return birthday;
}
public void setBirthday(Date birthday) {
this.birthday = birthday;
}
public Date getCreated() {
return created;
}
public void setCreated(Date created) {
this.created = created;
}
public Date getUpdated() {
return updated;
}
public void setUpdated(Date updated) {
this.updated = updated;
}
@Override
public String toString() {
return "User{" +
"id=" + id +
", userName='" + userName + '\'' +
", password='" + password + '\'' +
", name='" + name + '\'' +
", age=" + age +
", sex=" + sex +
", birthday=" + birthday +
", created=" + created +
", updated=" + updated +
'}';
}
}
准备的差不多了,我们去 开发一个 根据id查询用户信息 的接口:
先创建一个接口 UserMapper接口
然后我们去引导类上加一个包扫描,这样就不用在每个Mapper上加mapper注解了:
再去写一个UserService类,提供一个查询方法:
这个idea误报,要是看不习惯,可以关掉:
继续回到项目:
我们添加一个UserController类,并提供一个查询方法
@RestController
@RequestMapping("user")
public class UserController {
@Autowired
private UserService userService;
@GetMapping("{id}")
public User queryUserById(@PathVariable("id")Long id){
return this.userService.queryUserById(id);
}
}
这样就完成了,我们去启动运行,访问 测试一下:
(我的结果显示这样,是因为我使用了Chrom的 json-view 插件,有需要的可以找我要~)
这个接口,我们就完成了。