使用nginx反向代理,一个80端口下,配置多个微信项目

  我们要接入微信公众号平台开发,需要填写服务器配置,然后依据接口文档才能实现业务逻辑。但是微信公众号接口只支持80接口(80端口)。我们因业务需求需要在一个公众号域名下面,发布两个需要微信授权的项目,怎么办?

  我们可以用nginx服务器做反向代理来解决这个问题。nginx服务器对外80端口,然后根据URL参数不同,对内访问不同的项目。

  

  nginx配置如下:

  打开/usr/local/nginx/conf/nginx.conf

 1 worker_processes  4;
 2 error_log  logs/error.log;
 3 events {
 4     worker_connections  1024;
 5 }
 6 http {
 7     include       mime.types;
 8     default_type  application/octet-stream;
 9     sendfile        on;
10     keepalive_timeout  65;
11
12 gzip on;
13 gzip_min_length 1k;
14 gzip_buffers 16 64k;
15 gzip_http_version 1.1;
16 gzip_comp_level 6;
17 gzip_types text/plain application/x-javascript text/css application/xml application/javascript;
18 gzip_vary on;
19
20     #指向项目一
21     upstream backend1  {
22         server  192.168.1:8081;
23     }
24     #指向项目二
25     upstream backend2{
26         192.168.1.1:8082;
27     }
28     proxy_cache_path /tmp/cache levels=1:2 keys_zone=cache:128m inactive=1d  max_size=1G;
29     include vhosts/*;
30 }

  打开/usr/local/reverse_proxy_nginx/conf/nginx.conf

 1 worker_processes  2;
 2 events {
 3     worker_connections  1024;
 4 }
 5 http {
 6     include       mime.types;
 7     default_type  application/octet-stream;
 8     access_log  /home/nginx_log/reverse_proxy_no1_access.log;
 9     sendfile        on;
10     keepalive_timeout  65;
11     upstream backend1  {
12         #server 192.168.1.1:8181;
13     server  192.168.1.1:8081;
14     }
15     upstream backend2  {
16         #server 192.168.1.1:8082;
17     server  192.168.1.1:8082;
18     }
19     proxy_cache_path /tmp/cache levels=1:2 keys_zone=cache:128m inactive=30m  max_size=1G;
20     server {
21         listen       8081;
22         server_name  h5.xxxx.com;
23
24         location / {
25                 proxy_pass http://backend1;
26             #Proxy Settings
27                proxy_redirect     off;
28              proxy_set_header   Host             $host;
29             proxy_set_header   X-Real-IP        $remote_addr;
30             proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;
31             proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504;
32             proxy_max_temp_file_size 0;
33             proxy_connect_timeout      90;
34             proxy_send_timeout         90;
35             proxy_read_timeout         90;
36             proxy_buffer_size          4k;
37             proxy_buffers              4 32k;
38             proxy_busy_buffers_size    64k;
39             proxy_temp_file_write_size 64k;
40         add_header Nginx-Res "http://backend1";
41         }
42
43         location ~ ^/(h5)(.*)$ {
44               proxy_pass  http://backend2;
45               proxy_redirect off;
46               proxy_set_header Host $host;
47               proxy_cache cache;
48               proxy_cache_valid 200 302 1d;
49               proxy_cache_valid 301 1d;
50               proxy_cache_valid any 1m;
51               expires 1h;
52           add_header Nginx-Res "http://backend2";
53               proxy_ignore_headers "Cache-Control" "Expires" "Set-Cookie";
54               add_header Nginx-Cache "$upstream_cache_status";
55           }
56
57
58         error_page   500 502 503 504  /50x.html;
59         location = /50x.html {
60             root   html;
61         }
62     location ~ .*\.(gif|jpg|png|css|js|ico)(.*) {
63               proxy_pass http://backend1;
64               proxy_redirect off;
65               proxy_set_header Host $host;
66               proxy_cache cache;
67               proxy_cache_valid 200 302 30d;
68               proxy_cache_valid 301 1d;
69               proxy_cache_valid any 1m;
70               expires 30d;
71               proxy_ignore_headers "Cache-Control" "Expires" "Set-Cookie";
72           add_header Nginx-Res "http://backend1";
73               add_header Nginx-Cache "$upstream_cache_status";
74         }

  当我们打开URL包含h5时,就会跳到8081端口项目中,但是对外还是80端口。所以两个项目可以同时实现微信授权登录等。

时间: 2024-08-11 05:42:46

使用nginx反向代理,一个80端口下,配置多个微信项目的相关文章

nginx 反向代理 与 Apache backend的配置联合配置

nginx 反向代理 与 Apache backend的配置联合配置: 说明: nginx 将http映射到Apache上的特定子目录. 配置方法步骤: 1.  设置域名, 子域名映射到指定服务器ip, 2. nginx设置好server ,以及对应的目录, 或者 转发到指定Apache端口. server { listen 80 default_server; listen [::]:80 default_server ipv6only=on; root /usr/share/nginx/ht

使用nginx反向代理一个ip下的多个tomcat

问题:使用阿里云主机和域名后,默认只能解析到ip的80端口,如果配置二级域名指向同一个ip的话是不成立的 解决方案:使用nginx反向代理服务器进行反向代理 原理:利用 nginx upstream机制使得nginx可以成为一个反向代理服务器,没画图软件后期补上 配置文件如下 1 worker_processes 1; 2 error_log logs/error.log; 3 pid logs/nginx.pid; 4 worker_rlimit_nofile 65535; 5 events

nginx 反向代理时丢失端口的解决方案

今天,配置nginx反向代理时遇到一个问题,当设置nginx监听80端口时转发请求没有问题.但一旦设置为监听其他端口,就一直跳转不正常:如,访问欢迎页面时应该是重定向到登录页面,在这个重定向的过程中端口丢失了. 这里给出一个简短的解决方案,修改nginx的配置文件. 一.配置文件 # the 90 port server { listen 90; server_name zxy1994.cn; proxy_set_header X-Forwarded-Host $host; proxy_set_

nginx 反向代理时丢失端口的解决方案(转)

今天,配置nginx反向代理时遇到一个问题,当设置nginx监听80端口时转发请求没有问题.但一旦设置为监听其他端口,就一直跳转不正常:如,访问欢迎页面时应该是重定向到登录页面,在这个重定向的过程中端口丢失了. 这里给出一个简短的解决方案,修改nginx的配置文件. 一.配置文件 # the 90 port server { listen 90; server_name zxy1994.cn; proxy_set_header X-Forwarded-Host $host; proxy_set_

Nginx 反向代理 负载均衡 虚拟主机配置

通过本章你将学会利用Nginx配置多台虚拟主机,清楚代理服务器的作用,区分正向代理和反向代理的区别,搭建使用Nginx反向搭理和负载均衡,了解Nginx常用配置的说明.即学即用,你还在等什么?一睹为快先了解Nginx的三大功能Nginx 可以作为一台http服务器.可以做网站静态服务器,比如图片服务器,高效,减轻服务器压力.同时它也支持https服务.Nginx 可以配置多台虚拟主机.可以实现在一台服务器虚拟出多个网站效果,省钱.Nginx 最重要的是反向代理,负载均衡.在服务器集群中,Ngin

Nginx反向代理后端多节点下故障节点的排除思路

仔细想来,其实是个非常简单的问题:开发和运维觉得两个后端节点跑起来压力太大了,就扩充了两个新的后端节点上去,这一加就出问题了,访问时页面间歇性丢失,这尼玛什么情况...想了半天没思路,查了Nginx的配置,没发现问题,查询后端的错误日志,也是一头雾水. 先贴出代理服务器的配置(upstream部分): upstream api { server 192.168.1.10:9109; server 192.168.1.11:9109; server 192.168.1.12:9109; serve

Nginx反向代理及简单负载均衡配置

nginx配置文件主要分为六个区域:main section.events section.http section.sever section.location section.upstream section. 以下为Nginx的主要配置 #main module配置 use nobody;  #设置运行用户 worker_processes 1;    #设置启动进程,通常设置成cpu数量相当 error_log  logs/error.log;  #全局错误日志定义类型,[ debug

nginx反向代理tomacat+keepalived实现动静分离、负载均衡、高可用

本文的动静分离主要是通过nginx+tomcat来实现,其中nginx处理图片.html.JS.CSS等静态文件,tomcat处理jsp.servlet等动态请求 服务器名称                                 系统版本                           预装软件                     IP地址 Nginx服务器                             CentOS 7 最小安装              Nginx

nginx反向代理502-Bad Gateway问题解决方法

用nginx反向代理 localhost:80 域名到服务器 localhost:8080 端口服务时,访问出现502 bad gateway原因分析:1.查看8080端口服务启动2.查看错误日志:error.log,以centos7.x为例,更改配置路径为:web.dev.xxx.access.ssl.log:xxx - - [22/Oct/2019:10:24:04 +0800] "GET /test HTTP/1.1" 502 3693 "-" "c