{"id":31,"date":"2020-05-18T00:54:19","date_gmt":"2020-05-17T16:54:19","guid":{"rendered":"https:\/\/www.soholab.tw\/?p=31"},"modified":"2020-05-18T00:54:19","modified_gmt":"2020-05-17T16:54:19","slug":"%e5%9c%a8-nginx-%e4%b8%ad%e5%95%9f%e7%94%a8-http-2-%e4%b8%a6%e6%8f%90%e9%ab%98-https-%e5%ae%89%e5%85%a8%e6%80%a7%e8%88%87%e6%95%88%e8%83%bd","status":"publish","type":"post","link":"https:\/\/soholab.tw\/?p=31","title":{"rendered":"\u5728 nginx \u4e2d\u555f\u7528 HTTP\/2 \u4e26\u63d0\u9ad8 HTTPS \u5b89\u5168\u6027\u8207\u6548\u80fd"},"content":{"rendered":"\n<p>\u539f\u6587\u51fa\u8655 <a href=\"https:\/\/snippetinfo.net\/mobile\/media\/1604\">https:\/\/snippetinfo.net\/mobile\/media\/1604<\/a><\/p>\n\n\n\n<p>HTTP\/2 \u7e3d\u7b97\u5728\u53bb\u5e74\u5b9a\u7a3f\u4e86 (<a rel=\"noreferrer noopener\" href=\"https:\/\/www.rfc-editor.org\/rfc\/rfc7540.txt\" target=\"_blank\">RFC 7540<\/a>)\uff0c\u76f8\u95dc\u7684\u670d\u52d9\u4e5f\u6162\u6162\u589e\u52a0\u00a0\u4eca\u5929\u5c31\u7c21\u55ae\u4ecb\u7d39\u4e00\u4e0b\u5982\u4f55\u5728 nginx \u4e0a\u63d0\u4f9b HTTP\/2\u7576\u7136\uff0c\u5982\u679c\u8981\u4f7f\u7528 HTTP\/2\uff0c\u6700\u597d\u5148\u7533\u8acb SSL\uff0c\u4e26\u555f\u7528 HTTPS\u00a0\u70ba\u4f55\u8981\u900f\u904e nginx \u63d0\u4f9b HTTP\/2 \u5462? \u5176\u5be6\u4e3b\u8981\u662f\u5f88\u591a\u670d\u52d9\u53ef\u80fd\u7919\u65bc\u5f88\u591a\u7a2e\u72c0\u6cc1 &#8220;\u5347\u4e0d\u4e0a\u53bb&#8221;\uff0c\u4f8b\u5982\u9084\u5728\u4f7f\u7528 apache 2.2 (HTTP\/2 \u61c9\u8a72\u662f\u5230 apache 2.4 \u624d\u63d0\u4f9b) \u4e4b\u985e\u7684! \u5982\u679c web server \u5347\u4e0d\u4e0a\u53bb\uff0c\u900f\u904e nginx \u505a reverse proxy \u662f\u6eff\u597d\u7684\u9078\u64c7\u7684\u3002\u81f3\u65bc\u5982\u4f55\u8a2d\u5b9a\u53ef\u4ee5\u53c3\u8003\u9019\u908a:\u00a0<a href=\"https:\/\/snippetinfo.net\/media\/1581\/\"><strong>Nginx \u52a0\u4e0a SSL \u8a2d\u5b9a (reverse proxy mode)<\/strong><\/a>\u00a0\u6709\u8208\u8da3\u4e5f\u53ef\u4ee5\u4e86\u89e3\u4e00\u4e0b\u4f55\u8b02 HTTP\/2 (<a href=\"https:\/\/snippetinfo.net\/media\/1605\">\u4e94\u5206\u9418\u4ecb\u7d39 HTTP\/2<\/a>)<\/p>\n\n\n\n<h3 class=\"wp-block-heading\">\u6b65\u9a5f<\/h3>\n\n\n\n<ul class=\"wp-block-list\"><li><strong>\u9996\u5148\u8981\u5347\u7d1a\u4f60\u7684 nignx \u5230 1.9.5 \u4ee5\u4e0a<\/strong>\u6700\u7c21\u55ae\u7684\u65b9\u6cd5\u5c31\u662f\u7528 yum \u8a2d\u5b9a repo\uff0c\u4e26\u4e14\u4fee\u6539\u4f60\u7684 repo \u5982\u4e0b[nginx] name=nginx repo baseurl=http:\/\/nginx.org\/packages\/mainline\/centos\/6\/$basearch\/ gpgcheck=0 enabled=1&nbsp;\u5982\u679c\u4f60\u662f\u5225\u7684 OS\uff0c\u53ef\u4ee5\u53c3\u8003\u9019\u908a\u7684\u8aaa\u660e:&nbsp;<a rel=\"noreferrer noopener\" href=\"https:\/\/nginx.org\/en\/linux_packages.html\" target=\"_blank\">http:\/\/nginx.org\/en\/linux_packages.html<\/a><\/li><li><strong>\u5347\u7d1a nginx<\/strong>yum upgrade nginx<\/li><li><strong>\u555f\u7528 HTTP\/2<\/strong>\u5176\u5be6\u5347\u7d1a\u5230 1.9.5+ \u5f8c\uff0c\u53ea\u8981\u589e\u52a0 http2 \u5728 listen \u5f8c\u9762\u5373\u53ef. listen 443 ssl http2; listen [::]:443 ssl http2; <\/li><li>\u63d0\u9ad8 HTTPS \u5b89\u5168\u6027\u8207\u6548\u80fd<\/li><li><strong>\u6e2c\u8a66\u5b89\u5168\u6027<\/strong>\u8a2d\u5b9a\u5b8c\u6210\u5f8c\uff0c\u53ef\u4ee5\u5230\u9019\u908a\u6e2c\u8a66\u770b\u770b\u4f60\u7684 HTTPS \u5b89\u4e0d\u5b89\u5168<a rel=\"noreferrer noopener\" href=\"https:\/\/www.ssllabs.com\/ssltest\" target=\"_blank\">https:\/\/www.ssllabs.com\/ssltest<\/a>&nbsp;\u55ef\uff0c\u7adf\u7136\u53ea\u6709\u62ff\u5230 B\uff0c\u53ea\u597d\u60f3\u8fa6\u6cd5\u63d0\u9ad8\u4e86!<img decoding=\"async\" src=\"https:\/\/soholab.tw\/wp-content\/uploads\/2020\/05\/31-1.png\" class=\"wp-image-34\" style=\"width: px;\" alt=\"\"><\/li><li><strong>\u5efa\u7acb Diffie-Hellman \u53c3\u6578<\/strong>\u9019\u4e3b\u8981\u662f\u89e3\u6c7a Diffie-Hellman \u516c\u958b\u91d1\u9470\u4e0d\u8db3\u7684\u554f\u984c\uff0c\u5f88\u7c21\u55ae\uff0c\u53ea\u8981\u7522\u751f\u4e00\u500b\u6a94\u6848\u52a0\u5165\u8a2d\u5b9a\u5373\u53ef# \u7522\u751f DH parameters openssl dhparam 4096 -out \/etc\/nginx\/cert\/dhparam.pem\u7136\u5f8c\u5728 nginx.conf \u7684 SSL \u8a2d\u5b9a\u52a0\u4e0assl_dhparam \/etc\/nginx\/cert\/dhparam.pem; \u9019\u6a23\u5c31\u53ef\u4ee5\u4e86\uff0c\u81f3\u65bc\u9019\u500b\u98a8\u96aa\u7684\u539f\u56e0\u70ba\u53ef\u4ee5\u53c3\u8003\u9019\u908a:&nbsp;<a rel=\"noreferrer noopener\" href=\"https:\/\/wiki.mozilla.org\/Security\/Server_Side_TLS#DHE_handshake_and_dhparam\" target=\"_blank\">https:\/\/wiki.mozilla.org\/Security\/Server_Side_TLS#DHE_handshake_and_dhparam<\/a>&nbsp;\u76f8\u95dc\u8a2d\u5b9a\u53c3\u8003\u5982\u4e0bssl_dhparam \/etc\/nginx\/cert\/dhparam.pem; ssl_protocols TLSv1 TLSv1.1 TLSv1.2; ssl_prefer_server_ciphers on; ssl_ciphers &#8220;EECDH+AESGCM:EDH+AESGCM:AES256+EECDH:AES256+EDH&#8221;; <img decoding=\"async\" src=\"https:\/\/snippetinfo.net\/mobile\/media\/1604\"><\/li><li><strong>Apache \u7684\u8a2d\u5b9a\u65b9\u5f0f<\/strong># \u7522\u751f dhparam cd \/etc\/ssl\/certs openssl dhparam -out dhparam.pem 4096 # \u628a\u4e0b\u5217\u8a2d\u5b9a\u52a0\u5230 ssl.conf SSLOpenSSLConfCmd DHParameters &#8220;\/etc\/ssl\/certs\/dhparam.pem&#8221;<img decoding=\"async\" src=\"https:\/\/snippetinfo.net\/mobile\/media\/1604\"><\/li><li><strong>\u91cd\u65b0\u6e2c\u8a66<\/strong>\u5b8c\u6210\u5f8c\u91cd\u65b0\u6e2c\u8a66\u4e00\u6b21! Yeah~ \u5f97\u5230&nbsp;<img decoding=\"async\" class=\"wp-image-35\" style=\"width: 128px;\" src=\"https:\/\/soholab.tw\/wp-content\/uploads\/2020\/05\/31-2.png\" alt=\"\">&nbsp;\u4e86<img decoding=\"async\" class=\"wp-image-36\" style=\"width: px;\" src=\"https:\/\/soholab.tw\/wp-content\/uploads\/2020\/05\/31-3.png\" alt=\"\"><\/li><li><strong>\u78ba\u8a8d HTTP\/2 \u662f\u5426\u555f\u7528?<\/strong>\u5230\u9019\u500b\u7ad9\u6e2c\u8a66\u4e00\u4e0b\u5c31\u597d\u4e86<a rel=\"noreferrer noopener\" href=\"https:\/\/tools.keycdn.com\/http2-test\" target=\"_blank\">https:\/\/tools.keycdn.com\/http2-test<\/a><img decoding=\"async\" class=\"wp-image-37\" style=\"width: px;\" src=\"https:\/\/soholab.tw\/wp-content\/uploads\/2020\/05\/31-4.png\" alt=\"\"><\/li><\/ul>\n","protected":false},"excerpt":{"rendered":"<p>\u539f\u6587\u51fa\u8655 https:\/\/snippetinfo.net\/mobile\/media\/1604 HTTP\/2 \u7e3d [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-31","post","type-post","status-publish","format-standard","hentry","category-uncategorized"],"_links":{"self":[{"href":"https:\/\/soholab.tw\/index.php?rest_route=\/wp\/v2\/posts\/31","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/soholab.tw\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/soholab.tw\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/soholab.tw\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/soholab.tw\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=31"}],"version-history":[{"count":0,"href":"https:\/\/soholab.tw\/index.php?rest_route=\/wp\/v2\/posts\/31\/revisions"}],"wp:attachment":[{"href":"https:\/\/soholab.tw\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=31"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/soholab.tw\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=31"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/soholab.tw\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=31"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}