一. rpc基本学习

1. 什么是rpc,为什么有了http还要rpc

我们常说的http,应该是说的http1,http只是应用层的一个协议
Rpc是一种调用方式,全称叫远程过程调用,对应本地调用,rpc是一种调用方式,不是一种协议
更具体的来说,rpc使用的数据传输协议,不是像http1一样一种业界通用的协议,而是在TCP、UDP、http2基础上自定义的一种协议

Rpc传输数据的过程本质和http1其实是一样的,都是一套网络框架,不同之处在于:
第一个就是协议层:数据都是基于TCP连接来传输的,一样都有消息头和消息体,两者的区别在于消息头,http的优点是可以自定义很多字段,十分灵活,但是对于功能单一的微服务之间来说,请求头中事实上很多字段都是冗余的,例如各种浏览器行为的请求头;同时,虽然都是基于TCP连接,但是Rpc基于http2,有多路复用的优势,不像http1建立一个tcp连接,如果不是升级成websocket,甚至是一种半双工的状态,rpc速度更快;
第二个编解码层:也就是网络传输之前,需要将结构化数据和二进制数据互相转化,也就是序列化和反序列化的过程,http使用的是json,优点是直观灵活,缺点是没有类型空间大。

总之:rpc适用于在微服务架构下,职责单一的服务之间做数据传输,相比于http1,有数据包更小,序列化更快,传输效率更高的优势。
但是rpc要求服务之间接口有强依赖,因为像本地调用一样来调用的方式,决定了桩文件需要统一,当接口需要更新调整时,服务双方都要进行更新; 同时服务之间加密认证也要维护,例如TLS方式的认证,当客户端域名增加时,需要升级证书私钥,否则服务端不能识别。

2. grpc框架

2.1 安装grpc的使用环境

也就是proto buf的序列化协议编译器,该协议是谷歌的协议,其他协议请自行下载对应的编译器。
进入github,搜索protobuf
下载win64的zip包
解压
配置环境变量
运行命令 protoc 看是否配置成功

2.2 安装go语言的grpc核心库

go get google.golang.org/grp
生成别的语言请自行查看需要安装的库
有了核心库之后
就可以直接安装go语言的两个关键应用
go install google.golang.org/protobuf/cmd/protoc-gen-go@latest
go install google.golang.org/grpc/cmd/protoc-gen-go-grpc@latest
这两个安装完成之后,
Gopath目录的bin下就出现了这两个exe文件
在这里插入图片描述

2.3 写约束文件

编写一个XXX.proto文件
简单例子:
在这里插入图片描述

然后cd到该文件的目录下,想生成什么语言的文件,就用什么语言对应的命令,这里用go举例:
protoc --go_out=. XXX.proto
protoc --go-grpc_out=. XXX.proto
在这里插入图片描述

2.4 写业务逻辑

可以直接在grpc文件中写业务逻辑,也可以继承该grpc文件,重写方法来实现业务逻辑。
在这里插入图片描述
最好重写,否则一旦更新并重新生成,很麻烦。

2.5 服务端编写

创建grpc server对象S
将S注册到grpc Server的内部注册中心
创建listen,监听TCP连接
在这里插入图片描述

2.6 客户端编写

创建指定服务器的TCP连接
创建客户端对象Conn
发送RPC请求,接收响应
在这里插入图片描述

3. grpc认证安全传输

这里的认证不是用户的身份认证,而是指多个server和多个client之间,如何识别对方是谁,并且可以安全的进行数据的传输

SSL/TLS认证方式
基于TOKEN的认证方式
不采用任何措施的连接,这是不安全的连接
自定义的身份认证。

3.1 SSL/TLS认证方式

