分享同域名反代方法,请教不同方法的效率执行问题
侧边栏壁纸
  • 累计撰写 65,139 篇文章
  • 累计收到 0 条评论

分享同域名反代方法,请教不同方法的效率执行问题

James
2020-08-29 / 0 评论 / 64 阅读 / 正在检测是否收录...

目前已知可以实现同域名反代的方法有3种,我分享的是最简单配置的直接发送HOSTHEADER调取的方法

另外两种方法还有一个是修改HOST然后宝塔配置界面设置反代,还有一种是upstream的配置方法。

想请教大佬的是:假设源服务器性能很强,线路垃圾,反代服务器线路很好,性能一般的前提下:

三种同域名反代方法中,哪个效率最高,另外我下面的配置是不是有需要优化的参数啥的,还能再怎么优化?

环境:

源服务器:宝塔+NIGNX,反代服务器:宝塔+NIGNX,源服务器和目标服务器都绑定了网站域名,其实装不装宝塔都是OK的,设置好证书路径即可。

宝塔做个301.www.domains.com自动跳到domains.com

配置文件修改:(其中domains.com是你需要同域名反代的站点域名,127.0.0.1是你的源服务器IP)

server
{
listen80;

listen443sslhttp2;

server_namedomains.comwww.domains.com;
indexindex.phpindex.htmlindex.htmdefault.phpdefault.htmdefault.html;

#SSL-STARTSSL相关配置,请勿删除或修改下一行带注释的404规则
#error_page404/404.html;
ssl_certificate /www/server/panel/vhost/cert/domains.com/fullchain.pem;
ssl_certificate_key /www/server/panel/vhost/cert/domains.com/privkey.pem;
ssl_protocolsTLSv1.1TLSv1.2TLSv1.3;
ssl_ciphersECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE;
ssl_prefer_server_cipherson;
ssl_session_cacheshared:SSL:10m;
ssl_session_timeout10m;
#添加
ssl_buffer_size1400;
add_headerStrict-Transport-Securitymax-age=15768000;
ssl_staplingon;
ssl_stapling_verifyon;
#添加结束
error_page497 https://$host$request_uri;

#SSL-END

#ERROR-PAGE-START 错误页配置,可以注释、删除或修改
#error_page404/404.html;
#error_page502/502.html;
#ERROR-PAGE-END

#PHP-INFO-START PHP引用配置,可以注释或修改
includeenable-php-00.conf;
#PHP-INFO-END

#REWRITE-STARTURL重写规则引用,修改后将导致面板设置的伪静态规则失效
include/www/server/panel/vhost/rewrite/domains.com.conf;
#REWRITE-END

#禁止访问的文件或目录
location~^/(.user.ini|.htaccess|.git|.svn|.project|LICENSE|README.md)
{

  return404;

}

#一键申请SSL证书验证目录相关设置
location~.well-known{

  allowall;

}

#添加
if($ssl_protocol=""){return301https://$host$request_uri;}
if($host!=www.domains.com){
rewrite^/(.*)$$scheme://www.domains.com)/$1permanent;
}

location/{
proxy_passhttps://127.0.0.1:443;

proxy_passhttps://127.0.0.1:443;

ProxySettings

proxy_redirect off;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header REMOTE-HOST $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_next_upstreamerrortimeoutinvalid_headerhttp_500http_502http_503http_504;
proxy_max_temp_file_size0;
proxy_connect_timeout 90;
proxy_send_timeout 90;
proxy_read_timeout 90;
proxy_buffer_size 4k;
proxy_buffers 432k;
proxy_busy_buffers_size 64k;
proxy_temp_file_write_size64k;
error_page404401402403404500502503504/502.html;
}

添加结束

access_log  /www/wwwlogs/domains.com.log;

error_log /www/wwwlogs/domains.com.error.log;
}


-----------------------------------------------------
网友回复:

引用:joachim发表于2020-6-2223:49

直接转发


网友回复:

我也马克一下,也有这种需求,楼主找到好方案后务必艾特我一下,谢谢


网友回复:

引用:ZHT5178发表于2020-6-2223:54

直接转发的做法?有教程么大佬

0