我是Nginx的新手,我的目标是:
当我访问127.0.0.1:8080/proxy/git/
或Https://127.0.0.1/proxy/git/
时,Nginx(反向)代理可以转到https://github.com
我的nginx conf很震撼:
http {
server {
listen 8080 default backlog=2048;
listen 443 ssl;
server_name 127.0.0.1;
ssl_certificate /etc/nginx/xxxxxxx.crt;
ssl_certificate_key /etc/nginx/xxxxxxx.key;
location /proxy/git/ {
proxy_pass https://github.com/;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass_header Server;
proxy_redirect off;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Scheme $scheme;
}
error_page 500 502 503 504 /50x.html;
}
##
# Basic Settings
##
sendfile on;
tcp_nopush on;
tcp_nodelay on;
keepalive_timeout 65;
types_hash_max_size 2048;
# server_tokens off;
# server_names_hash_bucket_size 64;
# server_name_in_redirect off;
当我进入或在我的Chrome地址栏中,我得到301重定向并且地址变成了,我认为它变成了直接访问,但我想要代理访问,这是一张图片:
但是,当我重定向到http&静态网站时,没关系。
我在网站上搜索了很多,有人说这是因为proxy_redirect
,我已将其测试到proxy_redirect / /;
或删除它,并将proxy_set_header Host $host;
更改为proxy_set_header Host $http_host;
但都没有意义。
特别是,如果我删除proxy_redirect
行并将$host
更改为$http_hosts,
,如下所示:
proxy_pass https://github.com/;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass_header Server;
#proxy_redirect default;
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Scheme $scheme;
似乎它会做自己和我自己?
所以,我的问题是:
任何人都可以告诉我如何在127.0.0.1下将代理转发到github? (想象一下,我在一个必须使用这种反向代理的地方)
如果你能用简单的词语来解释我们为什么要这样做,你会很高兴。我也想知道原因。
我的英语很差,所以为了说清楚,我们可以将github称为“目标服务器”或“目标网站”,并调用127.0.0.1“代理服务器”或“nginx”
真诚地感谢任何想要帮助我的人!
答案 0 :(得分:4)
我找到了原因。
Github需要Https和HOST:github.com
proxy_set_header Host $http_host;
无法帮助您更改此主机标头,而应使用proxy_set_header Host $proxy_host;
。这会将主机头更改为github。