【微服务核心笔记】

一、注册中心 Nacos

Alibaba Nacos,服务提供者和服务消费者将自己的信息注册到注册中心,注册中心通过心跳机制来确保每个服务都可以正常运行,服务消费者订阅注册中心,注册中心为服务消费者推送变更信息

1、功能

  • 动态服务发现
  • 配置管理

2、搭建

  1. 创建 nacos 所需要的数据库
  2. 在服务器创建 nacos 配置文件 custom.env,指定模式和连接 Mysql 相关信息
  3. 使用 docker 创建 nacos 镜像,指明配置文件
  4. 访问 ip:8848/nacos,账号密码 nacos

3、服务注册

将服务注册到 Nacos 中,让它统一管理

  1. 服务中添加 spring-cloud-starter-alibaba-nacos-discovery 的依赖
  2. 服务中添加 Nacos 配置,改服务端口其他配置相同会自动变成集群
spring:application:name: item-service # 服务名称cloud:nacos:server-addr: 192.168.150.101:8848 # nacos地址

4、服务发现

在一个服务中得到已经注册的其他服务的信息

  1. 服务中添加 spring-cloud-starter-alibaba-nacos-discovery 的依赖
  2. 自动注入 DiscoveryClient,使用 List<ServiceInstance> instance = discoveryClient.getInstances("服务名称") 得到实例列表,然后通过 ServiceInstance instance = instances.get(RandomUtil.randomInt(instances.size())); 随机得到一个服务对象,就可以使用此对象获得相关信息,如:instance.getUri() 获得服务的地址

二、远程调用 OpenFeign

Spring Cloud OpenFeign,是一个声明式的 http 客户端,是 SpringCloud 在 Eureka 公司开源的 Feign 基础上改造而来。基于 SpringMVC 的常见注解,优雅的实现 http 请求的发送

1、基础使用

  1. 服务中添加 spring-cloud-starter-openfeignspring-cloud-starter-loadbalancer 依赖
  2. 在启动类上添加 @EnableFeignclients 注解来开启远程调用
  3. 编写 OpenFeign 客户端:@FeignClient 指定要请求的服务列表;@GetMapping 指定请求方式和请求路径;方法参数指定请求参数;方法返回值指定返回后封装的类型
// 3. 编写 OpenFeign 客户端
// 向 http://item-service/items 发送一个 GET 请求,携带 ids 为请求参数,并自动将返回值处理为 List<ItemDTO>
@FeignClient("item-service")
public interface ItemClient {@GetMapping("/items")List<ItemDTO> queryItemByIds(@RequestParam("ids") Collection<Long> ids);
}

2、开启连接池

Feign 底层默认 HttpURLConnection 实现,不支持连接池,为了更好的性能,通常使用支持连接池的实现 OKHttp、Apache HttpClient

使用

  1. 引入 feign-okhttp 依赖
  2. 在配置文件中配置:feign:okhttp:enabled: true # 开启 OKHttp 功能

3、最佳实践

项目中一般是将所有的远程调用封装到一个模块中,然后让其他服务引入这个模块,但是可能会出现注解扫描不到的情况,所以要在启动类的注解上添加 @EnableFeignclients(basePackages = "远程调用模块的包路径")

4、输出日志

OpenFeign 只会在 FeignClient 所在包的日志级别为 DEBUG 时,

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/585176.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

根据文法求对应的语言

技巧&#xff1a;最后得到的是终结符组成的闭包 例题&#xff1a; 文法G[S]: S-->AB A-->aAb|ab B-->Bc|&#xff0c;求对应的语言 ①S-->(aAb|ab)(Bc|) ②我们可以观察到&#xff0c;无论A-->aAb还是A-->ab&#xff0c;都一定会同时出现ab,…

3、python-常见数据类型-元组(tuple)

简介 元组是一种不可变序列 元组也是一种序列&#xff0c;因此也可以对它进行索引、分片 一.定义元组 # TODO a 是一个元组 a (1, 2, 3) # TODO 空元组 b () # TODO 元组是以逗号分割 c (12) d (12,) print(a) print(b) print(c) print(d)# (1, 2, 3) # () # 12 # (12,)…

Java学习——设计模式——结构型模式1

文章目录 结构型模式代理模式适配器模式 结构型模式 结构型模式主要涉及如何组合各种对象以便获得更好、更灵活的结构。虽然面向对象的继承机制提供了最基本的子类扩展父类的功能&#xff0c;但结构型模式不仅仅简单地使用继承&#xff0c;而更多地通过组合与运行期的动态组合来…

NModbus-一个C#的Modbus协议库实现

NModbus-一个基于C#实现的Modbus通信协议库 最近在学习C#的时候&#xff0c;因为之前做过环保设备时使用C做过环保设备采集使用到了Modbus协议&#xff0c;当时看了一下基于C语言开发的libmodbus库。所以特意搜索看了一下C#下有什么Modbus协议库&#xff0c;在Github上面找了一…

Spring Cloud Gateway之Predicate断言详解

目录 Predicate&#xff08;断言&#xff09;内置Predicate请求参数匹配请求路径匹配Header 属性匹配Cookie 匹配请求方式匹配请求 ip 地址匹配时间匹配组合匹配 Predicate&#xff08;断言&#xff09; 在 Spring Cloud Gateway 中&#xff0c;Predicate&#xff08;断言&…

K8S学习指南(49)-k8s的证书管理

文章目录 引言什么是证书管理&#xff1f;证书管理的基本流程1. 证书生成2. 证书签发3. 证书使用4. 证书更新 Kubernetes 证书管理示例1. 生成自签名证书2. 使用自签名证书3. 部署使用证书的应用 证书续期与更新结论 引言 Kubernetes&#xff08;K8s&#xff09;是一款开源的容…

