Proxy-Wasm 项目使用教程

Proxy-Wasm 项目使用教程

specWebAssembly for Proxies (ABI specification)项目地址:https://gitcode.com/gh_mirrors/spec8/spec

1. 项目的目录结构及介绍

Proxy-Wasm 项目的目录结构如下:

spec/
├── abi-versions
├── c-api
├── context.md
├── design
├── examples
├── extensions
├── include
├── sdk
├── specification.md
├── status.md
└── tests

目录介绍

  • abi-versions: 包含不同版本的 ABI(Application Binary Interface)规范。
  • c-api: 包含 C 语言 API 的相关文件。
  • context.md: 描述上下文相关的文档。
  • design: 包含项目的设计文档。
  • examples: 包含示例代码。
  • extensions: 包含扩展相关的文件。
  • include: 包含头文件。
  • sdk: 包含 SDK 相关的文件。
  • specification.md: 项目的详细规范文档。
  • status.md: 项目的状态文档。
  • tests: 包含测试文件。

2. 项目的启动文件介绍

Proxy-Wasm 项目的启动文件通常位于 examples 目录下。以下是一个典型的启动文件示例:

#include "proxy_wasm_intrinsics.h"

class ExampleRootContext : public RootContext {
public:
  explicit ExampleRootContext(uint32_t id, StringView root_id) : RootContext(id, root_id) {}

  bool onStart(size_t) override {
    LOG_INFO("Starting example plugin");
    return true;
  }
};

class ExampleContext : public Context {
public:
  explicit ExampleContext(uint32_t id, RootContext* root) : Context(id, root) {}

  FilterHeadersStatus onRequestHeaders(uint32_t, bool) override {
    LOG_INFO(std::string("onRequestHeaders ") + std::to_string(id()));
    return FilterHeadersStatus::Continue;
  }
};

static RegisterContextFactory register_ExampleContext(CONTEXT_FACTORY(ExampleContext),
                                                      ROOT_FACTORY(ExampleRootContext));

启动文件介绍

  • ExampleRootContext: 定义根上下文类,处理插件的启动逻辑。
  • ExampleContext: 定义请求上下文类,处理请求头部的逻辑。
  • RegisterContextFactory: 注册上下文工厂,用于创建上下文实例。

3. 项目的配置文件介绍

Proxy-Wasm 项目的配置文件通常是一个 JSON 文件,用于配置插件的行为。以下是一个典型的配置文件示例:

{
  "config": {
    "vm_config": {
      "engine": "wasmtime",
      "code": {
        "local": {
          "filename": "example.wasm"
        }
      }
    },
    "root_id": "example",
    "listeners": [
      {
        "address": "0.0.0.0:8080",
        "filters": [
          {
            "name": "example",
            "config": {
              "key": "value"
            }
          }
        ]
      }
    ]
  }
}

配置文件介绍

  • vm_config: 配置 Wasm 虚拟机,包括引擎类型和代码路径。
  • root_id: 根上下文的唯一标识符。
  • listeners: 配置监听器,包括地址和过滤器。
  • filters: 配置过滤器,包括名称和配置项。

以上是 Proxy-Wasm 项目的基本使用教程,涵盖了项目的目录结构、启动文件和配置文件的介绍。希望对您有所帮助。

specWebAssembly for Proxies (ABI specification)项目地址:https://gitcode.com/gh_mirrors/spec8/spec

创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

余印榕

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值