微服务
Maven的依赖冲突解决方案:
- 路径最短原则
- 配置优先原则
- 破坏规则则使用排除
微服务
将应用划分为若干个体量更小的服务,每个服务可以独立开发、独立部署、独立运行,服务之间可以通过轻量级通信机制进行相互调用。
Nacos应用步骤
服务提供者
1、添加依赖
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
2、添加配置
spring.application.name=role-service 定义的服务名称,服务消费者是通过服务名称查找地址
spring.cloud.nacos.discovery.server-addr=localhost:8848 Nacos的地址
3、在配置类上添加注解以启动Nacos客户端
@EnableDiscoveryClient 也可以直接定义在主类
@SpringBootConfiguration
public class NacosConfig {
}
服务消费者
1、添加依赖
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
2、添加配置配置
spring.application.name=user-service 定义的服务名称,服务消费者是通过服务名称查找地址
spring.cloud.nacos.discovery.server-addr=localhost:8848 Nacos的地址
3、通过注解启动nacos client
@EnableDiscoveryClient
4、可以通过nacos client查询注册在nacos中的所有对应的服务提供者
@RestController
public class TestController {
@Autowired
private RestTemplate restTemplate;
@Autowired
private DiscoveryClient discoveryClient;
@GetMapping("/test")
public String test(String name){
// String url="http://localhost:8070/hello?name=zhangsan"
//从nacos根据服务名称获取对应的服务提供方的地址端口号等信息
List<ServiceInstance> serviceInstances = discoveryClient.getInstances("hello-service");
//从nacos种获取服务列表后需要根据某种策略获取某一个具体的服务实例---负载均衡
Random r=new Random();
ServiceInstance instance = serviceInstances.get(r.nextInt(serviceInstances.size()));
System.out.println("远程服务的主机地址:"+instance.getHost());
System.out.println("远程服务的端口号:"+instance.getPort());
//拼接访问的URL地址
String url=instance.getUri()+"/say?name="+name;
System.out.println("远程服务地址:"+url);
String res = restTemplate.getForObject(url, String.class);
return "Consumer:["+res+"]";
}
}
Nacos使用步骤
1、安装
2、 启动nacos命令startup -m standalone
3、启动服务提供者
4、在nacos的webUI可以查看localhost:8848/nacos