热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

gRPCHTTP网关I

文章目录gRPC-HTTP网关IHTTP网关是什么?HTTP网关都有哪些嘞?gRPC-GatewaygRPC-Gateway是什么?gRPC-Gateway有啥优势呢?使用gRPC




文章目录


  • gRPC- HTTP网关 I
    • HTTP网关是什么?
    • HTTP网关都有哪些嘞?
    • gRPC-Gateway
    • gRPC-Gateway是什么?
    • gRPC-Gateway有啥优势呢?
    • 使用gRPC提供HTTP接口有啥注意事项?
    • 总结


gRPC- HTTP网关 I

gRPC是什么?我们再来回顾一下

gRPC是 Google开发的基于HTTP/2标准设计的一个通用的,高性能的RPC框架,有如下3个最明显的特点:


  • 支持主流的编程语言,C++,Java,Python,Go,Ruby等,基于ProtoBuf生成相应的服务端和客户端代码。
  • 基于HTTP/2协议,且提供了更强的应用性能 – 节省带宽,减少TCP请求连接数
  • 基于ProtoBuf定义服务,面向接口对服务进行设计

具体的,这篇文章都有介绍到 – gRPC的介绍


HTTP网关是什么?

分享gRPC 的HTTP网关之前,先来大致说说 HTTP网关是什么

网关是啥?


网关(Gateway)就是一个网络连接到另一个网络的关口

网关他是一个设备,将两个使用不同传输协议的网络段连接在一起,网关一般用作网络的入口和出口点,因为所有数据必须在路由之前通过或与网关通信。

网关所有网络都有一个边界,限制与直接连接到它的设备的通信。如果网络想要与该边界之外的设备,节点或网络通信,则它们需要网关的功能。网关通常被表征为路由器和调制解调器的组合。


HTTP网关那就不难理解,是基于HTTP请求的网络关口


