{"id":563,"date":"2025-09-16T21:18:55","date_gmt":"2025-09-16T13:18:55","guid":{"rendered":"https:\/\/blog.zhouhonghe.com\/?p=563"},"modified":"2025-12-29T16:58:22","modified_gmt":"2025-12-29T08:58:22","slug":"linux%e4%bd%bf%e7%94%a8certbot%e8%87%aa%e5%8a%a8%e6%9b%b4%e6%96%b0lets-encrypt%e8%af%81%e4%b9%a6","status":"publish","type":"post","link":"https:\/\/blog.zhouhonghe.com\/?p=563","title":{"rendered":"\u4f7f\u7528Certbot\u81ea\u52a8\u66f4\u65b0Let's encrypt\u8bc1\u4e66"},"content":{"rendered":"<p><strong>Certbot\u5b89\u88c5<\/strong><\/p>\n<p><a href=\"https:\/\/certbot.eff.org\/instructions?ws=nginx&amp;os=pip\" target=\"_blank\" rel=\"noopener\">https:\/\/certbot.eff.org\/instructions?ws=nginx&amp;os=pip<\/a><\/p>\n<p><strong>\u9632\u706b\u5899\u8fdb\u884c\u51fa\u7ad9\u653e\u901a<\/strong><\/p>\n<p>\u7f16\u8f91\u811a\u672c<br \/>\n<code>sudo vi \/usr\/local\/bin\/ufw-letsencrypt.sh<\/code><\/p>\n<p><em>#!\/bin\/bash<\/p>\n<p># Let's Encrypt \u76f8\u5173\u57df\u540d<br \/>\nDOMAINS=(<br \/>\n\"acme-v02.api.letsencrypt.org\"<br \/>\n\"acme-staging-v02.api.letsencrypt.org\"<br \/>\n# \"ocsp.int-x3.letsencrypt.org\"<br \/>\n# \"certificates.letsencrypt.org\"<br \/>\n)<\/p>\n<p>RULE_COMMENT=\"LETSENCRYPT_$(date +%Y%m%d)\"<\/p>\n<p># \u5220\u9664\u65e7\u7684 Let's Encrypt \u89c4\u5219<br \/>\nOLD_RULES=$(sudo ufw status numbered | grep \"LETSENCRYPT\" | awk '{print $NF}')<br \/>\nif [ -n \"$OLD_RULES\" ]; then<br \/>\nwhile read -r ip; do<br \/>\necho \"\u5220\u9664\u65e7\u89c4\u5219: $ip\"<br \/>\nsudo ufw delete allow out to \"$ip\" 2&gt;\/dev\/null<br \/>\ndone &lt;&lt;&lt; \"$OLD_RULES\"<br \/>\nfi<\/p>\n<p># \u4e3a\u6bcf\u4e2a\u57df\u540d\u6dfb\u52a0\u89c4\u5219<br \/>\nfor domain in \"${DOMAINS[@]}\"; do<br \/>\necho \"\u5904\u7406\u57df\u540d: $domain\"<br \/>\nIPS=$(getent ahosts \"$domain\" | awk '{print $1}' | sort -u)<\/p>\n<p>if [ -n \"$IPS\" ]; then<br \/>\nwhile read -r ip; do<br \/>\necho \"\u5141\u8bb8\u51fa\u7ad9\u8bbf\u95ee: $ip ($domain)\"<br \/>\nsudo ufw allow out to \"$ip\" comment \"$RULE_COMMENT - $domain\"<br \/>\ndone &lt;&lt;&lt; \"$IPS\"<br \/>\nelse<br \/>\necho \"\u8b66\u544a: \u65e0\u6cd5\u89e3\u6790\u57df\u540d $domain\"<br \/>\nfi<br \/>\ndone<\/p>\n<p>echo \"Let's Encrypt \u89c4\u5219\u66f4\u65b0\u5b8c\u6210\"<\/em><\/p>\n<p>\u66f4\u65b0\u8fd0\u884c\u6743\u9650<br \/>\n<code>sudo chomd +x \/usr\/local\/bin\/ufw-letsencrypt.sh<\/code><\/p>\n<p>\u5b9a\u65f6\u8fd0\u884c<br \/>\n<code>sudo crontab -e<\/code><br \/>\n<em> 0 2 * * 1 \/usr\/local\/bin\/ufw-letsencrypt.sh &gt;\/dev\/null 2&gt;&amp;1<\/em><\/p>\n","protected":false},"excerpt":{"rendered":"<p>Certbot\u5b89\u88c5 https:\/\/certbot.eff.org\/instructions?ws=nginx [&hellip;]<\/p>... ","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-563","post","type-post","status-publish","format-standard","hentry","category-others"],"_links":{"self":[{"href":"https:\/\/blog.zhouhonghe.com\/index.php?rest_route=\/wp\/v2\/posts\/563","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/blog.zhouhonghe.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/blog.zhouhonghe.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/blog.zhouhonghe.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/blog.zhouhonghe.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=563"}],"version-history":[{"count":11,"href":"https:\/\/blog.zhouhonghe.com\/index.php?rest_route=\/wp\/v2\/posts\/563\/revisions"}],"predecessor-version":[{"id":650,"href":"https:\/\/blog.zhouhonghe.com\/index.php?rest_route=\/wp\/v2\/posts\/563\/revisions\/650"}],"wp:attachment":[{"href":"https:\/\/blog.zhouhonghe.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=563"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/blog.zhouhonghe.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=563"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/blog.zhouhonghe.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=563"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}