idea 如何开启mybatis控制台SQL日志打印

开启 application.yaml mybatis-plus:configuration:log-impl: org.apache.ibatis.logging.stdout.StdOutImplmybatis:configuration:log-impl: org.apache.ibatis.logging.stdout.StdOutImplmap-underscore-to-camel-case: truetypeAliasesPackage: XXXXmapper-locations: c…

【AI】人工智能爆发推进器之知识图谱

目录 一、什么是知识图谱 二、知识图谱的发展历程 三、知识图谱的应用场景 四、知识谱图的例子 知识图谱&#xff0c;一度被称作是人工智能的基石&#xff0c;这是应用组普遍的技术或者说是理念。 一、什么是知识图谱 **知识图谱&#xff08;Knowledge Graph&#xff09;…

node.js对应npm安装和使用

介绍 node.js是一个基于 Chrome V8 引擎的 JavaScript 运行环境&#xff0c;安装node后自带npm。NPM &#xff1a;Node Package ManagerNPM是Node.js标准的软件包管理器 。2010年底&#xff0c;Node.js 的包管理器 npm 诞生&#xff0c;是全球最大的开源库生态系统。 node 20…

SONiC和ONL所依赖的Debian版本说明

Debian 的最新几个版本 下一代 Debian 正式发行版的代号为 trixie — 测试&#xff08;testing&#xff09;版 Debian 12 (bookworm) — 当前的稳定&#xff08;stable&#xff09;版 Debian 11 (bullseye) — 当前的旧的稳定&#xff08;oldstable&#xff09;版 Debian 10&a…

idea配置docker推送本地镜像到远程私有仓库

目录 1&#xff0c;搭建远程Docker 私有仓库 Docker registry 2&#xff0c;Windows10/11系统上安装Docker Desktop 3&#xff0c;idea 配置远程私有仓库地址 4&#xff0c;idea 配置Docker 5&#xff0c;idea在本地构建镜像 6&#xff0c;推送本地Docker镜像到远程 Dock…

线性代数——(期末突击)行列式(上)-行列式计算、行列式的性质

目录 行列式 行列式计算 逆序数 行列式的性质 转置 两行&#xff08;列&#xff09;互换 两行&#xff08;列&#xff09;对应相等 提公因子 两行&#xff08;列&#xff09;对应成比例 某行&#xff08;列&#xff09;为零 行列式分裂 行列式变换及三角行列式 行…

Leetcode.2735 收集巧克力

题目链接 Leetcode.2735 收集巧克力 rating : 2043 给你一个长度为 n n n、下标从 0 0 0 开始的整数数组 n u m s nums nums&#xff0c; n u m s [ i ] nums[i] nums[i] 表示收集位于下标 i i i 处的巧克力成本。每个巧克力都对应一个不同的类型&#xff0c;最初&#xff…

通过ADB来实现脚本来控制手机

ADB 简介 adb的全称为Android Debug Bridge,安卓调试桥,可以通过调试命令来控制手机,诸如开机,关机等按键控制;或者启动,关闭应用;异或进行触摸模拟. 通过学习adb,可以实现简单的脚本控制,最大的特点是不需要root,对于普通手机都可以进行,帮助我们完成一些简单的重复性事件,…

centos搭建kubernetes集群步骤

目录 1. 修改host 2. 时间同步 3. 禁用firewalled 4. 禁用selinux 5. 禁用swap 6. 网桥设置 7. docker安装 8. 安装k8s 9. 异性操作 10. 配置flannel​​​​​​​ 1. 修改host cat >> /etc/hosts << EOF 172.16.188.175 master 172.16.188.176 node1 …

基于Freeswitch实现的Volte网视频通知应用

现在运营商的Volte网络已经很好的支持视频通话了&#xff0c;因此在原来的电话语音通知的基础上&#xff0c;可以更进一步实现视频的通知&#xff0c;让用户有更好的体验&#xff0c;本文就从技术角度&#xff0c;基于Freeswitch来实现此类应用&#xff08;本文假设读者已对Fre…

2分钟快速了解Nginx

1.简介 Nginx&#xff08;发音为 “engine x”&#xff09;是一个高性能的HTTP和反向代理服务器&#xff0c;也用作邮件代理服务器。它以其稳定性、丰富的功能集、简单的配置和低资源消耗而闻名。 2.详细解释 Nginx由俄罗斯程序员Igor Sysoev为解决C10k问题&#xff08;即同…

三台CentOS7.6虚拟机搭建Hadoop完全分布式集群(三)

这个是笔者大学时期的大数据课程使用三台CentOS7.6虚拟机搭建完全分布式集群的案例&#xff0c;已成功搭建完全分布式集群&#xff0c;并测试跑实例。 9 安装hbase 温馨提示&#xff1a;安装hbase先在master主节点上配置&#xff0c;然后远程复制到slave01或slave02 &#xf…

6130 树的最长路

思路&#xff1a;树的最长路问题可以通过两次 DFS 求解&#xff0c;具体思路如下&#xff1a; 1.第一次 DFS 求树的直径 以任意一个点为起点进行深度优先遍历&#xff08;DFS&#xff09;&#xff0c;找到与该点距离最远的点 u 。 以 u 为起点进行 DFS &#xff0c;找到与 u 距…

pytest pytest-html优化样式

conftest.py import pytest from pytest_metadata.plugin import metadata_keydef pytest_html_report_title(report):report.title"接口测试报告"def pytest_configure(config):# 获取命令行参数中的测试环境、测试版本、开始时间、测试人员config.stash[metadata_…