はじめに
Dockerをやってみたいと思ったけど、何から始めたら良いのかわからず、
周りに聞いたら下記2点の回答をもらいました。
- Docker本家のサイトを見る (http://docs.docker.com/linux/started/)
- 書籍を読む(Docker実践入門 by 中井先生)
書籍を読み始めてみましたが、あまりぴんと来なかったので、Docker本家のサイトにシフト。
多分、自分はまず手を動かしたいタイプだからかも。
そんなわけで、Hello Worldを試してみることにしました。
しかし、社内環境ではproxyがあるので、ハマる…。
環境
- OS: Ubuntu14.04LTS
Hello Worldの手順
Dockerのインストール
- インストール
$ wget -qO- https://get.docker.com/ | sh
...
If you would like to use Docker as a non-root user, you should now consider
adding your user to the "docker" group with something like:
sudo usermod -aG docker tiffany
Remember that you will have to log out and back in for this to take effect!
- 確認
$ docker -v
Docker version 1.8.3, build f4bf5c7
- docker起動 (サイトには記載がなかったけど、起動が必要)
$ sudo service docker start
docker start/running, process 32503
Hello Worldを実行
- 実行したらエラーに…。
$ docker run hello-world
Post http:///var/run/docker.sock/v1.20/containers/create: dial unix /var/run/docker.sock: permission denied.
*Are you trying to connect to a TLS-enabled daemon without TLS?
*Is your docker daemon up and running?
- sudoをつけて実行してみたら
Network timed out while trying to connect to https://index.docker.io/v1/repositories/library/hello-world/images. You may want to check your internet connection or if you are behind a proxy.
ますますわからない…。
検索してみるとdocker-machineを入れるとかなんとか…(試してもダメだったけど…)
http://stackoverflow.com/questions/31990757/network-timed-out-while-trying-to-connect-to-https-index-docker-io
原因は、proxyだった!
proxyの設定
- proxyの定義ファイル
こんなファイルがあることすら知らず…。コメントアウトしているところを適宜変更。
$ sudo vi /etc/default/docker
- docker再起動
$ sudo service docker restart
docker stop/waiting
docker start/running, process 9196
Hello World再び
- 再度実行したけど、変わらず。
dockerグループにログインユーザ(tiffany)が入っていないためsudoが必要。
dockerグループにログインユーザを入れる方法はまた次回。
$ docker run hello-world
Post http:///var/run/docker.sock/v1.20/containers/create: dial unix /var/run/docker.sock: permission denied.
*Are you trying to connect to a TLS-enabled daemon without TLS?
*Is your docker daemon up and running?
- sudo を入れると hello-world が動いた!
$ sudo docker run hello-world
Unable to find image 'hello-world:latest' locally
latest: Pulling from library/hello-world
b901d36b6f2f: Pull complete
0a6ba66e537a: Pull complete
Digest: sha256:517f03be3f8169d84711c9ffb2b3235a4d27c1eb4ad147f6248c8040adb93113
Status: Downloaded newer image for hello-world:latest
Hello from Docker.
This message shows that your installation appears to be working correctly.
To generate this message, Docker took the following steps:
1. The Docker client contacted the Docker daemon.
2. The Docker daemon pulled the "hello-world" image from the Docker Hub.
3. The Docker daemon created a new container from that image which runs the
executable that produces the output you are currently reading.
4. The Docker daemon streamed that output to the Docker client, which sent it
to your terminal.
To try something more ambitious, you can run an Ubuntu container with:
$ docker run -it ubuntu bash
Share images, automate workflows, and more with a free Docker Hub account:
https://hub.docker.com
For more examples and ideas, visit:
https://docs.docker.com/userguide/