首页 > 其他分享 >envoy开发调试环境搭建

envoy开发调试环境搭建

时间:2022-10-15 18:57:26浏览次数:78  
标签:http name vscode image envoy address 调试 搭建

image
image

前段时间研究envoy的filter开发,在windows机器环境上面折腾了会,这里记录一下,希望能够帮助到大家少走一些坑

主要是使用vscode devContainer的方式来搭建开发调试环境, 这里稍微解释下,devContainer开发容器是把工程所需的环境打包成容器镜像,在本机运行vscode后会连接到这个开发容器,特别envoy是个cpp项目,环境配置比较复杂,这种方式这样大大提高了开发环境的搭建

但是对于计算机的配置有一些要求:

  • 内存>= 32G
  • 空余磁盘空间>100G的

首先安装DockerDeskTop

请配置启用WSL2 image

会默认在WSL2环境启用下面2个linux子系统 image

这里有个坑 默认好像是安装在系统盘C盘,如果你的C盘剩余可用空间如果低于100G的话, 需要更改 WSL Docker Desktop 存储路径

我是将WSL Docker Desktop 存储路径转存到了我的移动硬盘

image
image
image
image

有102G

具体如何操作这里请参考 https://blog.csdn.net/qq12547345/article/details/125358539

下载envoy源码

https://github.com/envoyproxy/envoy

git clone 这里就得注意,我在windows环境git clone后会遇到文件的换行格式有问题,然后我用wsl的ubuntu机器git clone 就没有这个问题。

也许是我的环境问题,如果你也遇到了提示文件格式有问题,可以试试

我本来是用最新版的尝试,发现不行(请看文章最后我遇到的错误记录),然后我就一个版本一个版本的试验,在1.20.7版本搞成功了, 下面是基于1.20.7版本的envoy。

构建开发容器

打开vscode装好 DevContainer这个插件

image
image

然后打开envoy工程

vscode会检测到envoy工程的devcontainer配置文件 就会给个提示

image
image

这一步是根据devcontainer配置文件进行构建开发容器,需要花点时间,请耐心等待

在开发容器内生成相应的依赖文件

这一步成功完成后,代码着色,代码跳转就没问题

我们在vscode里面新开一个Terminal

image
image

# 这个命令需要在容器内部执行
sudo chown -R vscode /workspaces
image
image

然后运行脚本

tools/vscode/refresh_compdb.sh
image
image

执行成功如下 image

会创建一个complie_commands.json文件 image

检查代码提示和跳转确认都正常

image
image

以上代码查看搞定了

调试环境

搞一个envoy的配置文件 envoy-demo.yaml

static_resources:
  listeners:
  - name: main
    address:
      socket_address:
        address: 0.0.0.0
        port_value: 8888
    filter_chains:
    - filters:
      - name: envoy.filters.network.http_connection_manager
        typed_config:
          "@type": type.googleapis.com/envoy.extensions.filters.network.http_connection_manager.v3.HttpConnectionManager
          stat_prefix: ingress_http
          codec_type: AUTO
          route_config:
            name: local_route
            virtual_hosts:
            - name: local_service
              domains:
              - "*"
              routes:
              - match:
                  prefix: "/"
                route:
                  cluster: web_service
          http_filters:
          - name: envoy.filters.http.lua
            typed_config:
              "@type": type.googleapis.com/envoy.extensions.filters.http.lua.v3.Lua
              inline_code: |
                function envoy_on_request(request_handle)
                  local headers, body = request_handle:httpCall(
                  "soa_service",
                  {
                    [":method"] = "POST",
                    [":path"] = "/",
                    [":authority"] = "192.168.1.5"
                  },
                  "hello world",
                  5000)
                  request_handle:headers():add("foo", 'yuzd')
                end
                function envoy_on_response(response_handle)
                  body_size = response_handle:body():length()
                  response_handle:headers():add("test-body-size", tostring(body_size))
                end
          - name: envoy.filters.http.router
  clusters:
  - name: web_service
    type: STRICT_DNS  # static
    lb_policy: ROUND_ROBIN
    load_assignment:
      cluster_name: web_service
      endpoints:
      - lb_endpoints:
        - endpoint:
            address:
              socket_address:
                address: 127.0.0.1
                port_value: 8000
  - name: soa_service
    type: STRICT_DNS  # static
    lb_policy: ROUND_ROBIN
    load_assignment:
      cluster_name: soa_service
      endpoints:
      - lb_endpoints:
        - endpoint:
            address:
              socket_address:
                address: 192.168.1.5
                port_value: 5000

