pom.xm中的依赖:
<?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.itcast.cloud</groupId>
<artifactId>cloud-demo</artifactId>
<packaging>pom</packaging>
<version>1.0-SNAPSHOT</version>
<modules>
<module>user-service</module>
<module>user-registry</module>
<module>user-invoke</module>
</modules>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-autoconfigure</artifactId>
<version>2.0.3.RELEASE</version>
</dependency>
</dependencies>
<!-- -->
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.1.RELEASE</version>
<relativePath/>
</parent>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
<spring-cloud.version>Finchley.RELEASE</spring-cloud.version>
<mybatis.starter.version>1.3.2</mybatis.starter.version>
<mapper.starter.version>2.0.2</mapper.starter.version>
<mysql.version>5.1.32</mysql.version>
<pageHelper.starter.version>1.2.3</pageHelper.starter.version>
</properties>
<dependencyManagement>
<dependencies>
<!-- springCloud -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<!-- mybatis启动器 -->
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>${mybatis.starter.version}</version>
</dependency>
<!-- 通用Mapper启动器 -->
<dependency>
<groupId>tk.mybatis</groupId>
<artifactId>mapper-spring-boot-starter</artifactId>
<version>${mapper.starter.version}</version>
</dependency>
<!-- 分页助手启动器 -->
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper-spring-boot-starter</artifactId>
<version>${pageHelper.starter.version}</version>
</dependency>
<!-- mysql驱动 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>${mysql.version}</version>
</dependency>
</dependencies>
</dependencyManagement>
<repositories>
<repository>
<id>spring-milestones</id>
<name>Spring Milestones</name>
<url>https://repo.spring.io/milestone</url>
<snapshots>
<enabled>false</enabled>
</snapshots>
</repository>
</repositories>
</project>
注册中心的配置:application.yml文件:
server:
port: 10088
spring:
application:
name: user-registry
eureka:
client:
service-url: # 这个表示eureka配置到哪台服务器中;
defaultZone: http://127.0.0.1:10088/eureka
register-with-eureka: false # 表示不注册自己 高可用的时候可以打开
fetch-registry: false # 表示本身是注册中心 不去拉取里面的服务
启动类的配置:
@SpringBootApplication
@EnableEurekaServer
public class UserRegistryApplication {
public static void main(String[] args) {
SpringApplication.run(UserRegistryApplication.class, args);
}
}
微服务1的application.yml的配置:
server:
port: 8090
spring:
application:
name: user-service
datasource:
url: jdbc:mysql://localhost:3306/mybatis
username: root
password: 123
mybatis:
type-aliases-package: com.itcast.user.pojo
configuration:
map-underscore-to-camel-case: true
eureka:
client:
service-url:
defaultZone: http://127.0.0.1:10088/eureka
instance:
lease-renewal-interval-in-seconds: 5 # 每隔5秒发送一次心跳
lease-expiration-duration-in-seconds: 40 # 40秒不发送就过期
prefer-ip-address: true
ip-address: 127.0.0.1
instance-id: ${spring.application.name}:${server.port}
微服务1的启动类配置:
@SpringBootApplication
@MapperScan("com.itcast.user.mapper")
@EnableDiscoveryClient
public class UserApplication {
public static void main(String[] args) {
SpringApplication.run(UserApplication.class, args);
}
}
暴露微服务1的接口:直接把controller中的方法直接写成接口的抽象方法暴露
public interface UserApi {
@GetMapping("/{id}")
User queryById(@PathVariable("id") Long id);
}
微服务2的配置application.yml文件配置:
server:
port: 8091
spring:
application:
name: invoke-service
datasource:
url: jdbc:mysql://localhost:3306/mybatis
username: root
password: 123
eureka:
client:
service-url:
defaultZone: http://127.0.0.1:10088/eureka
instance:
lease-renewal-interval-in-seconds: 5 # 每隔5秒发送一次心跳
lease-expiration-duration-in-seconds: 40 # 40秒不发送就过期
prefer-ip-address: true
ip-address: 127.0.0.1
instance-id: ${spring.application.name}:${server.port}
微服务2启动类的配置:
@SpringBootApplication
@EnableDiscoveryClient
@EnableFeignClients
public class InvokeApplication {
public static void main(String[] args) {
SpringApplication.run(InvokeApplication.class, args);
}
}
怎么调用微服务1的接口:
@FeignClient(value = "user-service",path = "/user")
public interface UserClient{
@GetMapping("/{id}")
User queryById(@PathVariable("id") Long id);
}
在微服务上面这样配置可以直接用xml写sql语句,可以不用注释;
server:
port: 8089
spring:
application:
name: order-service
datasource:
url: jdbc:mysql://127.0.0.1:3306/heima32?useUnicode=true&characterEncoding=utf8&autoReconnect=true&allowMultiQueries=true
username: root
password: 123
driver-class-name: com.mysql.jdbc.Driver
druid:
initial-size: 5
min-idle: 5
max-active: 20
max-wait: 1000
test-on-borrow: true
rabbitmq:
host: 192.168.36.131
username: leyou
password: leyou
virtual-host: /leyou
template:
retry:
enabled: true
initial-interval: 10000ms
max-interval: 30000ms
multiplier: 2
exchange: ly.item.exchange
publisher-confirms: true
redis:
host: 192.168.36.131
eureka:
client:
service-url:
defaultZone: http://127.0.0.1:10086/eureka
instance:
prefer-ip-address: true
ip-address: 127.0.0.1
instance-id: ${eureka.instance.ip-address}.${server.port}
lease-renewal-interval-in-seconds: 3
lease-expiration-duration-in-seconds: 40
mybatis:
type-aliases-package: com.leyou.item.pojo
mapper-locations: mapper/OrderMapper.xml
configuration:
map-underscore-to-camel-case: true
mapper:
not-empty: false
identity: mysql
ly:
worker:
workerId: 1
datacenterId: 1
jwt:
pubKeyPath: E:/heima32/ssh/id_rsa.pub # 公钥地址
cookieName: LY_TOKEN # cookie的名称
pay:
appId: wx8397f8696b538317
mchId: 1473426802
key: T6m9iK73b0kn9g5v426MKfHQH7X8rKwb
connectTimeoutMs: 5000
readTimeoutMs: 10000