이 글은 주로 Nginx 리버스 프록시 웹소켓 구성 예시를 소개합니다. 이 글은 성공적인 구성 후 프로젝트 요구 사항을 요약한 것입니다. 필요한 친구는 이를 참조할 수 있습니다.
최근 요구 사항이 있는데, 이는 nginx 리버스를 사용해야 한다는 것입니다. 프록시 웹소켓 검색 후, 이 글은 기록만 남깁니다.
코드 복사 코드는 다음과 같습니다.
注: 看官方文档说 Nginx 在 1.3 以后的版本才支持 websocket 反向代理,所以要想使用支持 websocket 的功能,必须升级到 1.3 以后的版本, 因此我这边是下载的 Tengine 的最新版本测试的
1. 코드 복사
코드는 다음과 같습니다.wget http://tengine.taobao.org/download/tengine-2.0.3.tar.gz2. 기본 종속성 설치
패키지코드 복사
코드는 다음과 같습니다.yum -y install pcre* yum -y install zlib* yum -y install openssl*3. 압축을 풀고 컴파일하고 설치합니다
. 코드를 복사하세요
코드는 다음과 같습니다.tar -zxvf tengine-2.0.3.tar.gz cd tengine-2.0.3 ./configure --prefix=安装目录 make sudo make installnginx.conf 구성은 다음과 같습니다.
코드를 복사합니다.
코드는 다음과 같습니다.user apps apps; worker_processes 4; # 这个由于我是用的虚拟机,所以配置的 4 ,另外 tengine 可以自动根据CPU数目设置进程个数和绑定CPU亲缘性 # worker_processes auto # worker_cpu_affinity auto error_log logs/error.log; pid logs/nginx.pid; #Specifies the value for maximum file descriptors that can be opened by this process. worker_rlimit_nofile 65535; events { use epoll; worker_connections 65535; } # load modules compiled as Dynamic Shared Object (DSO) # #dso { # load ngx_http_fastcgi_module.so; # load ngx_http_rewrite_module.so; #} http { include mime.types; default_type application/octet-stream; server_names_hash_bucket_size 128; client_header_buffer_size 4k; large_client_header_buffers 4 32k; client_max_body_size 80m; sendfile on; tcp_nopush on; client_body_timeout 5; client_header_timeout 5; keepalive_timeout 5; send_timeout 5; open_file_cache max=65535 inactive=20s; open_file_cache_valid 30s; open_file_cache_min_uses 1; tcp_nodelay on; fastcgi_connect_timeout 300; fastcgi_send_timeout 300; fastcgi_read_timeout 300; fastcgi_buffer_size 64k; fastcgi_buffers 4 64k; fastcgi_busy_buffers_size 128k; fastcgi_temp_file_write_size 128k; client_body_buffer_size 512k; proxy_connect_timeout 5; proxy_read_timeout 60; proxy_send_timeout 5; proxy_buffer_size 16k; proxy_buffers 4 64k; proxy_busy_buffers_size 128k; proxy_temp_file_write_size 128k; gzip on; gzip_min_length 1k; gzip_buffers 4 16k; gzip_http_version 1.0; gzip_comp_level 2; gzip_types text/plain application/x-javascript text/css application/xml; gzip_vary on; proxy_temp_path /dev/shm/temp; proxy_cache_path /dev/shm/cache levels=2:2:2 keys_zone=cache_go:200m inactive=5d max_size=7g; log_format log_access '$remote_addr - $remote_user [$time_local] "$request" "$request_time" "$upstream_response_time"' '$status $body_bytes_sent "$http_referer" ' '"$http_user_agent" $http_x_forwarded_for $host $hostname' ; #websocket 需要加下这个 map $http_upgrade $connection_upgrade { default upgrade; '' close; } include /home/apps/tengine/conf/test.com; }test.com 구성 파일 내용:
코드를 복사합니다.
코드는 다음과 같습니다.upstream test.com { server 192.168.1.5:9000; } server { listen 80; server_name test.com; #charset koi8-r; #access_log logs/host.access.log main; location ^~ /websocket { proxy_pass http://test.com; proxy_redirect off; proxy_set_header X-Real-IP $remote_addr; proxy_set_header Host $host; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; } }map 명령을 구문 분석합니다.
map $http_upgrade $connection_upgrade 위의 nginx.conf 구성에서 $http_upgrade 변수의 값은 새 변수를 생성합니다. $connection_upgrade. 생성된 규칙은 {}의 내용입니다. 구성을 참조하세요.
코드 복사
코드는 다음과 같습니다.map $http_upgrade $connection_upgrade { default upgrade; '' close; }규칙이 일치하지 않으므로 기본 규칙이 사용됩니다. $connection_upgrade 값은 항상 업그레이드입니다. 그런 다음 $http_upgrade가 빈 문자열이면 값이 닫힙니다. 개인적인 이해!
관련 권장 사항:
Nginx 및 PHP 설치 및 구성 6개의 Nginx 역방향 프록시 및 부하 분산 배포 가이드
nginx 역방향 프록시 메커니즘으로 프런트엔드 교차 도메인 문제 해결
위 내용은 Nginx 역방향 프록시 웹 소켓 구성 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!