认识微服务
微服务技术栈
微服务概念
微服务结构
微服务技术对比
企业需求
SpringCloud
认识Springcloud
服务拆分及远程调用
每个服务只能查询自己数据库中的表,导致其他服务如果想使用别人的表数据,这就需要进行远程调用,这里使用RestTemplate进行发送http请求来实现远程调用
第一步:在启动类中创建Restemplate对象
@MapperScan("cn.itcast.order.mapper")
@SpringBootApplication
public class OrderApplication {public static void main(String[] args) {SpringApplication.run(OrderApplication.class, args);}/*** 创建RestTempalte并注入Spring容器* @return*/@Beanpublic RestTemplate restTemplate(){return new RestTemplate();}}
第二步:在订单服务中通过注入RestTemplate来发送http请求到用户服务中
@Service
public class OrderService {@Autowiredprivate OrderMapper orderMapper;@Autowiredprivate RestTemplate restTemplate;public Order queryOrderById(Long orderId) {// 1.查询订单Order order = orderMapper.findById(orderId);// 2。利用RestTemplate发起http请求,查询用户String url = "http://localhost:8081/user/"+order.getUserId();User user = restTemplate.getForObject(url, User.class);//3. 封装数据order.setUser(user);// 4.返回return order;}
}
上面这种方式并没有体现或者使用微服务技术,而且会有很多的问题
Eureka
硬编码导致程序复用性太低,所以到底服务消费者怎样获取地址以及如何选择。所以我们引入一门新技术Eureka
使用Eureka步骤:
①搭建Eureka服务器
第一步:引入依赖
<!-- eureka服务器依赖--><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-server</artifactId></dependency>
第二步:在启动类上添加注解@EnableEurekaServer注解
@EnableEurekaServer
@SpringBootApplication
public class EurekaApplication {public static void main(String[] args) {SpringApplication.run(EurekaApplication.class,args);}
}
第三步:配置Eureka信息
server:port: 10086 # 服务端口spring:application:name: eurekaserver # eureka服务名称
eureka:client:service-url: # eureka的地址信息defaultZone: http://127.0.0.1:10086/eureka
②服务注册,即微服务在Eureka上注册登记
第一步:引入依赖
<!-- eureka客户端依赖--><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId></dependency>
第二步:配置文件
spring:datasource:url: jdbc:mysql://localhost:3306/cloud_user?useSSL=falseusername: rootpassword: rootdriver-class-name: com.mysql.cj.jdbc.Driverapplication:name: userservice # user服务端名称eureka:client:service-url: # eureka的地址信息defaultZone: http://127.0.0.1:10086/eureka
③服务拉取,即一个微服务拉取另外一个微服务的服务
第一步:修改Service层的代码,把硬编码改为服务名
@Service
public class OrderService {@Autowiredprivate OrderMapper orderMapper;@Autowiredprivate RestTemplate restTemplate;public Order queryOrderById(Long orderId) {// 1.查询订单Order order = orderMapper.findById(orderId);// 2。利用RestTemplate发起http请求,查询用户String url = "http://userservice/user/"+order.getUserId();//使用rureka服务名User user = restTemplate.getForObject(url, User.class);//3. 封装数据order.setUser(user);// 4.返回return order;}
}
第二步:负载均衡,在启动类上加@LoadBalanced注解
@MapperScan("cn.itcast.order.mapper")
@SpringBootApplication
public class OrderApplication {public static void main(String[] args) {SpringApplication.run(OrderApplication.class, args);}/*** 创建RestTempalte并注入Spring容器* @return*/@Bean@LoadBalanced //负载均衡public RestTemplate restTemplate(){return new RestTemplate();}}
④总结
Ribbon负载均衡原理
获取Service服务列表:
负载均衡的策略:
负载均衡规则详解:
修改负载均衡规则:
①在拉取服务的消费者中的启动类中设置:
②在拉取服务的消费者中的yml配置文件中设置:
饥饿加载:
Nacos
启动命令:startup.cmd -m standalone
服务注册和拉取:
第一步:引入依赖
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-alibaba-dependencies</artifactId><version>2.2.6.RELEASE</version><type>pom</type><scope>import</scope></dependency>
<!-- nacos客户端依赖包 --><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency>
第二步:更改配置
application:name: orderservice # orderservice服务端名称cloud:nacos:server-addr: localhost:8848
服务多级存储模型(服务-集群-实例)
application:name: orderservice # orderservice服务端名称 cloud:nacos:server-addr: localhost:8848discovery:cluster-name: HZ # 集群名字
集群模式下的负载均衡规则:
application:name: orderservice # orderservice服务端名称cloud:nacos:server-addr: localhost:8848discovery:cluster-name: HZ #集群名字userservice:ribbon:NFLoadBanlancerRuleClassName : com.alibaba.cloud.nacos.ribbon.NacosRule
服务实例的权重设置:
环境隔离
application:name: orderservice # orderservice服务端名称cloud:nacos:server-addr: localhost:8848discovery:cluster-name: HZ #集群名字namespace: a7e40dd8-f071-420a-ac82-58be16660415 #配置namespaceuserservice:ribbon:NFLoadBanlancerRuleClassName : com.alibaba.cloud.nacos.ribbon.NacosRule
Eureka和Nacos的总结对比
①与Eureka不同的是,Nacos中服务提供者被划分了临时实例和非临时实例。临时实例是以心跳监测健康状态,当不健康就会被剥离。而非临时实例是以nacos主动询问健康状态,就算不健康也不会被剥离。
②在Eureka中,消费者每隔30秒去注册中心pull拉取服务列表并缓存,而在Nacos中消费者是以拉取pull+注册中心主动推送变更消息push来获取服务列表