Rumah >Operasi dan penyelenggaraan >Nginx >Bagaimana untuk mengkonfigurasi berbilang WeChat di bawah port proksi terbalik Nginx 80

Bagaimana untuk mengkonfigurasi berbilang WeChat di bawah port proksi terbalik Nginx 80

王林
王林ke hadapan
2023-05-24 14:58:061632semak imbas

Penjelasan terperinci tentang mengkonfigurasi berbilang projek WeChat di bawah port proksi terbalik nginx 80

Jika kami ingin mengakses platform akaun awam WeChat untuk pembangunan, kami perlu mengisi konfigurasi pelayan dan kemudian melaksanakannya mengikut logik perniagaan dokumen antara muka. Walau bagaimanapun, antara muka akaun rasmi WeChat hanya menyokong antara muka 80 (port 80). Disebabkan keperluan perniagaan, kami perlu menerbitkan dua projek yang memerlukan kebenaran WeChat di bawah satu nama domain akaun rasmi Apakah yang perlu kami lakukan?

Kita boleh menggunakan pelayan nginx sebagai proksi terbalik untuk menyelesaikan masalah ini. Pelayan nginx secara luaran mengakses port 80, dan kemudian mengakses projek yang berbeza secara dalaman berdasarkan parameter url yang berbeza.

 Bagaimana untuk mengkonfigurasi berbilang WeChat di bawah port proksi terbalik Nginx 80

Konfigurasi nginx adalah seperti berikut:

Buka /usr/local/nginx/conf/nginx.conf

worker_processes 4;
error_log logs/error.log;
events {
  worker_connections 1024;
}
http {
  include    mime.types;
  default_type application/octet-stream;
  sendfile    on;
  keepalive_timeout 65;

gzip on;
gzip_min_length 1k;
gzip_buffers 16 64k;
gzip_http_version 1.1;
gzip_comp_level 6;
gzip_types text/plain application/x-javascript text/css application/xml application/javascript;
gzip_vary on;

  #指向项目一
  upstream backend1 {
    server 192.168.1:8081;
  }
  #指向项目二
  upstream backend2{
    192.168.1.1:8082;
  }
  proxy_cache_path /tmp/cache levels=1:2 keys_zone=cache:128m inactive=1d max_size=1g;
  include vhosts/*;
}

Buka / usr/local /reverse_proxy_nginx/conf/nginx.conf

worker_processes 2;
events {
  worker_connections 1024;
}
http {
  include    mime.types;
  default_type application/octet-stream;
  access_log /home/nginx_log/reverse_proxy_no1_access.log;
  sendfile    on;
  keepalive_timeout 65;
  upstream backend1 {
    #server 192.168.1.1:8181;
  server 192.168.1.1:8081;
  }
  upstream backend2 {
    #server 192.168.1.1:8082;
  server 192.168.1.1:8082;
  }
  proxy_cache_path /tmp/cache levels=1:2 keys_zone=cache:128m inactive=30m max_size=1g;
  server {
    listen    8081;
    server_name h5.xxxx.com;

    location / {
        proxy_pass http://backend1;
      #proxy settings
        proxy_redirect   off;
       proxy_set_header  host       $host;
      proxy_set_header  x-real-ip    $remote_addr;
      proxy_set_header  x-forwarded-for $proxy_add_x_forwarded_for;
      proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504;
      proxy_max_temp_file_size 0;
      proxy_connect_timeout   90;
      proxy_send_timeout     90;
      proxy_read_timeout     90;
      proxy_buffer_size     4k;
      proxy_buffers       4 32k;
      proxy_busy_buffers_size  64k;
      proxy_temp_file_write_size 64k;
    add_header nginx-res "http://backend1";
    }

    location ~ ^/(h5)(.*)$ { 
       proxy_pass http://backend2;
       proxy_redirect off;
       proxy_set_header host $host;
       proxy_cache cache;
       proxy_cache_valid 200 302 1d;
       proxy_cache_valid 301 1d;
       proxy_cache_valid any 1m;
       expires 1h;
     add_header nginx-res "http://backend2";
       proxy_ignore_headers "cache-control" "expires" "set-cookie";
       add_header nginx-cache "$upstream_cache_status";
     }

    
    error_page  500 502 503 504 /50x.html;
    location = /50x.html {
      root  html;
    }
  location ~ .*\.(gif|jpg|png|css|js|ico)(.*) {
       proxy_pass http://backend1;
       proxy_redirect off;
       proxy_set_header host $host;
       proxy_cache cache;
       proxy_cache_valid 200 302 30d;
       proxy_cache_valid 301 1d;
       proxy_cache_valid any 1m;
       expires 30d;
       proxy_ignore_headers "cache-control" "expires" "set-cookie";
     add_header nginx-res "http://backend1";
       add_header nginx-cache "$upstream_cache_status";
    }

Atas ialah kandungan terperinci Bagaimana untuk mengkonfigurasi berbilang WeChat di bawah port proksi terbalik Nginx 80. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:yisu.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam