目前已知可以实现同域名反代的方法有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
直接转发的做法?有教程么大佬