因為碰 SaltStack,而官方建議用的格式是 YAML (雖然也支援 JSON,但文件幾乎都是 YAML),所以被迫要學一堆奇怪的 YAML hack,在官方文件上甚至寫了一篇「YAML Idiosyncrasies」讓大家參考,用 Idiosyncrasies 這個詞彙比較中性,但需要專文來寫就可以想像 YAML 有多 !@#$%^...
然後文章裡面也發現 SaltStack 在亂搞,於是就快起笑了...
首先是建議 indent 為 2 spaces,另外禁用 tab,這些到是沒什麼好抱怨的。但 dict 的設計就讓人崩潰,像是這樣的結構:
foo:
- bar:
baz1: abc
baz2: def
你以為對應的 JSON 是:
{
"foo": {
"bar": {
"baz1": "abc",
"baz2": "def"
}
}
}
但實際對應的 JSON 中,bar、baz1、baz2 視同一層:
{
"foo": {
"bar": null,
"baz1": "abc",
"baz2": "def"
}
}
因為其實對應的 YAML 是:
foo:
- bar:
- baz1: abc
- baz2: def
你就不能把最上面的 YAML 定義成 syntax error 嗎... =_=
接下是 SaltStack 的惡搞時間,因為 YAML parser 會把 644 當作數字傳進去,所以這樣的設定:
/etc/vimrc:
file:
- managed
- source: salt://edit/vimrc
- mode: 644
SaltStack 會收到 644 (十進位),而如果你寫成 0644 時,就會被讀成八進位,也就是 420 (十進位):
/etc/vimrc:
file:
- managed
- source: salt://edit/vimrc
- mode: 0644
我覺得後面這個是比較正確的寫法,所以應該要會動,但 SaltStack 對這部份 workaround,會變成 chmod 420 /etc/vimrc
,然後就噴飯了...
另外 2013_01_12
這種字串會被解讀成 20130102 (十進位),這會不會太歡樂...
反正用下去後應該會再踩更多地雷,繼續看下去吧...