上面的配置的意思是监听了8080,然后配置转发到 8000,并且配置了一个lua的httpfilter拦截器把流量转到了 宿主机的5000

等会我们就在lua的http拦截器那里打上断点,看看是怎么拦截的


tools/vscode/generate_debug_config.py //source/exe:envoy-static --args "-c envoy-demo.yaml"
image
image

在我电脑上执行需要约1个小时左右,取决于电脑配置

执行成功会生成调试的配置文件如下图:

image
image

在main.cc 和lua_filter.cc里面打上断点

按照我们上面的envoy-demo.yaml配置

我们需要在容器内起一个8000端口的服务


python -m SimpleHTTPServer
image
image

然后再宿主机内起一个5000端口的服务 image

然后再vscode按F5 调试envoy

首先进入main.cc的断点 image

启动成功 vscode右下角会提示:

image
image

点击OpenInBrower打开

请求到8888端口 envoy按照配置会转发到 本地的8000端口(python服务) 且会走lua的httpfilter代码,请求5000端口的服务

命中lua.cc的断点 image

查看5000端口的服务,确认从envoy发出的请求 image

新版本的envoy遇到的问题记录

采用如上方式编译是成功的,代码跳转啥的也都是没问题,就是一F5调试就会出现

image
image

提了issue: https://github.com/envoyproxy/envoy/issues/22788

再issue下面有个兄弟给了一个方法,试了也不行,目前我可成功调试的是envoy 1.20.7版本,具体原因不解,有知道麻烦给教育下~!

 

 

envoy相关知识

关注公众号一起学习

标签:http,name,vscode,image,envoy,address,调试,搭建
From: https://www.cnblogs.com/yudongdong/p/16794770.html

相关文章

  • 用flask搭建管理平台
    flask是什么?flask可以做什么这里就不说了,百度一下即可,这篇文章主要是手把手带你使用flask搭建一个简单的注册、登陆、以及用户权限管理模块。在pycharm上创建新的flask......
  • HM-SCAli2【案例环境搭建】
    1.案例准备以电商项目中的商品、订单、用户为案例进行学习1.1技术选型maven:3.3.9数据库:MySQL5.7持久层:SpingDataJpa其他:SpringCloudAlibaba技术栈1.2......
  • 驱动开发:WinDBG 配置内核双机调试
    WinDBG是在windows平台下,强大的用户态和内核态调试工具,相比较于VisualStudio它是一个轻量级的调试工具,所谓轻量级指的是它的安装文件大小较小,但是其调试功能却比VS更为强......
  • Ubuntu如何搭建Gitlab
    先贴官方文档:https://packages.gitlab.com/gitlab/gitlab-ce/install 前往官方下载地址查看自己https://packages.gitlab.com/gitlab/gitlab-ce //TODO: 1、官......
  • Ubuntu如何搭建Jenkins
    前言:由于我通过aptinstall的方式安装未能成功启动,还没有查清楚原因。所以目前我只提供下载资源包的方式。另提供Jenkins通过aptget安装的官方文档:https://pkg.jenkins.......
  • 基于SSM+Vue的游戏攻略管理系统Java游戏商城系统(源码调试+讲解+文档)
    ......
  • Linux系统编程05-GDB调试
    首先需要加入调试选项-g,在可执行文件中加入源代码信息,打开所有警告-Wallgcc-g-Wallprogram.c-oprogram启动:gdb可执行程序退出:quit设置参数:set......
  • 转载:ElementUI源码系列一 - 从零搭建项目架构,项目准备、项目打包、项目测试流程
    创建入口文件首先,在你的电脑里寻找一个风水宝地,创建一个文件夹,通过 npminit-y,初始化 package.json文件;创建 src文件夹,在它下面创建 src/index.js入口文件,它是我们项......
  • windbg-双机调试
    使用VirtualKD-Redux 配合windbg进行虚拟机双机调试非常方便,在实体机端选择custom按钮,自定义命令使用如下命令:"D:\ProgramFiles(x86)\WindowsKits\10\Debuggers\x64......
  • OJ项目环境搭建
    OJ项目环境搭建数据库建库:problem,user,submit,category/*NavicatPremiumDataTransferSourceServer:localhostSourceServerType:MySQLS......