我们先不去使用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 插件,有需要的可以找我要~)

这个接口,我们就完成了。