91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

升級到Https的腳本是怎樣的

發布時間:2021-11-12 18:08:07 來源:億速云 閱讀:217 作者:柒染 欄目:安全技術

升級到Https的腳本是怎樣的,針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

現在很多站長都會考慮將自己的站點從http升級到https,不僅是基于安全的考慮,有的也是因為第三方平臺的限制,如谷歌瀏覽器會將http站點標記為不安全的站點,微信平臺要求接入的微信小程序必須使用https等。

http與https的區別

為了數據傳輸的安全,https在http的基礎上加入了ssl協議,ssl協議依靠證書來驗證服務器的身份,并為瀏覽器和服務器之間的通信加密。要想將http升級為https,只需要給http站點增加一個CA證書即可。

目前獲取CA證書有兩種途徑:

  • 購買收費的CA證書

  • 獲取免費的證書

收費的CA證書各大服務提供商都有賣,如阿里云、騰訊云等。

升級到Https的腳本是怎樣的

收費的證書不便宜,從阿里云官方網站看,它的價格可以從幾千元到上萬元不等。

 升級到Https的腳本是怎樣的

這對于小公司平臺,甚至是個人站點來說,是一個不小的開支。

Letsencrypt是一個免費、自動化和開放的證書頒發機構,其頒發的證書一次有效期為三個月,但是只要能持續更新,基本可以永久使用。

今天推薦的這個腳本acme.sh,實現了 acme 協議, 可以幫你持續自動從Letsencrypt更新CA證書。下載地址如下:

https://github.com/Neilpang/acme.sh

安裝 acme.sh

安裝acme.sh很簡單,一個命令即可:

curl https://get.acme.sh | sh

普通用戶和 root 用戶都可以安裝使用。安裝過程進行了以下幾步:

1、把acme.sh安裝到你的home目錄下:

~/.acme.sh/

并創建 一個 bash 的 alias,方便你使用:alias acme.sh=~/.acme.sh/acme.sh

2、自動為你創建 cronjob,每天 0:00  點自動檢測所有的證書。如果快過期了,需要更新,則會自動更新證書,安裝過程不會污染已有的系統任何功能和文件,所有的修改都限制在安裝目錄中:  ~/.acme.sh/

生成證書

acme.sh 實現了 acme 協議支持的所有驗證協議, 一般有兩種方式驗證: http 和 dns 驗證。

1、http 方式需要在你的網站根目錄下放置一個文件, 來驗證你的域名所有權,完成驗證,然后就可以生成證書了。

acme.sh --issue -d mydomain.com -d www.mydomain.com --webroot /home/wwwroot/mydomain.com/

acme.sh 會全自動的生成驗證文件, 并放到網站的根目錄,然后自動完成驗證。最后會聰明的刪除驗證文件,整個過程沒有任何副作用。

如果你用的是apache服務器,acme.sh 還可以智能的從 apache的配置中自動完成驗證,你不需要指定網站根目錄:

acme.sh --issue -d mydomain.com --apache

如果你用的是nginx服務器,或者反代,acme.sh還可以智能的從 nginx的配置中自動完成驗證,你不需要指定網站根目錄:

acme.sh --issue -d mydomain.com --nginx

注意:無論是 apache 還是 nginx  模式,acme.sh在完成驗證之后,會恢復到之前的狀態,都不會私自更改你本身的配置。好處是你不用擔心配置被搞壞,但也有一個缺點,你需要自己配置 ssl  的配置,否則,只能成功生成證書,你的網站還是無法訪問https。 但是為了安全,你還是自己手動改配置吧。

如果你還沒有運行任何 web 服務,80 端口是空閑的, 那么 acme.sh 還能假裝自己是一個webserver, 臨時聽在80  端口,完成驗證:

acme.sh --issue -d mydomain.com --standalone

2、dns 方式,在域名上添加一條 txt 解析記錄,驗證域名所有權。

