下载nacos,找到bin目录下startup.cmd启动nacos。正常启动如图,默认端口8848
idea中建立springboot服务提供者工程,依赖如下
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<!-- springboot 整合web组件-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- 服务注册中心 -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
<version>0.2.2.RELEASE</version>
</dependency>
</dependencies>
application,yml文件
spring:
cloud:
nacos:
discovery:
###服务注册地址
server-addr: 127.0.0.1:8848
application:
##服务名称
name: member
server:
port: 8081
编写一个服务接口
@RestController
public class UserService {
@Value("${server.port}")
private String serverPort;
@RequestMapping("/getUser")
@ResponseBody
public String getUserName(){
return "yuanping"+serverPort;
}
}
然后启动工程,启动成功后打开nacos主页查看服务注册情况。这里我不同端口启动两个服务。只需要把application.yml文件端口改为8082就行。
访问地址
http://localhost:8848/nacos/index.html,
同样的我再创建一个消费者工程,同样创建springboot工程,maven依赖。编写一个消费接口。这个代码是获取到nacos注册的所有实例,然后通过负载均衡算法发别请求不同的主机端口。
@RestController
public class OrderService {
@Autowired
private DiscoveryClient discoveryClient;
@Autowired
private RestTemplate restTemplate;
private AtomicInteger atomicInteger = new AtomicInteger(0);
@RequestMapping("/getOrderToMember")
public String getOrderToMember() {
// 1.根据服务名称 从服务注册中心获取 调用接口地址集群列表
List<ServiceInstance> instances = discoveryClient.getInstances("member");
ServiceInstance serviceInstance = instances.get(atomicInteger.incrementAndGet()%instances.size());
URI uri = serviceInstance.getUri();// ip和端口号
// 2.使用本地负载均衡器 选择一个地址调用
// 3. 使用httpclient调用接口
String result = restTemplate.getForObject(uri + "/getUser", String.class);
return result;
}
}
直接访问接口地址,即可访问另一个工程的应用接口。每刷一次就是另一个工程端口。