使用SSL在CentOS 7,Nginx和PHP-FPM上设置清漆

问题描述 投票:1回答:1

我之前没有使用过Varnish,但是我需要在我们的Magento网站上安装它以帮助加快速度。

我发现了很多关于如何在Centos 7,PHP-FPM等上设置Varnish的文章,但没有关于CentOS7,Nginx,PHP-FPM和SSL运行的文章。根据我的理解,Varnish并不熟悉SSL,所以你需要做一些Nginx jiggery-pokery才能让事情顺利进行。这也是一个多店Magento网站,因此增加了另一层复杂功能。

有没有人有任何信息可以帮助解决这个问题?

magento nginx centos7 varnish
1个回答
1
投票

我将向您展示我自己的Nginx配置文件,以使其工作。这是Debian 9而不是Centos 7,但是Nginx应该以相同的方式工作。

如果有人有更好的配置或建议,我会认真听...我是Magento开发人员,而不是系统管理员。我有很多关于Nginx和Varnish的知识。

在这里,Varnish正在侦听端口6081。

  1. 我创建了一个Varnish Proxy来将HTTPS请求重定向到HTTP varnish。在/etc/nginx/sites-available/proxy.website.com
## HTTPS termination & Varnish proxy
server {

  server_name en.website.com fr.website.com es.website.com de.website.com;

  listen 443 ssl http2;


  access_log /var/www/log/varnish-proxy.log;
  error_log /var/www/log/varnish-proxy.error.log;

  include /etc/nginx/conf/ssl.conf;

  keepalive_timeout 300s;

  location / {
    #BYPASS VARNISH
    #proxy_pass http://127.0.0.1:611;
    #VARNISH ENABLED
    proxy_pass http://127.0.0.1:6081;

    proxy_set_header Host $http_host;
    proxy_set_header X-Forwarded-Host $http_host;
    proxy_set_header X-Real-IP  $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_set_header X-Forwarded-Proto $scheme;
    proxy_set_header X-Forwarded-Port 443;
    proxy_set_header X-Secure on;
    proxy_set_header X-Magento-Debug 1;
  }
}

  1. 然后,我在/etc/nginx/sites-available/website.com的vhost:
upstream fastcgi_backend { # USE YOUR OWN CONFIG HERE
   # use tcp connection
   # server  127.0.0.1:9000;
   # or socket
   server   unix:/var/run/php7.1-fpm.sock; 
}
map $http_host $MAGE_RUN_CODE_GLOBAL { # USE YOUR OWN CONFIG HERE
    en.website.com en;
    fr.website.com fr;
    es.website.com es;
    de.website.com de;
}

# Redirect to https
server {
  server_name en.website.com fr.website.com es.website.com de.website.com;
  listen 80;

  location ~ /.well-known {
    allow all;
  }

  return 301 https://$http_host$request_uri;
}

# Redirect to https
server {
  server_name _;
  listen 611;

  set $MAGE_ROOT /var/www/magento;
  set $MAGE_MODE developer;
  set $MAGE_RUN_TYPE store;
  set $MAGE_RUN_CODE $MAGE_RUN_CODE_GLOBAL;

  set $HTTPS_FORWARD on;
  set $FPM_USER www-data;

  access_log /var/www/log/website.com.access.log;
  error_log /var/www/log/website.com.error.log error;

  include /var/www/magento/nginx.conf.sample;
}
  1. 启用您的虚拟主机
sudo ln -s /etc/nginx/sites-available/proxy.website.com /etc/nginx/sites-enabled/
sudo ln -s /etc/nginx/sites-available/website.com /etc/nginx/sites-enabled/
  1. 重启nginx。 -t将测试您的配置文件,-s reload将重新加载Nginx配置而不会中断服务:
nginx -t && nginx -s reload

编辑:

  1. 编辑Varnish启动配置: CentOS 6:/etc/sysconfig/varnish CentOS 7:/etc/varnish/varnish.params Debian / Ubuntu:/etc/default/varnish
...
## Alternative 2, Configuration with VCL
DAEMON_OPTS="-a :6081 \
             -T localhost:6082 \
             -f /etc/varnish/default.vcl \
             -S /etc/varnish/secret \
             -s malloc,1024m \
             -p workspace_backend=256 \
             -p http_resp_hdr_len=42000"
...
  1. 在Magento管理员: 将Stores > Configuration > Advanced > System > Full Page Cache > Caching Application设置为Varnish Cache 现在陈述新的“Varnish配置”提起 将Access listBackend host设置为localhost。我不知道其他选择是什么。 保存配置更改 Clic Export VCL根据您的Varnish版本
  2. 上传Magento VCL 将默认清漆VCL /etc/varnish/default.vcl备份到/etc/varnish/default.vcl.bkp 将magento VCL放入新的/etc/varnish/default.vcl文件中。 编辑第一行:
vcl 4.0; import std;

backend default {
    .host = "127.0.0.1";
    .port = "404";
}

backend mywebsite {
    .host = "127.0.0.1";
    .port = "611";
}

acl purge {
    "localhost";
}

sub vcl_recv {

    if (req.http.host ~ "website.com") {
        set req.backend_hint = mywebsite;
    } else {
        set req.backend_hint = default;
    }

...
  1. 有时,您必须处理特殊情况,例如禁用某些URL的Varnish。 转到您的/etc/varnish/default.vcl并根据需要进行编辑。当你第一次看到VCL时,这是非常不利的,但最终它并不难理解。 或者以这种方式编辑您的清漆代理:
## HTTPS termination & Varnish proxy
server {
...
  location ^~ /sitemap {
    #BYPASS VARNISH
    proxy_pass http://127.0.0.1:611;

    proxy_set_header Host $http_host;
    proxy_set_header X-Forwarded-Host $http_host;
    proxy_set_header X-Real-IP  $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_set_header X-Forwarded-Proto $scheme;
    proxy_set_header X-Forwarded-Port 443;
    proxy_set_header X-Secure on;
  }
...
}
© www.soinside.com 2019 - 2024. All rights reserved.