nginx配置https和wss

385 阅读1分钟

本地生成证书,生产环境建议购买证书,生成步骤本文不做描述,生成的证书可以保存起来,以后直接用,不需要每次都重新生成

#user nobody; worker_processes 1;

#error_log logs/error.log; #error_log logs/error.log notice; #error_log logs/error.log info;

#pid logs/nginx.pid;

events { worker_connections 1024; }

http { include mime.types; default_type application/octet-stream; proxy_headers_hash_bucket_size 256; types_hash_bucket_size 256;

sendfile        on;
#tcp_nopush     on;

#keepalive_timeout  0;
keepalive_timeout  65;

#gzip  on;

server {
    listen       80;
    listen  [::]:80;
    server_name  localhost;
    #charset koi8-r;

    #access_log  logs/host.access.log  main;
 

	location / {
                    root /opt/nginx-html/web/front;
                    index index.html index.htm;
            }  



    #error_page  404              /404.html;

    # redirect server error pages to the static page /50x.html
    #
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   html;
    }
	}




# HTTPS server
server {
    listen       443 ssl;
    server_name  192.168.3.60;
    
    ssl_certificate      /usr/local/nginx/ssl_key/nginx.crt;
    ssl_certificate_key  /usr/local/nginx/ssl_key/nginx.nopass.key;

    ssl_session_cache    shared:SSL:1m;
    ssl_session_timeout  5m;

    ssl_ciphers  HIGH:!aNULL:!MD5;
    ssl_prefer_server_ciphers  on;

  

     location /api/ {
       proxy_redirect off;
       proxy_set_header Host $host;
       proxy_set_header X-Real-IP $remote_addr;
       proxy_set_header X-Forwarded-For $remote_addr;
       proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
       proxy_set_header Remote_addr $remote_addr;
       proxy_pass http://192.168.3.67:30701/;
   }

}

server {
#监听端口
listen 8888 ssl;
	server_name xxx.com; 

	#SSL-INFO-START
	ssl_certificate      /usr/local/nginx/ssl_key/nginx.crt;
	ssl_certificate_key  /usr/local/nginx/ssl_key/nginx.nopass.key;
	ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
	ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE;


	location / {
        proxy_pass http://websocket;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection $connection_upgrade;
        proxy_http_version 1.1;
    }
    
access_log  xxx.log;
     error_log  xxx.log;
}

map $http_upgrade $connection_upgrade {
    default upgrade;
    '' close;
}
upstream websocket {
	#这里是服务器开放的端口
    server 192.168.3.66:8105;
}

}