客户端和服务端之间的调用,我们可以通过加入证书的方式,实现调用的安全性
TLS建立于TCP协议之上的协议,是应用层的协议,前身是SSL,作用是将应用层的报文进行加密之后再交给TCP进行传输
首先通过openssl生成证书和私钥
下载openssl的安装包(用第三方的,不用自己编译)
下载地址: https://slproweb.com/products/Win32OpenSSL.html
配置环境变量
查看是否安装成功
生成私钥: Openssl genrsa -out server.key 2048
在这里插入图片描述
生成证书:openssl req -new -x509 -key server.key -out server.crt -days 36500
国家名字那些先全部回车留空
在这里插入图片描述
Crt文件是根据key文件生成的
然后再生成csr
Openssl req -new -key server.key -out server.csr
在这里插入图片描述
将openssl的安装目录中的openssl.cfg文件复制到同级目录下
然后解开
copy_extensions = copy
再解开
req_extensions = v3_req # The extensions to add to a certificate request
再添加代码
在这里插入图片描述
DNS.1 = example.com
可以写多个,这个相当于访问域名是否会同意
到此准备工作完成
接着生成自己的私钥
Openssl genpkey -algorithm RSA -out test.key
在这里插入图片描述
再生成我们自己的证书
Openssl req -new -nodes -key test.key -out test.csr -days 3650 -subj “/C=cn/O=mycomp/CN=myname” -config ./openssl.cfg -extensions v3_req
在这里插入图片描述
最后生成san证书 pem
Openssl x509 -req -days 365 -in test.csr -out test.pem -CA server.crt -CAkey server.key -CAcreateserial -extfile ./openssl.cfg -extensions v3_req
在这里插入图片描述
目前一共有了7個文件,但是我们要用到的就是两个,一个test.key,也就是私钥文件,一个是test.pem证书文件
其他的文件都用于认证和签发
然后就是使用我们自己生成的文件来认证服务了

首先是服务端
在这里插入图片描述
然后这时服务端就不是谁都可以访问了
在这里插入图片描述

3.2 基于TOKEN的认证方式

同样是在credentials包下
有两个需要我们的客户端自己实现的接口
在这里插入图片描述
首先就是客户端要传递Token信息给服务端
在这里插入图片描述
在这里插入图片描述
然后就是服务端要能够处理客户端发来的token信息
在这里插入图片描述
总之,grpc将各种认证方式浓缩到一个统一的credentials上,可以单独使用一种凭证,也可以一起使用,这也是grpc的精妙之处

事实上,服务端对token的验证使用拦截器来统一处理的
代码的改造就是这样
在这里插入图片描述
在这里插入图片描述

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

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

相关文章

Marin说PCB之在CST软件中如何搭建两端子电容器--02

上回书到说到李相赫同学在导入一颗新的两端子电容器物料的时候,发现其阻抗频率特性曲线太反常了: 和之前的Murata家的GRT033D70E105ME18这个物料放在一起比对一下: 上编文章中有一句话我不知道诸位道友们是否还有印象啊? Murata家…

断点回归模型

断点回归(Regression Discontinuity Design, RDD)是一种准实验设计方法,用于评估政策或其他干预措施的效果。这种方法利用了一个清晰的阈值或“断点”,在这个阈值上,处理状态(例如是否接受某种干预&#xf…

2-2 opencv实战进阶系列 多边形识别

目录 一、不说废话,先上现象 二、前言 三、思路讲解 step1:用阈值编辑器对图像进行处理。 step2:应用阈值进行二值化 step3:轮廓查找 step4: 显示文字 四、完整代码贴出 五、现象展示 六、结语 一、不说废话&…

【FastAPI】离线使用Swagger UI 或 国内网络如何快速加载Swagger UI

在FastAPI中,默认情况下,当应用启动时,Swagger UI 会通过在线加载 Swagger UI 的静态资源。这意味着如果应用运行在没有互联网连接的环境中,默认的 Swagger 文档页面将无法加载。 为了在离线环境中使用 Swagger UI,你…

计算机毕业设计 智能推荐旅游平台 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点…

生成树详细配置(STP、RSTP、MSTP)

目录 一. 实验内容 STP配置实验 RSTP配置实验 MSTP配置实验 二. 1 ) STP配置实验 实验拓扑 ​编辑 实验配置 实验结果 2 ) RSTP配置实验 实验拓扑 实验配置 实验结果 3 ) MSTP配置实验 实验拓扑 实验配置 ​编辑 实验结果 三 实验总结 一. 实验内容 1) …

(详细整理!!!!)Tensorflow与Keras、Python版本对应关系!!!

