go语言实现一个简单的简单网关

Python019

go语言实现一个简单的简单网关,第1张

网关=反向代理+负载均衡+各种策略,技术实现也有多种多样,有基于 nginx 使用 lua 的实现,比如 openresty、kong;也有基于 zuul 的通用网关;还有就是 golang 的网关,比如 tyk。

这篇文章主要是讲如何基于 golang 实现一个简单的网关。

转自: troy.wang/docs/golang/posts/golang-gateway/

整理:go语言钟文文档:www.topgoer.cn

启动两个后端 web 服务(代码

这里使用命令行工具进行测试

具体代码

直接使用基础库 httputil 提供的NewSingleHostReverseProxy即可,返回的reverseProxy对象实现了serveHttp方法,因此可以直接作为 handler。

具体代码

director中定义回调函数,入参为*http.Request,决定如何构造向后端的请求,比如 host 是否向后传递,是否进行 url 重写,对于 header 的处理,后端 target 的选择等,都可以在这里完成。

director在这里具体做了:

modifyResponse中定义回调函数,入参为*http.Response,用于修改响应的信息,比如响应的 Body,响应的 Header 等信息。

最终依旧是返回一个ReverseProxy,然后将这个对象作为 handler 传入即可。

参考 2.2 中的NewSingleHostReverseProxy,只需要实现一个类似的、支持多 targets 的方法即可,具体实现见后面。

作为一个网关服务,在上面 2.3 的基础上,需要支持必要的负载均衡策略,比如:

随便 random 一个整数作为索引,然后取对应的地址即可,实现比较简单。

具体代码

使用curIndex进行累加计数,一旦超过 rss 数组的长度,则重置。

具体代码

轮询带权重,如果使用计数递减的方式,如果权重是5,1,1那么后端 rs 依次为a,a,a,a,a,b,c,a,a,a,a…,其中 a 后端会瞬间压力过大;参考 nginx 内部的加权轮询,或者应该称之为平滑加权轮询,思路是:

后端真实节点包含三个权重:

操作步骤:

具体代码

一致性 hash 算法,主要是用于分布式 cache 热点/命中问题;这里用于基于某 key 的 hash 值,路由到固定后端,但是只能是基本满足流量绑定,一旦后端目标节点故障,会自动平移到环上最近的那么个节点。

实现:

具体代码

每一种不同的负载均衡算法,只需要实现添加以及获取的接口即可。

然后使用工厂方法,根据传入的参数,决定使用哪种负载均衡策略。

具体代码

作为网关,中间件必不可少,这类包括请求响应的模式,一般称作洋葱模式,每一层都是中间件,一层层进去,然后一层层出来。

中间件的实现一般有两种,一种是使用数组,然后配合 index 计数;一种是链式调用。

具体代码

负载 loadx是一个Lua模块,可提供更好的load()。 用法 该模块提供以下功能: loadx(chunk, [, chunkname [, mode [, upvalues...]]]) 加载一个块。 此功能类似于Lua的本机load ,并且具有以下差异: 如果结果函数具有upvalues,则将upvalues设置为upvalues的值(如果指定了该参数)。 如果没有给出第一个升值,则将其设置为全局环境。 (当加载一个主块时,结果函数将始终只具有一个升值_ENV变量。但是,当您加载从一个函数创建的二进制块(例如string.dump )时,结果函数可以具有任意数量的升值)。 有关chunk , chunk chunkname和mode的定义,请参见本机load 。 来自本地load所有警告可能适用。 也可以看看: load : , 。 string.dump :

你可能感兴趣的资源

LUA模块源码

lua模块源码。提供脚本初级命令,有需要的可自行添加

Lua 模块与包

模块类似于一个封装库,从 Lua 5.1 开始,Lua 加入了标准的模块管理机制,可以把一些公用的代码放在一个文件里,以 API 接口的形式在其他地方调用,有利于代码的重用和降低代码耦合度。 Lua 的模块是由变量、函数等...

Lualoadstring函数用法实例

主要介绍了Lua loadstring函数用法实例,loadstring最典型的用处是去执行外部代码,也就是位于程序之外的代码,需要的朋友可以参考下 Lua中的loadfile、dofile、loadstring、require用法实例 主要介绍了Lua中的loadfile、dofile、loadstring、requir...

lua模块调用测试

lua 模块调用,vs2012版本,实现了简单的调用功能

lua实例:任务模块

lua任务模块代码,提供给大家学习lua语法,及继承思想

Lua和C/C++互相调用实例分析

下面对lua和c/c++的交互调用做一个实例分析: lua提供了API用于在c/c++中构造lua的运行环境,相关接口如下: //创建lua运行上下文 lua_State* luaL_newstate(void) //加载lua脚本文件 int luaL_loadfile(lua_State *L, const ...

Lua脚本-C工具类资源-CSDN文库

lua-5.2.1.tar.gz(71个子文件) lua-5.2.1 Makefile3KB src lzio.c2KB lgc.c36KB lua.c14KB loadlib.c21KB lstring.h1KB ldump.c3KB lfunc.c4KB ldo.h1KB Makefile6KB linit.c2KB ...

nginx,lua模块安装

nginx的lua模块安装

易语言lua的例子

易语言lua的例子,静态易语言调用LUA51.DLL和模块

lua-其它代码类资源-CSDN文库

lua,Lua:Go中用于Lua的VM和编译器。edundxluaforkgopher-luaporject,这是一个用Go编写的Lua5.1VM和编译器。GopherLua与Lua的目标相同:成为一种具有可扩展语义的脚本语言。它提供了GoAPI,使您可以轻松地将脚本语言嵌入到Go宿主程序中。...

lua-5.3.4安装包-其它代码类资源-CSDN文库

lua.hpp191B loadlib.c23KB lcorolib.c4KB Makefile7KB lualib.h1KB lfunc.c4KB ltable.c19KB lzio.h1KB lstring.h1KB ldebug.h1KB lstring.c6KB llex.h2KB lstrlib.c46KB

易语言Lua支持库

易语言Lua支持库源码,Lua支持库,GetNewInf,lua_ProcessNotifyLib,建立全局信息,内部_附加功能主函数,函数改C调用约定,加载内存库,取内存DLL函数地址,调用内存函数,到子程序指针,取子程序地址,取指针地址,取文本指针,...

一个用lua写的游戏脚本实例

一个用lua写的游戏脚本实例,是word格式的,值得一看,通过这个例子你可以了解到游戏中的脚本是怎么写的

一个比较好的LUA断点测试工具

一个比较好的LUA断点测试工具一个比较好的LUA断点测试工具一个比较好的LUA断点测试工具一个比较好的LUA断点测试工具

易语言LUA支持库1.0#0版(第三方)

这是一组全局函数,当您在您的应用程序中实现一个能被LUA调用的函数时候,需要用到这些函数。主要是数据交换相关。包含 LUA取参数数目、LUA取参数类型、LUA取参数值、LUA加返回值、LUA扩展栈。后续版本可能会根据...

Lua中的loadfile、dofile、loadstring、require用法实例

主要介绍了Lua中的loadfile、dofile、loadstring、require用法实例,需要的朋友可以参考下

emoji.lua:Lua的基本表情符号支持模块

表情符号 :speech_balloon:Lua的基本表情符号支持模块 :crescent_moon:例子 local emoji = require ( " emoji " )print (emoji. emojify ( " I :heart: :tea:! " ))-- >"I :red_heart: :teacup_without_handle:!...

LuaForWindows_v5.1.5-52 安装包

Lua 是一个小巧的脚本语言。作者是巴西人。该语言的设计目的是为了嵌入应用程序中,从而为应用程序提供灵活的扩展和定制功能。 Lua脚本可以很容易的被C/C++代码调用,也可以反过来调用C/C++的函数,这使得Lua在应用...

single-dir.lua:将 Lua 模块的所有依赖收集到一起

要使用目录“single-dir-out/modules”中的模块运行 Lua 应用程序, LUA_CPATH按如下方式设置LUA_PATH和LUA_CPATH : $ export LUA_PATH= " modules/?.luamodules/?/init.lua " $ export LUA_CPATH= " modules/?....

DMC-Lua-Library:一组很棒的 Lua 模块

DMC Lua 库这个库 repo 只是我其他 repos 中 Lua 模块的集合,所以它只是一个方便的地方来获取和更新所有这些。 我积极使用所有模块在服务器(使用 )和移动设备(使用 Corona SDK)上构建应用程序。 文档在每个相应...

lua iconv For windows

本来以为很简单 结果找了半天发现都是很坑爹的办法 linux下可以直接安装luaiconv windows下呢 只好自己编了 本来想找个别人写好的 发现根本找不到 更坑爹的是 我用eclipse的LDT开发 结果发现它的lua vm没办法加载c库...

lua-amalg:Lua模块的合并

lua-amalg:Lua模块的合并

xlsxwriter.lua, 用于创建 Excel XLSX文件的lua模块.zip

xlsxwriter.lua, 用于创建 Excel XLSX文件的lua模块 用于Lua的 Xlsxwriter用于创建 Excel XLSX... xlsxwriter模块Xlsxwriter是一个Lua模块,可以用于将文本。数字。公式和超链接写入 Excel 2007 + XLSX文件中的多个工

lua-newmodule:使 Lua 模块和 init.lua 变得简单

提出了一种更好、更简单的定义模块的方法(没有 module() 函数!)。 请参阅: : 。 在 Lua 5.2 中删除了 module() 函数。 见 更多关于 Lua 模块? 您应该阅读以下文章: 基基托写道: I wrote about ...

lua 5.3.5 windows预编译exe/dll文件 lua5.3.5.win.zip

lua5.3(32位/64位)windows 预编译(exe/DLL) adding: lua5.3.5-x86/lua.exe (in=14336) (out=7311) (deflated 49%) adding: lua5.3.5-x86/lua.o (in=24873) (out=9654) (deflated 61%) adding: lua5.3.5-x86/lua...

ISO14229-1中文

国际统一诊断标准ISO14229-1中文

Vulkan编程指南.pdf

Vulkan编程指南高清版,内容可复制,非常实用.

反编译工具 dll to c

能够把DLL转换成可编译的C或C++代码。亲测可用,无病毒。

USB type C 16Pin

在画PCB板的时候,如果没有元器件的3d封装会很难受,typec接口在绘制PCB经常会用到,但是网上关于typec的3D封装很少,就算有,绝大部分都是24pin的引脚的,16p的引脚特别难找到,博主我也是花了好长时间才找到的。如果各位急需typec16pin的封装,但是又没有积分下载的话,可以去淘宝上搜索 “CSDN下载” 只需要 1毛钱 就可以下载。

基于stm32水质监测系统(毕设)

基于stm32水质监测系统(毕设)

评论