Dehydrated:修订间差异

来自Gea-Suan Lin's Wiki
跳到导航 跳到搜索
此页面具有访问限制。如果您看见此消息,则说明您没有权限访问此页面。
(未显示同一用户的41个中间版本)
第3行: 第3行:
| name          = dehydrated
| name          = dehydrated
| author         = Lukas Schauer
| author         = Lukas Schauer
| latest preview version = v0.6.1
| latest preview date   = {{Start date and age|2018|3|14}}
| status         = 運行中
| status         = 運行中
| programming language  = [[Shell Script]]
| programming language  = [[Shell Script]]
第11行: 第9行:
| website         = {{URL|https://dehydrated.de/}}
| website         = {{URL|https://dehydrated.de/}}
}}
}}
'''dehydrated'''是一套支援ACME協定的套件(目前 由[[Let's Encrypt]]提供服務)。
'''dehydrated'''是一套支援ACME協定的 軟體 套件(目前 主要是 由[[Let's Encrypt]]提供服務)。


== 特色 ==
== 特色 ==
第17行: 第15行:


== 安裝 ==
== 安裝 ==
 在[[Ubuntu]] 17.10之後的版本(包含即將出版的18.04) 可以直接安裝<code>dehydrated</code><ref>{{Cite web |url=https://packages.ubuntu.com/search?keywords=dehydrated |title=Ubuntu – Package Search Results -- dehydrated |accessdate=2018-04-24}}</ref>, 而在 比較 舊的版本 可以透過 我包裝的[[PPA]]安裝:
 在[[Ubuntu]] 17.10之後的版本(包含即將出版的18.04) 的APT內有<code>dehydrated</code><ref>{{Cite web |url=https://packages.ubuntu.com/search?keywords=dehydrated |title=Ubuntu – Package Search Results -- dehydrated |accessdate=2018-04-24}}</ref> 可以裝 但因為我自己包了一包只有執行檔的( 比較 小), 可以透過[[PPA]]安裝:
<syntaxhighlight lang="shell-session">
<syntaxhighlight lang="bash">
$ sudo add-apt-repository ppa:gslin/dehydrated
sudo add-apt-repository ppa:gslin/dehydrated-lite
$ sudo apt update
sudo apt update
$ sudo apt install dehydrated
sudo apt install dehydrated-lite
</syntaxhighlight>
</syntaxhighlight>


 另外可以直接去官方網站上下載檔案,僅需下載<code>dehydrated</code>檔案。我建議把這個檔案放到<code>/usr/sbin/</code>下。
 另外 可以直接去官方網站上下載檔案,僅需下載<code>dehydrated</code>檔案。我建議把這個檔案放到<code>/usr/sbin/</code>下。


== 基本設定 ==
== 基本設定 ==
dehydrated在偵測到<code>/etc/dehydrated/config</code>或<code>/usr/local/etc/dehydrated/config</code>時(兩個都有時前者優先),會將<code>/etc/dehydrated</code>或是<code>/usr/local/etc</code>當作設定目錄,所以我們需要產生<code>/etc/dehydrated/config</code>,目前裡面不需要有東西:
dehydrated在偵測到<code>/etc/dehydrated/config</code>或<code>/usr/local/etc/dehydrated/config</code>時(兩個都有時前者優先),會將<code>/etc/dehydrated</code>或是<code>/usr/local/etc</code>當作設定目錄,所以我們需要產生<code>/etc/dehydrated/config</code>,目前裡面不需要有東西:
<syntaxhighlight lang="shell-session">
<syntaxhighlight lang="bash">
$ sudo mkdir /etc/dehydrated
sudo mkdir /etc/dehydrated
$ sudo touch /etc/dehydrated/config
sudo touch /etc/dehydrated/config
</syntaxhighlight>
</syntaxhighlight>


== 進階設定 ==
== 進階設定 ==
 這邊的設定都是選擇性設定,進階使用者可以修改dehydrated預設值。
 這邊的設定都是選擇性設定,進階使用者可以修改dehydrated預設值 ,對安全性與效能的參數進行調整


 在<code>config</code>內可以設定開啟憑證內標示一定要開OCSP Stapling:
 在<code>config</code>內可以設定開啟憑證內標示一定要開OCSP Stapling:
第47行: 第45行:


== 域名設定 ==
== 域名設定 ==
=== Domain ===
認證可以透過<code>http-01</code>或是<code>dns-01</code>的協定 。無論是那種 <code>domains.txt</code> 內設定要申請 網域名稱,裡面一行就是一張憑證,一行如果有多個域名就是將這些域名申請到同一個憑 裡:
Domain的 認證可以透過<code>http-01</code>或是<code>dns-01</code>的協定, 這邊 <code>http-01</code>的 方式認


在<code>domains.txt</code>內一行是一張憑證,有幾種方式可以設定。
=== 一張憑證一個域名 ===
 
==== 一張憑證一個域名 ====
 一行放一個域名,將需要申請的網域名稱放到<code>domains.txt</code>內:
 一行放一個域名,將需要申請的網域名稱放到<code>domains.txt</code>內:
<syntaxhighlight lang="shell-session">
<syntaxhighlight lang="bash">
$ cd /etc/dehydrated
cd /etc/dehydrated
$ echo 'blog.gslin.org' | sudo tee -a domains.txt
echo 'blog.gslin.org' | sudo tee -a domains.txt
$ echo 'wiki.gslin.org' | sudo tee -a domains.txt
echo 'wiki.gslin.org' | sudo tee -a domains.txt
</syntaxhighlight>
</syntaxhighlight>


==== 一張憑證多個域名 ====
=== 一張憑證多個域名 ===
 將想要放在同一張憑證的域名放在同一行,一樣是<code>domains.txt</code>內:
 將想要放在同一張憑證的域名放在同一行,一樣是<code>domains.txt</code>內:
<syntaxhighlight lang="shell-session">
<syntaxhighlight lang="bash">
$ cd /etc/dehydrated
cd /etc/dehydrated
$ echo 'blog.gslin.org wiki.gslin.org' | sudo tee -a domains.txt
echo 'blog.gslin.org wiki.gslin.org' | sudo tee -a domains.txt
</syntaxhighlight>
</syntaxhighlight>


=== Wildcard ===
=== Wildcard ===
Wildcard的認證 只能透過<code>dns-01</code>,而且 一定要有一個主域名(沒有<code>*</code>)
Wildcard的認證一定要 有帶 有一個主域名(沒有<code>*</code>):
<syntaxhighlight lang="shell-session">
<syntaxhighlight lang="bash">
$ cd /etc/dehydrated
cd /etc/dehydrated
$ echo 'gslin.org *.gslin.org' | sudo tee -a domains.txt
echo 'gslin.org *.gslin.org' | sudo tee -a domains.txt
</syntaxhighlight>
</syntaxhighlight>


== 認證設定 ==
== 認證設定 ==
Domain-validated certificate(即DV,非Wildcard的)的可以用<code>http-01</code>或是<code>dns-01</code>的方式認證。Wildcard的只能使用<code>dns-01</code>的方式認證。
=== http-01 ===
=== http-01 ===
dehydrated預設會用<code>/var/www/dehydrated</code>作為認證目錄,需要將網頁的<code>/.well-known/acme-challenge/</code>指到這邊。以[[nginx]]的設定會像是這樣:
dehydrated預設會用<code>/var/www/dehydrated/</code>作為認證目錄,需要將網頁的<code>/.well-known/acme-challenge/</code>指到這邊。以[[nginx]]的設定會像是這樣:
<pre>
<pre>
server {
server {
第86行: 第83行:
    }
    }
}
}
</pre>
以[[Apache]]的會是這樣(放到<code>/etc/apache2/conf-available/dehydrated.conf</code>內,再用<code>a2enconf dehydrated</code>啟用):
<pre>
Alias /.well-known/acme-challenge /var/www/dehydrated
<Directory /var/www/dehydrated>
   Options None
   AllowOverride None
   Require all granted
</Directory>
</pre>
</pre>


=== dns-01 ===
=== dns-01 ===
<code>dns-01</code>會需要使用<code>TXT</code> record認證。這邊會使用[[lexicon]],所以系統內需要安裝[[Python]](不適合用pyenv,因為 跑dehydrated 通常使用root權限)。
<code>dns-01</code>會需要使用<code>TXT</code> record認證。這邊會使用[[lexicon]](不適合用pyenv 安裝 ,因為通常使用root權限 跑dehydrated,這會使得環境無法取得 ,這需要另外安裝
 
{{See also|lexicon}}


 這 邊用Python 2說明:
  另外dehydrated需要lexicon的<code>examples/dehydrated.default.sh</code>(將dehydrated的hook命令轉給lexicon使用),所以需要下載 個檔案,複製到<code>/usr/sbin/lexicon-dehydrated.default.sh</code> 以便後續更新:
<syntaxhighlight lang="shell-session">
$ sudo apt install python python-pip
</syntaxhighlight>


然後安裝lexicon:
<syntaxhighlight lang="bash">
<syntaxhighlight lang="shell-session">
cd /tmp
$ sudo pip install dns-lexicon
git clone https://github.com/AnalogJ/lexicon.git
sudo cp lexicon/examples/dehydrated.default.sh /usr/sbin/lexicon-dehydrated.default.sh
</syntaxhighlight>
</syntaxhighlight>


  另外lexicon的<code>examples/dehydrated.default.sh</code> 拿來將dehydrated的hook指令介 給lexicon ,所以需要 下載 這個檔案,複製到<code>/usr/sbin/lexicon-dehydrated.default.sh</code>以便後續更新
  接用[[GitHub]]提供的連結 下載:


<syntaxhighlight lang="shell-session">
<syntaxhighlight lang="bash">
$ cd /tmp
cd /tmp
$ git clone https://github.com/AnalogJ/lexicon.git
curl -LO https://raw.githubusercontent.com/AnalogJ/lexicon/master/examples/dehydrated.default.sh
$ sudo cp lexicon/examples/dehydrated.default.sh /usr/sbin/lexicon-dehydrated.default.sh
sudo install -g root -m 0755 -o root dehydrated.default.sh /usr/sbin/lexicon-dehydrated.default.sh
</syntaxhighlight>
</syntaxhighlight>


第122行: 第129行:
</syntaxhighlight>
</syntaxhighlight>


 如果是使用<code>dns-01</code>(像是Wildcard),需要在環境變數裡提供對應的API token:
 如果是使用<code>dns-01</code>(像是Wildcard), 可能 需要在環境變數裡提供對應的API token (給[[lexicon]]使用)


<syntaxhighlight lang="shell-session">
<syntaxhighlight lang="shell-session">
第128行: 第135行:
</syntaxhighlight>
</syntaxhighlight>


 另外因為lexicon在設定DNS的值之後,預設會停30秒才會跑下一步,會比較慢, 請耐心
 另外因為lexicon在設定DNS的值之後,預設會停30秒才會跑下一步,會比較慢, 需要 一下才會知道結果。
 
== 自動更新 ==
上面提到更新的指令可以放到<code>/etc/cron.weekly</code>內執行,並且透過傳回值可以判斷是否有更新,然後重跑[[nginx]]或是[[Postfix]](以及其他有用到的服務)。
 
像是:
 
<syntaxhighlight lang="bash">
#!/bin/bash
export PATH=/usr/sbin:/usr/bin:/bin:"${PATH}"
sleep $(expr $(printf "%d" "0x$(hostname | md5sum | cut -c 1-8)") % 86400); dehydrated -c && ( service nginx reload; service postfix reload )
</syntaxhighlight>
 
或是:
 
<syntaxhighlight lang="bash">
#!/bin/bash
export PATH=/usr/sbin:/usr/bin:/bin:"${PATH}"
sleep $(expr $(printf "%d" "0x$(hostname | md5sum | cut -c 1-8)") % 86400); PROVIDER=digitalocean LEXICON_DIGITALOCEAN_TOKEN=x dehydrated -c -k /usr/sbin/lexicon-dehydrated.default.sh --challenge dns-01 && ( service nginx reload; service postfix reload )
</syntaxhighlight>
 
其中:
* <code>sleep</code>片段是為了同一個時間連到[[Let's Encrypt]]的伺服器造成類似DDoS的效果。
* <code>sleep</code>後面不使用隨機變數而是使用<code>hostname</code>與<code>md5sum</code>計算是為了隨機打散,但又要避免很湊巧一堆機器同時打Let's Encrypt的伺服器。
 
== 其他 ==
這邊主要是我的個人想法,放在最後避免干擾只是想要學設定方法的讀者。
 
dehydrated的相依性較少,僅需[[Bash]]、[[OpenSSL]]與[[curl]],這三個套件在蠻多[[Linux]]作業系統內已經內建,這對於自動化環境帶來的負擔會比較少(指的是[[Puppet]]或是[[Chef]]這類工具),同時也避免了套件版本互相影響的問題


== 後續 ==
  目前比較大 問題在於申請Wildcard certificate時,因為需要透過<code>dns-01</code> 申請 而這常常會用到[[lexicon]] (因為其他使用Shell Script的DNS操作軟體支援度比較低)。但lexicon使用[[Python]] 撰寫而引 了大量套件,這違背了使用dehydrated 本意(輕量 )。
上面提到更新 指令可以放到<code>/etc/cron.weekly</code> 內執行 透過傳回值可以判斷是否有更新,然後重跑[[nginx]] 或是[[Postfix]] (以及其他有 服務 )。


== 參考資料 ==
== 參考資料 ==
第138行: 第172行:
== 外部連結 ==
== 外部連結 ==
* {{Official|https://dehydrated.de/}}
* {{Official|https://dehydrated.de/}}
* [https://launchpad.net/~gslin/+archive/ubuntu/dehydrated PPA for dehydrated : Gea-Suan Lin]
* [https://launchpad.net/~gslin/+archive/ubuntu/dehydrated-lite PPA for dehydrated (lite) : Gea-Suan Lin]
* [https://github.com/AnalogJ/lexicon AnalogJ/lexicon: Manipulate DNS records on various DNS providers in a standardized way.]


[[Category:軟體]]
[[Category:軟體]]

2018年10月28日 (日) 15:59的版本

dehydrated
原作者 Lukas Schauer
开发状态 运行中
编程语言 Shell Script
许可协议 MIT license
网站 dehydrated.de
源代码库 github.com/lukas2511/dehydrated

dehydrated是一套支援ACME协定的软件套件(目前主要是由Let's Encrypt提供服务)。

特色

相较于官方推广的Certbot使用Python撰写,dehydrated仅使用Shell Script与OpenSSLcurl的指令就可以执行,这些指令在大多数系统中都已经提供。

安装

Ubuntu 17.10之后的版本(包含即将出版的18.04)的APT内有dehydrated[1]可以装,但因为我自己包了一包只有执行档的(比较小),可以透过PPA安装:

sudo add-apt-repository ppa:gslin/dehydrated-lite
sudo apt update
sudo apt install dehydrated-lite

另外也可以直接去官方网站上下载档案,仅需下载dehydrated档案。我建议把这个档案放到/usr/sbin/下。

基本设定

dehydrated在侦测到/etc/dehydrated/config/usr/local/etc/dehydrated/config时(两个都有时前者优先),会将/etc/dehydrated或是/usr/local/etc当作设定目录,所以我们需要产生/etc/dehydrated/config,目前里面不需要有东西:

sudo mkdir /etc/dehydrated
sudo touch /etc/dehydrated/config

进阶设定

这边的设定都是选择性设定,进阶使用者可以修改dehydrated预设值,对安全性与效能的参数进行调整。

config内可以设定开启凭证内标示一定要开OCSP Stapling:

OCSP_MUST_STAPLE=yes

config内可以设定KEYSIZE,预设是4096,可以改成2048:

KEYSIZE=2048

域名设定

认证可以透过http-01或是dns-01的协定。无论是那种,都是在domains.txt内设定要申请的域名,里面一行就是一张凭证,一行如果有多个域名就是将这些域名申请到同一个凭证里:

一张凭证一个域名

一行放一个域名,将需要申请的域名放到domains.txt内:

cd /etc/dehydrated
echo 'blog.gslin.org' | sudo tee -a domains.txt
echo 'wiki.gslin.org' | sudo tee -a domains.txt

一张凭证多个域名

将想要放在同一张凭证的域名放在同一行,一样是domains.txt内:

cd /etc/dehydrated
echo 'blog.gslin.org wiki.gslin.org' | sudo tee -a domains.txt

Wildcard

Wildcard的认证一定要有带有一个主域名(没有*):

cd /etc/dehydrated
echo 'gslin.org *.gslin.org' | sudo tee -a domains.txt

认证设定

Domain-validated certificate(即DV,非Wildcard的)的可以用http-01或是dns-01的方式认证。Wildcard的只能使用dns-01的方式认证。

http-01

dehydrated预设会用/var/www/dehydrated/作为认证目录,需要将网页的/.well-known/acme-challenge/指到这边。以nginx的设定会像是这样:

server {
    # ...

    # map /var/www/dehydrated/
    location /.well-known/acme-challenge/ {
        alias /var/www/dehydrated/;
    }
}

Apache的会是这样(放到/etc/apache2/conf-available/dehydrated.conf内,再用a2enconf dehydrated启用):

Alias /.well-known/acme-challenge /var/www/dehydrated
<Directory /var/www/dehydrated>
    Options None
    AllowOverride None
    Require all granted
</Directory>

dns-01

dns-01会需要使用TXT record认证。这边会使用lexicon(不适合用pyenv安装,因为通常使用root权限跑dehydrated,这会使得环境无法取得),这需要另外安装。

另外dehydrated需要lexicon的examples/dehydrated.default.sh(将dehydrated的hook命令转给lexicon使用),所以需要下载这个档案,复制到/usr/sbin/lexicon-dehydrated.default.sh以便后续更新:

cd /tmp
git clone https://github.com/AnalogJ/lexicon.git
sudo cp lexicon/examples/dehydrated.default.sh /usr/sbin/lexicon-dehydrated.default.sh

或是直接用GitHub提供的连结下载:

cd /tmp
curl -LO https://raw.githubusercontent.com/AnalogJ/lexicon/master/examples/dehydrated.default.sh
sudo install -g root -m 0755 -o root dehydrated.default.sh /usr/sbin/lexicon-dehydrated.default.sh

执行

第一次需要同意条款:

$ sudo dehydrated --register --accept-terms

之后就可以用-c自动更新:

$ sudo dehydrated -c

如果是使用dns-01(像是Wildcard),可能需要在环境变数里提供对应的API token(给lexicon使用):

$ sudo PROVIDER=digitalocean LEXICON_DIGITALOCEAN_TOKEN=x dehydrated -c -k /usr/sbin/lexicon-dehydrated.default.sh --challenge dns-01

另外因为lexicon在设定DNS的值之后,预设会停30秒才会跑下一步,会比较慢,需要等一下才会知道结果。

自动更新

上面提到更新的指令可以放到/etc/cron.weekly内执行,并且透过传回值可以判断是否有更新,然后重跑nginx或是Postfix(以及其他有用到的服务)。

像是:

#!/bin/bash
export PATH=/usr/sbin:/usr/bin:/bin:"${PATH}"
sleep $(expr $(printf "%d" "0x$(hostname | md5sum | cut -c 1-8)") % 86400); dehydrated -c && ( service nginx reload; service postfix reload )

或是:

#!/bin/bash
export PATH=/usr/sbin:/usr/bin:/bin:"${PATH}"
sleep $(expr $(printf "%d" "0x$(hostname | md5sum | cut -c 1-8)") % 86400); PROVIDER=digitalocean LEXICON_DIGITALOCEAN_TOKEN=x dehydrated -c -k /usr/sbin/lexicon-dehydrated.default.sh --challenge dns-01 && ( service nginx reload; service postfix reload )

其中:

  • sleep片段是为了同一个时间连到Let's Encrypt的服务器造成类似DDoS的效果。
  • sleep后面不使用随机变数而是使用hostnamemd5sum计算是为了随机打散,但又要避免很凑巧一堆机器同时打Let's Encrypt的服务器。

其他

这边主要是我的个人想法,放在最后避免干扰只是想要学设定方法的读者。

dehydrated的相依性较少,仅需BashOpenSSLcurl,这三个套件在蛮多Linux操作系统内已经内建,这对于自动化环境带来的负担会比较少(指的是Puppet或是Chef这类工具),同时也避免了套件版本互相影响的问题。

目前比较大的问题在于申请Wildcard certificate时,因为需要透过dns-01申请,而这常常会用到lexicon(因为其他使用Shell Script的DNS操作软件支援度比较低)。但lexicon使用Python撰写而引用了大量套件,这违背了使用dehydrated的本意(轻量)。

参考资料

外部链接