HTTPS配置指北

原文链接:https://www.changxuan.top/?p=672


下载 SSL 证书

如果是在各大云厂商注册的域名,一般都可以申请为期一年免费的SSL证书。当然也有其它的一些平台会提供免费证书。

配置 Nginx

先讲一下我服务器的情况。由于在服务器上运行了 Python、PHP 和 Java 三种语言编写的多个网站,为了能够都使用 80 端口访问,所以我用 Nginx 做了反向代理。这样只需要在 Nginx 层进行 https 配置就可以了。

配置文件

在更改配置文件时,我一般采用类似于开闭原则的方式进行更改。进入到文件夹 /etc/nginx 中,新建一个文件夹 dconf 。然后在 nginx 默认配置文件 nginx.conf 的 http域内加上一行配置,

# Load customize configuration
include  /etc/nginx/dnconf/*.conf;

这样每次启动 nginx 服务时,便会自动加载 dconf 文件夹中的自定义配置。然后在 dconf 中新建一个文件 php.conf 。(注:使用 yum命令安装的 Nginx 1.12.2)下面是配置文件 php.conf 中的内容:

upstream php {
        server 127.0.0.1:8088;
}
server {
        listen 443;
        server_name b.yuming.cn;
        ssl_certificate /etc/nginx/ssl/b.yuming.cn_bundle.crt;
        ssl_certificate_key /etc/nginx/ssl/b.yuming.cn.key;
        ssl on;
        ssl_session_cache builtin:1000 shared:SSL:10m;
        ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
        ssl_ciphers HIGH:!aNULL:!eNULL:!EXPORT:!CAMELLIA:!DES:!MD5:!PSK:!RC4;
        ssl_prefer_server_ciphers on;
        access_log /etc/nginx/logs/b.yuming.cn.access.log;
        location /
        {
          proxy_next_upstream http_502 http_504 error timeout invalid_header;
          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_pass http://php;
        }
}
server {
        listen 443;
        server_name a.yuming.cn;
        ssl_certificate /etc/nginx/ssl/a.yuming.cn_bundle.crt;
        ssl_certificate_key /etc/nginx/ssl/a.yuming.cn.key;
        ssl on;
        ssl_session_cache builtin:1000 shared:SSL:10m;
        ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
        ssl_ciphers HIGH:!aNULL:!eNULL:!EXPORT:!CAMELLIA:!DES:!MD5:!PSK:!RC4;
        ssl_prefer_server_ciphers on;
        access_log /etc/nginx/logs/a.yuming.cn.access.log;
        location /
        {
          proxy_next_upstream http_502 http_504 error timeout invalid_header;
          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_pass http://php;
        }
}
server {
          listen 80;
          server_name a.yuming.cn b.yuming.cn ;
          return 301 https://$host$request_uri;
}

配置文件解释

  • Apache 服务地址与端口
upstream php {
        server 127.0.0.1:8088;
}
  • 针对域名 a.yuming.cn 的配置
server {
        listen 443;
        server_name b.yuming.cn;
        ssl_certificate /etc/nginx/ssl/b.yuming.cn_bundle.crt;
        ssl_certificate_key /etc/nginx/ssl/b.yuming.cn.key;
        ssl on;
        ssl_session_cache builtin:1000 shared:SSL:10m;
        ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
        ssl_ciphers HIGH:!aNULL:!eNULL:!EXPORT:!CAMELLIA:!DES:!MD5:!PSK:!RC4;
        ssl_prefer_server_ciphers on;
        access_log /etc/nginx/logs/b.yuming.cn.access.log;
        location /
        {
          proxy_next_upstream http_502 http_504 error timeout invalid_header;
          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_pass http://php;
        }
}
  • 重定向 80 端口访问请求
server {
          listen 80;
          server_name a.yuming.cn b.yuming.cn ;
          return 301 https://$host$request_uri;
}

FAQ

  1. 配置好重启 nginx 之后,使用 https 可以正常访问网站,为什么浏览器上不显示锁标志?

查看网站中是否引用了http类型的图片、视频、JS或者CSS等资源,如果存在此类资源请改为https链接。

限时福利1:原价 129 元,最后2天仅需 69 元!后天涨价至98元 限时福利2:购课进答疑群专享柳峰(刘运强)老师答疑服务 限时福利3:购课添加助教领取价值 800 元的编程大礼包 为什么需要掌握高性能的MySQL实战? 由于互联网产品用户量大、高并发请求场景多,因此对MySQL的性能、可用性、扩展性都提出了很高的要求。使用MySQL解决大量数据以及高并发请求已经是程序员的必备技能,也是衡量一个程序员能力和薪资的标准之一。 为了让大家快速系统了解高性能MySQL核心知识全貌,我为你总结了「高性能 MySQL 知识框架图」,帮你梳理学习重点,建议收藏! 【课程设计】 课程分为四大篇章,将为你建立完整的 MySQL 知识体系,同时将重点讲解 MySQL 底层运行原理、数据库的性能调优、高并发、海量业务处理、面试解析等。 一、性能优化篇: 主要包括经典 MySQL 问题剖析、索引底层原理和事务与锁机制。通过深入理解 MySQL 的索引结构 B+Tree ,学员能够从根本上弄懂为什么有些 SQL 走索引、有些不走索引,从而彻底掌握索引的使用和优化技巧,能够避开很多实战中遇到的“坑”。 二、MySQL 8.0新特性篇: 主要包括窗口函数和通用表表达式。企业中的许多报表统计需求,如果不采用窗口函数,用普通的 SQL 语句是很难实现的。 三、高性能架构篇: 主要包括主从复制和读写分离。在企业的生产环境中,很少采用单台MySQL节点的情况,因为一旦单个节点发生故障,整个系统都不可用,后果往往不堪设想,因此掌握高可用架构的实现是非常有必要的。 四、面试篇: 程序员获得工作的第一步,就是高效的准备面试,面试篇主要从知识点回顾总结的角度出发,结合程序员面试高频MySQL问题精讲精练,帮助程序员吊打面试官,获得心仪的工作机会。
©️2020 CSDN 皮肤主题: 技术黑板 设计师:CSDN官方博客 返回首页