我们先不去使用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 插件,有需要的可以找我要~)
这个接口,我们就完成了。

京公网安备 11010502036488号