HTTP网关都有哪些嘞?


  • HTTP/* ,服务器端Web网关

例如,客户端在网络上下载资源,客户端通过http协议访问到web网关,web网关识别到请求之后,转成ftp协议,请求ftp服务器,进行文件的上传和下载


  • HTTP/HTTPS ,服务器端安全网关

安全网关,应该就能想到加密

网关对所有的输入Web请求加密,以提供额外的隐私和安全性保护。哪怕客户端可以用普通的HTTP浏览Web内容,但网关会自动加密用户的对话,保证安全性


  • HTTPS/HTTP客户端安全加速器网关

在HTTP请求前加上HTTPS进行拦截,保障流量的安全


将HTTPS/HTTP网关作为安全加速器,这些HTTPS/HTTP网关一般是在放Web服务器之前,通常作为不可见的拦截网关或反向代理使用。它们接收安全的HTTPS处理过的流量,对安全流量进行解密,并向Web服务器发送普通的HTTP请求


也就是说正常情况下,若流量能到web,说明流量是安全的


  • 其他资源网关

例如访问某些应用程序的内部数据,这是通过网络连接客户端和服务器的网关。

即网关就在 应用程序对应的服务器上,与客户端通过HTTP / HTTPS进行通信,并与自身服务器端的应用程序相连


gRPC-Gateway

Golang开发程序的时候,一般gRPC对内,用于微服务之间的内部通信,HTTP接口暴露出来,提供给前端,或者是客户端。

我们的微服务中既要有内部通信的gRPC,又要写对外暴露的HTTP接口,似乎无形中增加了不少工作量,维护两个版本的服务,这种做法是不是很low。那么有没有一种办法可以将2种方式结合,或者说是简化呢?

当然是有的,gRPC为我们提供了一个很方便的gRPC-Gateway插件


gRPC-Gateway是什么?

protoc的一个优秀的插件

gRPC-Gateway提供了基于proto文件中的服务接口定义生成HTTP的反向代理的能力。对于同一个标准的gRPC服务定义,除了基本的gRPC客户端以外还能生成相应的HTTP JSON的接口实现代码

它可以通过google提供的标准接口google/api/annotations.proto,我们能够对原有Protobuf服务,描述成其相应的HTTP接口形式

具体是这样的结构

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Ixl1gZaF-1622641660097)(C:\Users\Administrator\Desktop\image-20210602145356569.png)]


gRPC-Gateway有啥优势呢?

是啊,我们写微服务,对内用gRPC,对外用HTTP, 一个服务里面写2套接口,累是累了点,可是 gRPC-Gateway仅仅就是写gRPC服务同时也可以用于HTTP接口吗?

当然不是

使用 gRPC-Gateway的优势如下


  • 可以保持Restful的简单性

gRPC-Gateway工具,让我们可以很快速的基于proto接口定义,在使用RPC的同时对外提供Restful

使用gRPC的原有Protobuf服务一样可以感受到Restful的简单性,犹如直接写的HTTP接口,简单易用


  • 同时还可以充分提升应用内部的性能以及可靠性

这是RPC框架的本身优势,RPC专为分布式应用的高性能和高生产率设计而设计的


使用gRPC提供HTTP接口有啥注意事项?


  • gRPC提供的HTTP接口是基于HTTP 2.0
  • 别太爽就行

总结


  • 回顾gRPC基本要点
  • HTTP网关的介绍
  • 引出gRPC-gateway,以及其基本结构

好了,本次就到这里,下一次分享gRPC-gateway的实际环境搭建,案例编码,调试技巧,以及效果输出

技术是开放的,我们的心态,更应是开放的。拥抱变化,向阳而生,努力向前行。

我是小魔童哪吒,欢迎点赞关注收藏,下次见~



推荐阅读
  • 本文介绍了RPC框架Thrift的安装环境变量配置与第一个实例,讲解了RPC的概念以及如何解决跨语言、c++客户端、web服务端、远程调用等需求。Thrift开发方便上手快,性能和稳定性也不错,适合初学者学习和使用。 ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • Tomcat/Jetty为何选择扩展线程池而不是使用JDK原生线程池?
    本文探讨了Tomcat和Jetty选择扩展线程池而不是使用JDK原生线程池的原因。通过比较IO密集型任务和CPU密集型任务的特点,解释了为何Tomcat和Jetty需要扩展线程池来提高并发度和任务处理速度。同时,介绍了JDK原生线程池的工作流程。 ... [详细]
  • 本文讨论了在手机移动端如何使用HTML5和JavaScript实现视频上传并压缩视频质量,或者降低手机摄像头拍摄质量的问题。作者指出HTML5和JavaScript无法直接压缩视频,只能通过将视频传送到服务器端由后端进行压缩。对于控制相机拍摄质量,只有使用JAVA编写Android客户端才能实现压缩。此外,作者还解释了在交作业时使用zip格式压缩包导致CSS文件和图片音乐丢失的原因,并提供了解决方法。最后,作者还介绍了一个用于处理图片的类,可以实现图片剪裁处理和生成缩略图的功能。 ... [详细]
  • 背景应用安全领域,各类攻击长久以来都危害着互联网上的应用,在web应用安全风险中,各类注入、跨站等攻击仍然占据着较前的位置。WAF(Web应用防火墙)正是为防御和阻断这类攻击而存在 ... [详细]
  • 恶意软件分析的最佳编程语言及其应用
    本文介绍了学习恶意软件分析和逆向工程领域时最适合的编程语言,并重点讨论了Python的优点。Python是一种解释型、多用途的语言,具有可读性高、可快速开发、易于学习的特点。作者分享了在本地恶意软件分析中使用Python的经验,包括快速复制恶意软件组件以更好地理解其工作。此外,作者还提到了Python的跨平台优势,使得在不同操作系统上运行代码变得更加方便。 ... [详细]
  • Hadoop2.6.0 + 云centos +伪分布式只谈部署
    3.0.3玩不好,现将2.6.0tar.gz上传到usr,chmod-Rhadoop:hadophadoop-2.6.0,rm掉3.0.32.在etcp ... [详细]
  • TiDB | TiDB在5A级物流企业核心系统的应用与实践
    TiDB在5A级物流企业核心系统的应用与实践前言一、业务背景科捷物流概况神州金库简介二、现状与挑战神州金库现有技术体系业务挑战应对方案三、TiDB解决方案测试迁移收益问题四、说在最 ... [详细]
  • 一面自我介绍对象相等的判断,equals方法实现。可以简单描述挫折,并说明自己如何克服,最终有哪些收获。职业规划表明自己决心,首先自己不准备继续求学了,必须招工作了。希望去哪 ... [详细]
  • 项目需要将音视频文件上传服务器,考虑并发要求高,通过七牛来实现。直接上代码usingQiniu.IO;usingQiniu.IO.Resumable;usingQiniu.RPC; ... [详细]
  • SOA架构理解理解SOA架构,了解ESB概念,明白SOA与微服务的区别和联系,了解SOA与热门技术的结合与应用。1、面向服务的架构SOASOA(ServiceOrien ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • t-io 2.0.0发布-法网天眼第一版的回顾和更新说明
    本文回顾了t-io 1.x版本的工程结构和性能数据,并介绍了t-io在码云上的成绩和用户反馈。同时,还提到了@openSeLi同学发布的t-io 30W长连接并发压力测试报告。最后,详细介绍了t-io 2.0.0版本的更新内容,包括更简洁的使用方式和内置的httpsession功能。 ... [详细]
  • 本文介绍了Java高并发程序设计中线程安全的概念与synchronized关键字的使用。通过一个计数器的例子,演示了多线程同时对变量进行累加操作时可能出现的问题。最终值会小于预期的原因是因为两个线程同时对变量进行写入时,其中一个线程的结果会覆盖另一个线程的结果。为了解决这个问题,可以使用synchronized关键字来保证线程安全。 ... [详细]
  • 这篇文章给大家讲解如何利用dhtmlxGantt在服务器端集成数据。脚本数据保存如果您已初始化dataProcessor,则用户或以编程方式所做的任何更改都将自动 ... [详细]
author-avatar
郭辛奇木书可卿
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有