代码拉取完成,页面将自动刷新
#!/usr/bin/perl
# (C) Sergey Kandaurov
# (C) Nginx, Inc.
# Tests for http proxy_bind transparent with Linux CAP_NET_RAW capability.
# Ensure that such configuration isn't broken under a non-priveleged user.
###############################################################################
use warnings;
use strict;
use Test::More;
BEGIN { use FindBin; chdir($FindBin::Bin); }
use lib 'lib';
use Test::Nginx;
###############################################################################
select STDERR; $| = 1;
select STDOUT; $| = 1;
plan(skip_all => 'no linux capability') if $^O ne 'linux';
plan(skip_all => 'must be root') if $> != 0;
plan(skip_all => '127.0.0.2 local address required')
unless defined IO::Socket::INET->new( LocalAddr => '127.0.0.2' );
my $t = Test::Nginx->new()->has(qw/http proxy/)
->write_file_expand('nginx.conf', <<'EOF');
%%TEST_GLOBALS%%
daemon off;
events {
}
http {
%%TEST_GLOBALS_HTTP%%
server {
listen 127.0.0.1:8080;
server_name localhost;
location / {
proxy_bind 127.0.0.2 transparent;
proxy_pass http://127.0.0.1:8081/;
}
}
server {
listen 127.0.0.1:8081;
server_name localhost;
location / {
add_header X-IP $remote_addr always;
}
}
}
EOF
$t->run()->plan(1);
###############################################################################
like(http_get('/'), qr/X-IP: 127.0.0.2/, 'transparent');
###############################################################################
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。