CentOS 6 でApache Traffic Server (ATS)を使用して、基本的なプロキシ認証を使用してフォワード プロキシ サーバーをセットアップしようとしています。基本的なプロキシ認証を使用して、 SQUIDとApache httpd mod_proxyフォワード プロキシの両方を正常にデプロイしました。パフォーマンスを比較するためにATSと同じ。
ATS が提供するbasic-authプラグインの例を使用しようとしていますが、複数の問題があります。
CentOS 6 用の最新の epel リポジトリを追加し、trafficserver と trafficserver-devel (ATS コンパイラtsxsを使用するために必要) パッケージの両方をインストールします。basic-auth.c ファイルをソースからユーザー ディレクトリにコピーし、コンパイルを試みます。
# tsxs -v -o /root/basic-auth.so -c /root/basic-auth.c
ファイルが見つからないというエラーが表示されるとすぐに-ts/ink_defs.h
このファイルは、ソース コードでautoconfig -if
とconfigure
を実行することによって生成されます。そのため、先に進み、trafficserver git リポジトリのクローンを作成し、手順を実行して/opt/ts/
. これらをtsxs が参照するディレクトリにコピーしました (ここにあるのは、trafficserver - develを/usr/include/ts/
使用してインストールしたときのデフォルトの場所であるためです(以前にソースからのみトラフィック サーバーをインストールしたときは、tsxsは実行されませんでした)。
ファイルが配置されたので、basic-auth.cc でコンパイラを再度実行しました。今回ts.h
は、sdk_version パラメータが原因で、 でエラーが発生しました。
# tsxs -v -o basic-auth.so basic-auth.c
compiling basic-auth.c -> basic-auth.lo
cc -I/usr/include -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -m64 -mtune=generic -feliminate-unused-debug-symbols -fno-strict-aliasing -mcx16 -fpic -c basic-auth.c -o basic-auth.lo
In file included from basic-auth.c:30:
/usr/include/ts/ts.h:158: error: expected ‘)’ before ‘sdk_version’
In file included from /usr/include/ts/ink_defs.h:28,
from basic-auth.c:31:
/usr/include/ts/ink_config.h:41:26: error: ink_autoconf.h: No such file or directory
basic-auth.c: In function ‘TSPluginInit’:
basic-auth.c:222: warning: implicit declaration of function ‘TSPluginRegister’
tsxs: compilation failed: cc -I/usr/include -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -m64 -mtune=generic -feliminate-unused-debug-symbols -fno-strict-aliasing -mcx16 -fpic -c basic-auth.c -o basic-auth.lo
のコードを調査し、最新のソースts.h
と比較しました。156 行目が次のように変更されていることがわかります。
トラフィックサーバー開発:
tsapi TSReturnCode TSPluginRegister(TSSDKVersion sdk_version, TSPluginRegistrationInfo plugin_info);
ソース:
tsapi TSReturnCode TSPluginRegister(TSPluginRegistrationInfo *plugin_info);
したがって、バージョン管理に問題があると想定しています。自分のバージョンの ts.h を最新のソースに置き換えて、もう一度コンパイルを試みました。うまくいきました!
.so ファイルを plugins ディレクトリにコピーし、それに応じて plugins.config と records.config を変更します。残念ながら、trafficserver を起動しようとすると、セグメンテーション エラーで失敗します。
# /usr/bin/traffic_server
traffic_server: using root directory '/usr'
[Jul 15 16:19:21.224] Server {0x7fd9458ba7e0} DEBUG: (dns) ink_dns_init: called with init_called = 0
[Jul 15 16:19:21.227] Server {0x7fd9458ba7e0} DEBUG: (dns) localhost=vmProxy1
[Jul 15 16:19:21.227] Server {0x7fd9458ba7e0} DEBUG: (dns) Round-robin nameservers = 1
traffic_server: Segmentation fault (Signal sent by the kernel [(nil)])traffic_server - STACK TRACE:
/usr/bin/traffic_server(_Z19crash_logger_invokeiP7siginfoPv+0x99)[0x4a5209]
/lib64/libpthread.so.0[0x35b600f710]
/lib64/libc.so.6[0x35b5d3362f]
/usr/lib64/trafficserver/libtsutil.so.5(_xstrdup+0x6d)[0x7fd945f2b6cd]
/usr/bin/traffic_server(TSPluginRegister+0x7c)[0x4bcb6c]
/usr/lib64/trafficserver/plugins/basic-auth.so(TSPluginInit+0x2f)[0x7fd942334e1f]
/usr/bin/traffic_server(_Z11plugin_initb+0x322)[0x4dab22]
/usr/bin/traffic_server(main+0x1424)[0x4d2754]
/lib64/libc.so.6(__libc_start_main+0xfd)[0x35b5c1ed5d]
/usr/bin/traffic_server[0x4942a9]
Segmentation fault (core dumped)
より良いデバッグ ログを取得するために gdb を使用しようとしましたが、何も役に立ちません。別の言及がありますsdk_version
-しかし、ファイルを飛び回ってそれらを置き換えることは、本来の動作ではないと思い始めています...
Starting program: /usr/bin/traffic_server
[Thread debugging using libthread_db enabled]
traffic_server: using root directory '/usr'
[New Thread 0x7ffff7704700 (LWP 19967)]
[Jul 15 16:18:28.841] Server {0x7ffff77777e0} DEBUG: (dns) ink_dns_init: called with init_called = 0
[New Thread 0x7ffff68ff700 (LWP 19968)]
[New Thread 0x7ffff67fe700 (LWP 19969)]
[Jul 15 16:18:28.844] Server {0x7ffff77777e0} DEBUG: (dns) localhost=vmProxy1
[Jul 15 16:18:28.844] Server {0x7ffff77777e0} DEBUG: (dns) Round-robin nameservers = 1
[New Thread 0x7ffff46f5700 (LWP 19970)]
[New Thread 0x7ffff44f3700 (LWP 19971)]
Program received signal SIGSEGV, Segmentation fault.
__strlen_sse42 () at ../sysdeps/x86_64/multiarch/strlen-sse4.S:32
32 pcmpeqb (%rdi), %xmm1
Missing separate debuginfos, use: debuginfo-install tcl-8.5.7-6.el6.x86_64
(gdb) bt
#0 __strlen_sse42 () at ../sysdeps/x86_64/multiarch/strlen-sse4.S:32
#1 0x00007ffff7de86cd in _xstrdup (str=0xd46e3934ae7d6389 <Address 0xd46e3934ae7d6389 out of bounds>, length=-1)
at ink_memory.cc:231
#2 0x00000000004bcb6c in TSPluginRegister (sdk_version=<value optimized out>, plugin_info=0x7fffffffcc50)
at InkAPI.cc:1803
#3 0x00007ffff41f1e1f in TSPluginInit (argc=<value optimized out>, argv=<value optimized out>) at /root/basic-auth.c:222
#4 0x00000000004dab22 in plugin_load (validateOnly=false) at Plugin.cc:114
#5 plugin_init (validateOnly=false) at Plugin.cc:265
#6 0x00000000004d2754 in main (argv=<value optimized out>) at Main.cc:1714
私が間違っているかもしれないことについてのヒントやヒントは大歓迎です。