technology-note/linux/软件安装/5.nginx多ssl配置.md

69 lines
2.1 KiB
Markdown
Raw Normal View History

2019-05-07 19:45:50 +08:00
---
id: "20190504"
date: "2019/05/04 10:38:05"
title: "nginx配置多ssl证书"
tags: ["linux", "nginx", "多ssl证书"]
categories:
- "linux"
- "软件使用"
---
有时我们需要在一台主机(只有一个公网 ip上部署多个 https 虚拟主机,如何实现呢?
假如我们想当然的使用如下的配置:
```properties
server{
listen 443 default ssl;
server_name www.test1.com;
ssl_certificate xxxxx;
ssl_certificate_key xxxxx;
}
server{
listen 443 ssl;
server_name www.test2.com;
ssl_certificate xxxxx;
ssl_certificate_key xxxxx;
}
```
<!-- more -->
当然是无法实现的,不论请求哪个主机,都只会收到默认域名`www.test1.com`的证书,这是 SSL 协议本身造成的--先建立 SSL 连接,再发送 HTTP 请求,因此 nginx 建立 SSL 连接时并不知道所请求的域名,所以只会返回默认的主机。
# 解决办法
## 使用多个 IP
最古老的办法就是使用多个 IP每个域名绑定到一个 IP 上即可。
## 使用 TLS SNI
使用多 IP 的方法成本太高了,还好 nginx 支持 TLS 协议的 SNI 拓展(这个拓展让同一个 IP 使用不同的 https 证书成为可能。SNI 拓展需要客户端支持(一般都支持),本地 OpenSSL 支持(这个默认都是不支持的,需要手动编译支持)。
查看 nginx 知否支持 SNI使用如下命令
```bash
nginx -V
```
有如下输出说明支持 SNI。
![](https://raw.githubusercontent.com/FleyX/files/master/blog/20190504152556.png)
默认情况下是不支持的,下面我们来一步一步让它支持 SNI
1. 首先要重新编译安装 openssl详情参考我之前的博文[https://blog.tapme.top/blog/detail/20190503](https://blog.tapme.top/blog/detail/20190503)
2. openssl 支持 SNI 后,重装一次 nginx 理论上就可以了(至少我是这样的):
```bash
apt remove nginx
apt install nginx
```
然后就可以在一个 IP 上使用多个不同的 https 证书了.
**本文原创发布于:**[https://www.tapme.top/blog/detail/20190504](https://www.tapme.top/blog/detail/20190504)