小伙伴们大家好,不知道大家有没有被tensorflow框架困扰过 今天我就给大家整理一下tensorflow和keras、python版本的对应关系 大家这些都可以在官网找到,下面我把官网的连接给大家放在这里:在 Windows 环境中从源代码构建 | TensorFlow (g…

Centos镜像详细下载思路总结:包括阿里云镜像下载和官方地址下载--centos7和centos8 镜像下载

Centos镜像详细下载思路总结:包括阿里云镜像下载和官方地址下载。 系统镜像下载: 阿里云镜像: centos-vault安装包下载_开源镜像站-阿里云 官方网址: https://vault.centos.org/7.6.1810/isos/ 系统相关依赖包下载&#xff1a…

vue的ref和refs

语法 ref默认找当前组件中的,如果组件中有多个元素相同的ref值,默认找到最后一个

【OpenCV3】图像的翻转、图像的旋转、仿射变换之图像平移、仿射变换之获取变换矩阵、透视变换

1 图像的放大与缩小 2 图像的翻转 3 图像的旋转 4 仿射变换之图像平移 5 仿射变换之获取变换矩阵 6 透视变换 1 图像的放大与缩小 resize(src, dsize[, dst[, fx[, fy[, interpolation]]]]) src: 要缩放的图片dsize: 缩放之后的图片大小, 元组和列表表示均可.dst: 可选参数, 缩…

Python用MarkovRNN马尔可夫递归神经网络建模序列数据t-SNE可视化研究

原文链接:https://tecdat.cn/?p37634 本文聚焦于利用马尔可夫递归神经网络(MarkovRNN)结合树库展开建模工作。MarkovRNN 通过整合马尔可夫特性与离散随机变量来深入探索递归神经网络中的随机转换机制,旨在高效处理具有复杂潜在信…

OCR在线识别网站现已上线!

注意,本文只提供学习的思路,严禁违反法律以及破坏信息系统等行为,本文只提供思路 如有侵犯,请联系作者下架 由作者亲自开发的ocr识别网站哈哈,暂时汇聚了三十多种验证码模型以及算法,欢迎各路朋友去尝试,网站地址如下 http://gbj5w3.natappfree.cc/ocr 验证码类型包括但…

WORD批量转换器MultiDoc Converter

WORD批量转换器MultiDoc Converter https://www.52pojie.cn/thread-1318745-1-1.html 可批量将doc、docx等文件格式转成doc、docx、pdf、rtf、txt、html、epub等格式。 安装包下载地址:https://wws.lanzouj.com/irvVbiz0pkd 最终下载文件打包地址(未作成…

刘润《关键跃升》读书笔记7

沟通: 想明⽩,说清楚,能接受 团队沟通的正确⽅式可以⽤9个字来概括:想明⽩,说清楚,能接受 (⻅图4-1)想明⽩ 有时经理跟⼈沟通,讲完之后却⽆奈地对员⼯说,你怎…

ubuntu 安装python3 教程

本篇教程,主要介绍如何在Ubuntu上安装python3教程。 1、查看是否有python 在安装前,首先看看自己系统上,是否存在python环境,可能有些系统,默认就安装过python,如果已经有python了,可以直接跳过安装教程。 2、安装步骤 apt update && apt install -y python3 p…

C++ 在项目中使用Git

目录 一:配置邮箱和姓名 二:生成SSH Key 三:git 工作区和状态 四:git log 常用法 五:git diff 常用法 六:git 分支操作 七:git 回溯分支 八:git rebase -i 压缩历史提交…

Java基础 2. Java基础语法

Java基础 2. Java基础语法 文章目录 Java基础 2. Java基础语法2.1. 标识符2.1.1. 标识符的命名规则 :2.1.2. 标识符的命名规范: 2.2. 关键字2.3. 字面量2.3.1. Java中有哪些字面量2.3.2. 加号运算符 2.4. 变量2.5. 二进制2.6. 八进制与十六进制2.7. 原码反码补码2.7.1. byte与b…

【车载开发系列】ParaSoft单元测试环境配置(一)

【车载开发系列】ParaSoft单元测试环境配置(一) ParaSoft单元测试环境配置 【车载开发系列】ParaSoft单元测试环境配置(一)一. 什么是bdf文件二. bdf文件构成三. 新规做成bdf文件四. 导入bdf文件创建测试工程五. 获取编译器信息六. 新增自定义编译器Step1:打开向导Step2:…

【数学建模】2024数学建模国赛经验分享

文章目录 一、关于我二、我的数模历程三、经验总结: 一、关于我 我的CSDN主页:https://gxdxyl.blog.csdn.net/ 2020年7月(大二结束的暑假)开始在CSDN写作: 阿里云博客专家: 接触的领域挺多的&#xff…

元学习之模型诊断元学习(model-agnosticmeta-learning,MAML)

模型诊断元学习(model-agnosticmeta-learning,MAML), 另一个是Reptile。这两个算法都是在 2017 年提出来的,而且都是基于梯度下降法进行优化 的。那我们最常用的学习算法是梯度下降,在梯度下降中&#xff0…