最近电脑更新,换了 M1 的,所有工作从新开始,意味着 APISIX 插件开发之路中的绊脚石——单测环境筹备,也要从新筹备。
因为降级了芯片和最新的 macOS 零碎(12.2.1),导致过程并没有设想中的顺利,之前没遇到过的坑,一个个的裸露进去了,这里做一个分享和 BackUp。
还有想吐槽一下 APISIX 官网的文档,在对于单元测试和插件编写方面的内容,输入不是特地的多,而且散落各处,着实给开发人员带来了麻烦。
以下的操作都是基于 APISIX 源码下操作(https://github.com/apache/apisix),写该文时版本为 V2.12.1。
失常装置流程
- 装置各种环境依赖
# install OpenResty, etcd and some compilation tools
brew install openresty/brew/openresty luarocks lua@5.1 etcd curl git pcre openldap cpanminus
# start etcd server
brew services start etcd
官网最新源码中提供了脚本,位于utils/install-dependencies.sh
。间接执行这个脚本就能够对上方的依赖进行装置和启动。
官网文档
- 批改环境变量
结合实际装置状况批改 .bash_profile
文件,并别忘了 source ~/.bash_profile
。
OPENRESTY_HOME=/usr/local/openresty
PATH=$OPENRESTY_HOME/nginx/sbin:$OPENRESTY_HOME/bin:$PATH
export OPENRESTY_HOME
- 下载 APISIX 源码
git clone https://github.com/apache/apisix.git
- 源码环境下解决
# 源码根目录下
git clone https://github.com/iresty/test-nginx.git
rm -rf test-nginx/.git
sudo cpanm --notest Test::Nginx IPC::Run > build.log 2>&1 || (cat build.log && exit 1)
export PERL5LIB=.:$PERL5LIB
make deps
我看官网举荐应用 make deps ENV_LUAROCKS_SERVER=https://luarocks.cn
,但我试了,并没有起效,仍旧应用 https://luarocks.org,起初我通过批改 luarocks 配置文件 ~/.luarocks/config-5.1.lua
, 失效了,大家也能够本人试试,在文章下方做个反馈。
APISIX 文档
rocks_servers = {"https://luarocks.cn"}
因为 github 的网络起因,make deps
过程可能不是一帆风顺,有点急躁多试几次就能够了。
- 下载 toolkit 文件
在 t/
目录下,执行
git clone https://github.com/api7/test-toolkit toolkit
rm -rf toolkit/.git
这里须要重命名为 toolkit,否则援用找不到。
这里如果不下载这个源码会导致,toolkit.json
找不到的问题呈现。
https://github.com/apache/api…
- 启动 APISIX 服务(非必须,能够依据理论状况)
自己是通过 Docker 形式启动
git clone https://github.com/apache/apisix-docker.git
cd apisix-docker/compose/
docker-compose -f docker-compose.yaml -p docker-apisix up -d
这里须要📢留神,在下面咱们曾经启动了 etcd,这里也会启动 etcd,所以只有抉择其中一个就能够了。
- 测试一下
在源码根目录下,执行
prove -Itest-nginx/lib -r t/plugin/limit-conn.t
失常状况下这样子就能够启动了。
但事实没有这么顺利,而且下面的流程曾经是我采坑的后果了。
问题与解决方案
最新版本下无奈应用 brew 装置 openresty
% brew install openresty/brew/openresty
Running `brew update --preinstall`...
==> Auto-updated Homebrew!
Updated 1 tap (homebrew/core).
==> Updated Formulae
Updated 10 formulae.
==> Tapping openresty/brew
Cloning into '/opt/homebrew/Library/Taps/openresty/homebrew-brew'...
remote: Enumerating objects: 2866, done.
remote: Counting objects: 100% (34/34), done.
remote: Compressing objects: 100% (28/28), done.
remote: Total 2866 (delta 22), reused 10 (delta 6), pack-reused 2832
Receiving objects: 100% (2866/2866), 627.61 KiB | 638.00 KiB/s, done.
Resolving deltas: 100% (1610/1610), done.
Error: Invalid formula: /opt/homebrew/Library/Taps/openresty/homebrew-brew/Formula/php-session-nginx-module.rb
php-session-nginx-module: Calling bottle :unneeded is disabled! There is no replacement.
Please report this issue to the openresty/brew tap (not Homebrew/brew or Homebrew/core):
/opt/homebrew/Library/Taps/openresty/homebrew-brew/Formula/php-session-nginx-module.rb:8
官网的解决方案是将 brew 版本。https://github.com/openresty/…
而我抉择手动装置 openresty
tar -xzvf openresty-VERSION.tar.gz
// openresty-VERSION/ 目录
./configure --prefix=/usr/local/openresty --with-http_addition_module --with-http_flv_module --with-http_gzip_static_module --with-http_realip_module --with-http_ssl_module --with-http_stub_status_module --with-http_sub_module --with-http_dav_module --with-http_v2_module --with-pcre=/Users/demo/installapps/pcre-8.45 --with-openssl=/Users/demo/installapps/openssl
make
make install
装置 openresty 须要依赖 pcre 和 openssl,所以这个咱们也得手动装置
- openssl:https://blog.csdn.net/qyee16/…
- pcre:https://www.cnblogs.com/Jorda…
这里须要留神的是 pcre 要应用 1,不要应用 2,否则会有如下问题
src/core/ngx_regex.h:15:10: fatal error: 'pcre.h' file not found
#include <pcre.h>
^~~~~~~~
1 error generated.
make[1]: *** [objs/src/core/nginx.o] Error 1
make: *** [install] Error 2
参考文献
不要遗记批改环境变量哦。
make deps 时找不到门路问题
能够通过应用 ln -s
软链解决。
nginx 报错
跑单测的时候,报如下谬误
nginx: [emerg] "listen" directive is not allowed here in /Users/gjason/project/apisix-all/apisix/t/servroot/conf/nginx.conf:188
可能是数据格式谬误导致 nginx.conf 配置谬误。
也可能是 Nginx 没有装置好,比方短少下面提到的 pcre 和 openssl 导致的。