
私はデプロイツールのためにFabricに取り組んでおり、複数のホストにコマンドを配布しています。しかし、fabfile.pyで複雑なホストを定義する方法がわかりません。
たとえば、サーバーが 4 台あります。serverA、serverB、serverC、serverD
def prod():
env.hosts = ["serverA', "serverB" ]
def dev():
env.hosts = ["serverC' "serverD"]
def all():
prod()
dev()
再度定義せずにすべてのホストでコマンドを実行することは可能ですか?
EX: fab all {command}
答え1
定義を見てみましょう役割あなたの環境に合わせて。
from fabric.api import env, run
from fabric.decorators import task
env.roledefs = {
'prod': ['ServerA', 'ServerB'],
'dev': ['ServerC', 'ServerD'],
'envC': ['ServerE', 'ServerF']
}
env.roledefs['all'] = [h for r in env.roledefs.values() for h in r]
@task
def hostname():
run('hostname -f')
つまり、次のようにファブリック呼び出しを発行する必要があることになります。
fab -R prod hostname
fab -R dev hostname
fab -R all hostname
fab -R dev,envC hostname
答え2
より動的な代替ソリューション... fabfile に静的構成はなく、bash を使用します。
mfab() {
hosts=()
while [ "$#" != 0 ]; do
if [ "$1" = -- ]; then
shift
break
fi
hosts+=("$1")
shift
done
list=$(echo "${hosts[@]}" | tr ' ' ',')
fab -H "$list" "$@"
}
ドライランを実行する方法は次のとおりです。テストの前にこれを実行してください。
fab() { echo fab "$@"; }
例 1: シェル拡張/globbinb/その他任意のものを使用した任意のサイズのリスト
mfab node{A..D}{01..05} -- example_command
次のようなコマンドを実行します:
fab -H nodeA01,nodeA02,nodeA03,nodeA04,nodeA05,nodeB01,nodeB02,nodeB03,nodeB04,nodeB05,nodeC01,nodeC02,nodeC03,nodeC04,nodeC05,nodeD01,nodeD02,nodeD03,nodeD04,nodeD05 example_command
例 2: 7 台の新しいマシンを導入したところ、2 台ごとに 1 台のマシンが壊れているため、コマンドを実行して確認/修正したいと考えています。
mfab node{100..106..2} -- example_command
次のようなコマンドを実行します:
fab -H node100,node102,node104,node106 example_command
例 3:--
ファブリック自体で使用されるオプションを含むその他のオプション:
mfab node{01..10} -- -P -- uname -a