gohanを触ってみる

以下からgohanのバイナリソースをダウンロードし、中身を解凍する。

https://github.com/cloudwan/ansible-gohan/releases


# unzip gohan_linux-amd64.zip
# cd gohan_linux-amd64
# ./gohan server --config-file etc/gohan.yaml

これだけで一応gohanが動き始める。以下のurlにアクセスして動きを確かめることができる。

初期状態ではID: admin  Passward: admin でログインが可能。

https://localhost:9443/webui/

ちなみにURLの最後のスラッシュを書き忘れるとページが表示されないので、ご注意を。

 

続いてetcdと連携させる。

gohan設定した情報を分散key/valueストアであるetcdに書き出し、etcdの情報を元にシステムを構築する仕組みを作ってみる。

Ubuntuへetcdをインストール


    # curl -L  https://github.com/coreos/etcd/releases/download/v2.0.9/etcd-v2.0.9-linux-amd64.tar.gz -o etcd-v2.0.9-linux-amd64.tar.gz
    #tar xzvf etcd-v2.0.9-linux-amd64.tar.gz
    #cd etcd-v2.0.9-linux-amd64
    #cp etcd /bin/
    #cp etcdctl /bin/

etcdのインストールが完了したので、etcdを起動する。


    #etcd

 gohanとの連携のために./etc/gohan.yamlファイルを編集し、etcdの項目のコメントアウトを外し、gohanをリスタートする。

ためしにgohanのwebUIから[network]や[server]の項目を追加し、etcdのに書き込まれていることを確認する。etcdctlコマンドを使うと/config/v2.0/以下にUIで設定したnetworks/id1が書き込まれていることがわかる。


# etcdctl ls  --recursive
/monitoring
/gohan
/gohan/cluster
/gohan/cluster/lockstate
/gohan/cluster/lockmonitoring
/gohan/cluster/sync
/config
/config/v2.0
/config/v2.0/networks
/config/v2.0/networks/id1
/config/v2.0/servers
/mykey
/state

 

 また、同じくetcdctlコマンドでwebUIから設定した内容を確認することができる。


# etcdctl --peers=http://127.0.0.1:4001 get /config/v2.0/networks/id1
{"body":"{\"description\":\"mizukoshi-description\",\"id\":\"id1\",\"name\":\"mizukoshi\",\"tenant_id\":\"tenant12\"}","version":1}

 githubで公開されているpython-etcdを使えば、pythonプログラム内でetcdを扱うことができて非常に便利だった。

github.com