我有1台服务器,有2个IP地址: eth0 = 1.2.3.4 eth0:0 = 5.6.7.8
的/ etc /主机
127.0.0.1 localhost
1.2.3.4 domain1.com
5.6.7.8 domain2.net
在这个服务器中,我使用以下配置运行Apache(/etc/httpd/conf/httpd.conf):
...
Listen 1.2.3.4:8080
Listen 5.6.7.8:8080
...
<VirtualHost 1.2.3.4:8080>
DocumentRoot /var/www/domain1.com/public_html
...
</VirtualHost>
<VirtualHost 5.6.7.8:8080>
DocumentRoot /var/www/domain2.net/public_html
...
</VirtualHost>
到目前为止一切顺利,我可以让我的网络服务器正常工作。
然后我安装了Varnish Cache,其中包含以下参数:
的/ etc / SYSCONFIG /清漆
NFILES=131072
MEMLOCK=82000
NPROCS="unlimited"
RELOAD_VCL=1
VARNISH_LISTEN_PORT=80
DAEMON_OPTS="-a domain1.com:80 \
-T domain1.com:6082 \
-f /etc/varnish/default.vcl \
-S /etc/varnish/secret \
-s malloc,256m"
DAEMON_OPTS="-a domain2.net:80 \
-T domain2.net:6083 \
-f /etc/varnish/default.vcl \
-S /etc/varnish/secret \
-s malloc,512m"
/etc/varnish/default.vcl
backend domain1 {
.host = "1.2.3.4";
.port = "8080";
}
backend domain2 {
.host = "5.6.7.8";
.port = "8080";
}
sub vcl_recv {
if (req.http.host == "domain1.com") {
set req.http.host = "domain1.com";
set req.backend = domain1;
return (lookup);
}
if (req.http.host == "domain2.net") {
set req.http.host = "domain2.net";
set req.backend = domain2;
return (lookup);
}
}
但我可以访问domain2.net网站,但不能访问domain1.com。
查询在我的服务器上监听的端口时,我会注意到以下内容:
user@host# netstat -an | more
tcp 0 0 5.6.7.8:80 0.0.0.0:* LISTEN
tcp 0 0 5.6.7.8:8080 0.0.0.0:* LISTEN
tcp 0 0 1.2.3.4:8080 0.0.0.0:* LISTEN
tcp 0 0 5.6.7.8:6083 0.0.0.0:* LISTEN
有谁知道为什么Varnish忽略了所有1.2.3.4 / domain1.com配置?以及如何使其发挥作用?
提前致谢。
答案 0 :(得分:4)
在/etc/sysconfig/varnish
中,您只需将变量DAEMON_OPTS写入两次,因此只将第二组参数传递给varnish守护程序。但是既然你只使用了一个vcl脚本,为什么要启动两个varnish守护进程?
两个IP上的一个守护程序都可以使用,因此您只需删除DAEMON_OPTS中的域部分,并且清漆将侦听所有接口:
DAEMON_OPTS="-a :80 \
-T localhost:6082 \
-f /etc/varnish/default.vcl \
-S /etc/varnish/secret \
-s malloc,256m"
-T用于管理界面。大多数情况下,您只希望从localhost访问