搭建springboot项目
然后直接下一步构建
父工程pom.xml
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<java.version>1.8</java.version>
<maven.compiler.source>${java.version}</maven.compiler.source>
<maven.compiler.target>${java.version}</maven.compiler.target>
</properties>
创建api的module
api module下的pom
<properties>
<lombok.version>1.16.10</lombok.version>
<jackson-annotations-version>2.6.5</jackson-annotations-version>
</properties>
<dependencies>
<!--lombok-->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>${lombok.version}</version>
</dependency>
<!--jackson-->
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-annotations</artifactId>
<version>${jackson-annotations-version}</version>
<scope>compile</scope>
</dependency>
</dependencies>
同样方式创建model
<properties>
<mybatis-spring-boot.version>2.1.4</mybatis-spring-boot.version>
<mybatis-pagehelper.version>4.1.2</mybatis-pagehelper.version>
</properties>
<dependencies>
<!--api-->
<dependency>
<groupId>com.zwx.middleware</groupId>
<artifactId>api</artifactId>
<version>${project.parent.version}</version>
</dependency>
<!--spring-mybatis-->
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>${mybatis-spring-boot.version}</version>
</dependency>
</dependencies>
最后构建核心module:server
pom:
<?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">
<parent>
<artifactId>middleware</artifactId>
<groupId>com.zwx.middleware</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>server</artifactId>
<properties>
<start-class>com.debug.middleware.server.MainApplication</start-class>
<spring-boot.version>2.2.2.RELEASE</spring-boot.version>
<spring-session.version>1.2.0.RELEASE</spring-session.version>
<mysql.version>5.1.37</mysql.version>
<druid.version>1.1.24</druid.version>
<guava.version>19.0</guava.version>
<skipTests>true</skipTests>
</properties>
<!-- 依赖管理 -->
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>${spring-boot.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<dependencies>
<!--日志-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-log4j</artifactId>
<version>1.3.3.RELEASE</version>
</dependency>
<!--model-->
<dependency>
<groupId>com.zwx.middleware</groupId>
<artifactId>model</artifactId>
<version>${project.parent.version}</version>
</dependency>
<!--guava-->
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
<version>${guava.version}</version>
</dependency>
<!--mysql-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>${mysql.version}</version>
</dependency>
<!--druid-->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>${druid.version}</version>
</dependency>
<!--spring-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<version>${spring-boot.version}</version>
<exclusions>
<exclusion>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
</exclusion>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>log4j-over-slf4j</artifactId>
</exclusion>
</exclusions>
</dependency>
<!-- redis -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
<version>2.2.2.RELEASE</version>
</dependency>
<!--rabbitmq-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-amqp</artifactId>
<version>2.2.2.RELEASE</version>
</dependency>
<!--zookeeper-->
<dependency>
<groupId>org.apache.zookeeper</groupId>
<artifactId>zookeeper</artifactId>
<version>3.4.6</version>
<exclusions>
<exclusion>
<artifactId>slf4j-log4j12</artifactId>
<groupId>org.slf4j</groupId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.apache.curator</groupId>
<artifactId>curator-framework</artifactId>
<version>2.10.0</version>
</dependency>
<dependency>
<groupId>org.apache.curator</groupId>
<artifactId>curator-recipes</artifactId>
<version>2.10.0</version>
</dependency>
<!--redisson-->
<dependency>
<groupId>org.redisson</groupId>
<artifactId>redisson</artifactId>
<version>3.10.6</version>
</dependency>
<!--由于redisson底层是采用基于nio的netty框架进行通信,故而需要加入依赖-->
<!--<dependency>
<groupId>io.netty</groupId>
<artifactId>netty-all</artifactId>
<version>4.1.32.Final</version>
</dependency>-->
<!--for test-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<!--<scope>test</scope>-->
</dependency>
</dependencies>
<build>
<finalName>book_middleware_${project.parent.version}</finalName>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>${spring-boot.version}</version>
<executions>
<execution>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-war-plugin</artifactId>
<version>2.4</version>
<configuration>
<failOnMissingWebXml>false</failOnMissingWebXml>
</configuration>
</plugin>
</plugins>
<resources>
<resource>
<directory>src/main/resources</directory>
<filtering>true</filtering>
</resource>
</resources>
</build>
</project>
创建主入口
创建配置文件
application.yml:
spring:
#json日期格式化
jackson:
date-format: yyyy-MM-dd HH:mm:ss
time-zone: GMT+8
#数据库访问配置
datasource:
initialization-mode: always
driver-class-name: com.mysql.jdbc.Driver
url: jdbc:mysql://localhost:3306/db_middleware?useUnicode=true&characterEncoding=utf-8
username: root
password: 123456
jmx:
enabled: false
#redis
redis:
host: 127.0.0.1
port: 6379
# #rabbitmq配置
# rabbitmq:
# virtual-host: /
# host: 127.0.0.1
# port: 5672
# username: guest
# password: guest
#指定应用访问的上下文以及端口
server:
servlet:
context-path: /middleware
port: 8087
#logging日志配置
logging:
level:
org.springframework: INFO
com.fasterxml.jackson: INFO
com.zwx.middleware: DEBUG
# profiles:
# active: productions
# active: local
#mybatis配置
mybatis:
config-location: classpath:mybatis-config.xml
check-config-location: true
mapper-locations: classpath:mapper/*.xml
创建mybatis配置文件
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<settings>
<!-- 允许使用缓存配置 -->
<setting name="cacheEnabled" value="true"/>
<!-- SQL执行语句的默认响应超时时间 -->
<setting name="defaultStatementTimeout" value="3000"/>
<!-- 允许驼峰命名配置 -->
<setting name="mapUnderscoreToCamelCase" value="true"/>
<!-- 允许执行完SQL插入语句后返回主键的配置 -->
<setting name="useGeneratedKeys" value="true"/>
<!-- 设置控制台打印sql -->
<!--<setting name="logImpl" value="stdout_logging" />-->
</settings>
</configuration>
最后测试一下搭建的项目
package com.zwx.middleware.entity;
import lombok.Data;
@Data
public class Book {
private Integer bookNo;
private String name;
}
package com.zwx.middleware.controller;
import com.zwx.middleware.entity.Book;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
@RequestMapping("/book")
public class BookController {
@GetMapping("info")
public Book info(Integer bookNo,String bookName){
Book book = new Book();
book.setBookNo(bookNo);
book.setName(bookName);
return book;
}
}
使用postman测试
http://localhost:8087/middleware/book/info/?bookNo=10010&bookName=分布式中间件入门测试