一、前期工程创建
- 创建一个空项目
- 在项目上右键New->Module->Spring Initializr
二、创建一个注册中心(Eureka Server)
- 配置pom文件
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
<exclusions>
<exclusion>
<groupId>org.junit.vintage</groupId>
<artifactId>junit-vintage-engine</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-autoconfigure</artifactId>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
2.配置eureka信息application.yml
server:
port: 8761 #注册中心端口号
eureka:
instance:
hostname: eureka-server #eureka实例的主机名
client:
register-with-eureka: false #不把自己注册到eureka上
fetch-registry: false #不从eureka上来获取服务的注册信息
service-url:
defaultZone: http://localhost:8761/eureka #注册中心地址
3.使用@EnableEurekaServer启用注册中心的功能
/**
* 注册中心
* 1.配置eureka信息
* 2.@EnableEurekaServer
*/
@EnableEurekaServer
@SpringBootApplication
public class EurekaServerApplication {
public static void main(String[] args) {
SpringApplication.run(EurekaServerApplication.class, args);
}
}
4.启动服务,通过8761端口注册服务
三、创建一个服务提供者provider(Eureka Discorvery client)
1.配置eureka信息application.yml
server:
port: 8002 #服务提供端口
spring:
application:
name: provider-ticket
eureka:
instance:
prefer-ip-address: true #注册服务的时候使用服务的ip地址
client:
service-url:
defaultZone: http://localhost:8761/eureka
2.向注册中心提供一个服务
- controller
@RestController
public class TicketController {
@Autowired
TicketService ticketService;
@GetMapping("/ticket")
public String getTicket(){
return ticketService.getTicket();
}
}
- service
@Service
public class TicketService {
public String getTicket(){
//System.out.println("8002");
return "20200818";
}
}
3.运行,向注册中心注册服务
注册服务时,可同一个应用部署多个实例在注册中心中(对于不同的端口号,可以通过打jar包,运行每一个jar包就可部署多个 实例在注册中心)。
- 端口号8001
- 端口号8002
- 在Erueka中可以看到注册的两个实例
四、创建一个消费者consumer(Eureka Discorvery client)
1.配置eureka信息application.yml
spring:
application:
name: consumer-user
server:
port: 8200 #配置消费者端口号
eureka:
instance:
prefer-ip-address: true #注册服务的时候使用服务的ip地址
client:
service-url:
defaultZone: http://localhost:8761/eureka
2.处理请求
@RestController
public class userController {
@Autowired
RestTemplate restTemplate;
@GetMapping("/buy")
public String buyTicket(String name){
String s = restTemplate.getForObject("http://PROVIDER-TICKET/ticket", String.class);
return name + "的交易编号" + s;
}
}
3.从注册中心中发现服务
- 使用@EnableDiscoveryClient,开启发现服务功能
- RestTemplate:发送http请求,调用服务
- @Bean:放在容器中
- @LoadBalanced:使用负载均衡
@EnableDiscoveryClient //开启发现服务功能
@SpringBootApplication
public class ConsumerUserApplication {
public static void main(String[] args) {
SpringApplication.run(ConsumerUserApplication.class, args);
}
@LoadBalanced //使用负载均衡
@Bean
public RestTemplate restTemplate(){
return new RestTemplate();
}
}
4.启动服务方,调用到提供者的服务
http://localhost:8200/buy?name=JOOOE