Skip to content

Docker client for Scala backed by http4s, fs2, cats & circe.

License

Notifications You must be signed in to change notification settings

bhuemer/docker4s

Repository files navigation

docker4s

CircleCI

Docker client for Scala backed by http4s, fs2, cats & circe.

Installation

docker4s is available for Scala 2.12 on Sonatype OSS Snapshots at the following coordinates:

Http4s

resolvers +=
  "Sonatype OSS Snapshots" at "https://oss.sonatype.org/content/repositories/snapshots"

libraryDependencies ++= Seq(
  "org.docker4s" % "docker-client" % "0.1-SNAPSHOT",
  "org.docker4s" % "docker-client-http4s" % "0.1-SNAPSHOT",
  "io.netty" % "netty-transport-native-kqueue" % "4.1.33.Final" classifier "osx-x86_64"
  // Or, if you want to use UNIX domain sockets on `epoll`-based systems like Linux:
  // "io.netty" % "netty-transport-native-epoll" % "4.1.33.Final" classifier "linux-x86_64"
)

The second dependency is optional and only necessary when you want to use UNIX domain sockets to communicate with the Docker host (see also Netty project: Native transports).

Akka HTTP

resolvers +=
  "Sonatype OSS Snapshots" at "https://oss.sonatype.org/content/repositories/snapshots"

libraryDependencies ++= Seq(
  "org.docker4s" % "docker-client" % "0.1-SNAPSHOT",
  "org.docker4s" % "docker-client-akka" % "0.1-SNAPSHOT"
)

Usage example

The API is heavily inspired by the Docker client for Python and hopefully mostly self-explanatory. It's far from feature-complete and still in active development, but at the same time most of the crucial operations have been implemented already.

import cats.effect.{ExitCode, IO, IOApp}
import org.docker4s.DockerClient
import org.docker4s.api.Containers
import org.docker4s.api.Containers.LogParameter._
import org.docker4s.http4s.Http4sDockerClient

import scala.concurrent.ExecutionContext

object DockerApp extends IOApp {

  private implicit val ec: ExecutionContext = ExecutionContext.global

  override def run(args: List[String]): IO[ExitCode] = {
    // Uses environment variables to determine the Docker host, e.g. by default on a
    // MacOS X machine it'd be "unix:///var/run/docker.sock" without certificates.
    val clientResource = Http4sDockerClient.fromEnvironment[IO]
    clientResource.use({ client =>
      for {
        // Equivalent to `docker container ls`
        containers <- client.containers.list()
        _ = containers.foreach(container => println("Container: " + container))

        // Equivalent to `docker run hello-world`
        _ <- client.images.pull("hello-world").compile.drain
        container <- client.containers.create(image = "hello-world")
        _ <- client.containers.start(container.id)

        // Equivalent to `docker logs ${container.id}`
        _ <- client.containers.logs(container.id, stdout, stderr).evalTap[IO]({
          case Containers.Log(Containers.Stream.StdOut, message) => IO(System.out.println(message))
          case Containers.Log(Containers.Stream.StdErr, message) => IO(System.err.println(message))
        }).compile.drain
      } yield ExitCode.Success
    })
  }

}

About

Docker client for Scala backed by http4s, fs2, cats & circe.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages