2014年12月11日木曜日

groovyとDocker Remote APIでcontainerのログを取得する

groovyとDocker Remote APIでcontainerのログを取得するには、以下のようなコードを実行します。

サンプルコード
@Grab(group='org.apache.httpcomponents', module='httpclient', version='4.3.5')
import org.apache.http.client.methods.*
import org.apache.http.impl.client.*
import org.apache.http.message.*
import org.apache.http.auth.*
import groovy.json.*

def host = "192.168.1.215" // replace this
def port = 4243
def containerId = "your-container-id"

def httpclient = new DefaultHttpClient()
httpclient.withCloseable {

  def opts = "stderr=1&stdout=1&timestamps=1&follow=0&tail=20"
  def method = new HttpGet(
    "http://${host}:${port}/containers/${containerId}/logs?${opts}"
  )
  def response = httpclient.execute(method)
  println response.getStatusLine().getStatusCode()

  response.getEntity().getContent().text.eachLine {
    println it.substring(8)
  }
}
Docker Remote APIを使用可能にする方法
ubuntuの場合、/etc/default/dockerに以下のように記述します。
DOCKER_OPTS="-H tcp://0.0.0.0:4243 -H unix:///var/run/docker.sock -d"
そのあと、dockerを再起動します。
sudo service docker restart

動作環境
Docker 1.2.0

0 件のコメント:

コメントを投稿