這種方式的好處是,你不需要任何服務器,不需要任何公網 ip,只需要 dns 的解析記錄即可完成驗證。不過,壞處是,如果不同時配置 Automatic  DNS API,使用這種方式 acme.sh 將無法自動更新證書,每次都需要手動再次重新解析驗證域名所有權。

acme.sh --issue --dns -d mydomain.com

然后,acme.sh 會生成相應的解析記錄顯示出來,你只需要在你的域名管理面板中添加這條 txt 記錄即可。

等待解析完成之后, 重新生成證書:

acme.sh --renew -d mydomain.com

注意:第二次這里用的是 --renew

dns 方式的真正強大之處在于可以使用域名解析商提供的 api 自動添加 txt 記錄完成驗證。

acme.sh 目前支持 cloudflare, dnspod, cloudxns, godaddy 以及 ovh 等數十種解析商的自動集成。

copy/安裝 證書

前面證書生成以后,接下來需要把證書 copy 到真正需要用它的地方。

注意:默認生成的證書都放在安裝目錄下:~/.acme.sh/,請不要直接使用此目錄下的文件。例如,不要直接讓 nginx/apache  的配置文件使用這下面的文件。這里面的文件都是內部使用,而且目錄結構可能會變化。

正確的使用方法是使用 --installcert 命令,并指定目標位置,然后證書文件會被copy到相應的位置,例如:

acme.sh --installcert -d <domain>.com \  --key-file /etc/nginx/ssl/<domain>.key \  --fullchain-file /etc/nginx/ssl/fullchain.cer \  --reloadcmd "service nginx force-reload"

一個小提醒,這里用的是 service nginx force-reload,不是 service nginx reload,據測試,  reload并不會重新加載證書,所以用的 force-reload。

Nginx 的配置 ssl_certificate 使用 /etc/nginx/ssl/fullchain.cer,而非  /etc/nginx/ssl/.cer ,否則 SSL Labs 的測試會報 Chain issues Incomplete 錯誤。

--installcert命令可以攜帶很多參數,來指定目標文件。并且可以指定 reloadcmd,  當證書更新以后,reloadcmd會被自動調用,讓服務器生效。

值得注意的是,這里指定的所有參數都會被自動記錄下來,并在將來證書自動更新以后,被再次自動調用。

更新證書

目前證書在 60 天以后會自動更新,你無需任何操作。今后有可能會縮短這個時間,不過都是自動的,你不用關心。

更新 acme.sh

目前由于 acme 協議和 Letsencrypt CA 都在頻繁的更新,因此 acme.sh 也經常更新以保持同步。

升級 acme.sh 到最新版 :

acme.sh --upgrade

如果你不想手動升級, 可以開啟自動升級:

acme.sh --upgrade --auto-upgrade

之后, acme.sh 就會自動保持更新了。

你也可以隨時關閉自動更新:

acme.sh --upgrade --auto-upgrade 0

6. 出錯怎么辦:

如果出錯, 請添加 debug log:

acme.sh --issue ..... --debug

或者:

acme.sh --issue ..... --debug 2

最后,本文并非完全的使用說明,還有很多高級的功能,更高級的用法請參看其他 wiki 頁面。

https://github.com/Neilpang/acme.sh/wiki

關于升級到Https的腳本是怎樣的問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

永川市| 蓝山县| 赤峰市| 湘潭县| 汉中市| 渭源县| 台江县| 垦利县| 石家庄市| 隆德县| 北宁市| 鹿泉市| 阳东县| 叶城县| 焦作市| 丘北县| 通河县| 广宗县| 怀宁县| 恩平市| 阿勒泰市| 涡阳县| 北安市| 建瓯市| 北票市| 西乌珠穆沁旗| 张家界市| 连平县| 闽清县| 航空| 邯郸市| 临沧市| 太湖县| 同德县| 万年县| 龙井市| 牙克石市| 西宁市| 开化县| 贡嘎县| 海林市|