请教个nginx 配置SSL的问题
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了请教个nginx 配置SSL的问题相关的知识,希望对你有一定的参考价值。
参考技术A 生成证书可以通过以下步骤生成一个简单的证书:
首先,进入你想创建证书和私钥的目录,例如:
$ cd /usr/local/nginx/conf
创建服务器私钥,命令会让你输入一个口令:
$ openssl genrsa -des3 -out server.key 1024
创建签名请求的证书(CSR):
$ openssl req -new -key server.key -out server.csr
在加载SSL支持的Nginx并使用上述私钥时除去必须的口令:
$ cp server.key server.key.org
$ openssl rsa -in server.key.org -out server.key
配置nginx
最后标记证书使用上述私钥和CSR:
$ openssl x509 -req -days 365 -in server.csr -signkey server.key -out server.crt
修改Nginx配置文件,让其包含新标记的证书和私钥:
server
server_name YOUR_DOMAINNAME_HERE;
listen 443;
ssl on;
ssl_certificate /usr/local/nginx/conf/server.crt;
ssl_certificate_key /usr/local/nginx/conf/server.key;
重启nginx。
这样就可以通过以下方式访问:
https://YOUR_DOMAINNAME_HERE
另外还可以加入如下代码实现80端口重定向到443IT人乐园
server
listen 80;
server_name ww.centos.bz;
rewrite ^(.*) https://$server_name$1 permanent;
参考技术B 这个问题,你搭建2个虚拟机测试一下就知道了!
不过我觉得如果是动态的话,可能不行!如果是静态网站,或许可能实现!
需要去搭建环境验证。本回答被提问者和网友采纳
请教nginx 多个 server 怎么配置
参考技术A 在/etc/nginx/下建一个文件夹放站点的配置文件,如example 地址是:/etc/nginx/example在example文件夹里建多个站点的conf文件,如:example1.conf , example2.conf
每个conf配置文件如下,可修改server_name 和 location地址设置多个站点。
server
listen 80;
server_name michaelaschmidt.com www.michaelaschmidt.com;
access_log /var/www/access_michaelaschmidt.log;
location /
root /var/www/michaelaschmidt.com;
index index.php index.html index.htm;
error_page 500 502 503 504 /50x.html;
location = /50x.html
root /usr/share/nginx/html;
# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
location ~ /.php$
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /var/www/michaelaschmidt.com/$fastcgi_script_name;
include fastcgi_params;
location ~ //.ht
deny all;
保存后在/etc/nginx/nginx.conf里面的http 里面加入:
include /etc/nginx/example/*.conf; #将example文件夹下的所有.conf包含入nginx.conf配置文件
最后记得重启nginx:
/etc/init.d/nginx restart本回答被提问者和网友采纳
以上是关于请教个nginx 配置SSL的问题的主要内容,如果未能解决你的问题,请参考以下文章
Nginx负载均衡 ssl原理 生成ssl密钥对 Nginx配置ssl
[转帖]nginx配置ssl加密(单/双向认证部分https)
50.Nginx负载均衡ssl原理生成ssl密钥对Nginx配置ssl