您现在的位置是:首页 > 文章详情

Docker基础之四: Docker入门

日期:2015-12-13点击:400

Docker入门

对Docker感兴趣的朋友可以加我的微信ghostcloud2016,然后我把你加到我们的一个Docker爱好者群组里面。

首先我们检查docker是否安装成功:

root@gctest:~# docker info Containers: 3 Images: 18 Server Version: 1.9.0 Storage Driver: aufs Root Dir: /var/lib/docker/aufs Backing Filesystem: extfs Dirs: 24 Dirperm1 Supported: false Execution Driver: native-0.2 Logging Driver: json-file Kernel Version: 3.13.0-32-generic Operating System: Ubuntu precise (12.04.5 LTS) CPUs: 1 Total Memory: 979.2 MiB Name: gctest ID: 5RZM:ZIIU:OVNC:AS2Y:P6YZ:ZQBU:PUF2:7DR5:D3Y7:L6M5:X5RF:LQ6P WARNING: No swap limit support 

如果安装成功,会显示容器数量、镜像数量、docker版本等信息。可能的失败原因有:

docker: command not found 

这个是安装失败,参考上一节。

/var/lib/docker/repositories: permission denied 

这个可能是用户没有添加到docker组,参考上一节。

$ docker info Cannot connect to the Docker daemon. Is the docker daemon running on this host? 

这个是Daemon没有启动成功。

1 下载一个镜像

# Download an ubuntu image $ docker pull Ubuntu 

剖析:

  • 该命令首先检查本地有没有ubuntu镜像,如果没有默认会从Docker Hub进行拉取
  • 当下载成功会出现539c0211cd76: Download complete
  • 这个ID是一个缩写的ID,完整的ID可以通过下面的命令获取docker inspect 或者docker images –no-trunc=true

2 运行一个可交互的shell终端

$ docker run -i -t ubuntu /bin/bash 

剖析:

  • -i 表示启动一个可交互的容器
  • –t表示使用pseudo-TTY,关联到容器的stdin和stdout
  • 在终端中,如果输入exit命令将会停止当前容器;因此如果只是取消关联,可以键入ctrl-p或者ctrl-q
  • 你可以在其他终端通过docker ps –a查看已经运行的容器列表

3 运行一个长时间的程序

# Start a very useful long-running process $ JOB=$(docker run -d ubuntu /bin/sh -c "while true; do echo Hello world; sleep 1; done") # Collect the output of the job so far $ docker logs $JOB # Kill the job 稍微延迟点运行 $ docker kill $JOB 

剖析:

  • 本例启动了一个容器,而该容器会每隔1秒输出Helo World
  • –d 表示在后台运行
  • docker logs $JOB表示查看该容器的日志,就是查看标准输出stdout
  • docker kill $JOB表示停掉这个容器

4 查看容器

$ docker ps # 查看运行中的容器 $ docker ps -a # 查看所有容器 

5 容器操作

# 创建并启动容器 $ JOB=$(docker run -d ubuntu /bin/sh -c "while true; do echo Hello world; sleep 1; done") # 停止一个容器 $ docker stop $JOB # 启动一个已经创建的容器 $ docker start $JOB # 重启一个容器 $ docker restart $JOB # 停止一个容器 $ docker kill $JOB # 删除一个容器 $ docker stop $JOB # 必须先停止 $ docker rm $JOB 

6 导出服务端口

# 将4444端口从容器导出,在容器内部通过nc监听到4444端口(nc是一个简单的监听器,可以接收用户的输入) $ JOB=$(docker run -d -p 4444 ubuntu:12.10 /bin/nc -l 4444) # 通过docker port可以查看主机上哪一个端口映射到了容器的 4444端口(docker默认使用nat映射方式) $ PORT=$(docker port $JOB 4444 | awk -F: '{ print $2 }') # 向主机的端口,发送hello world $ echo hello world | nc 127.0.0.1 $PORT # 确认容器收到了hello world $ echo "Daemon received: $(docker logs $JOB)" 

剖析:

  • nc是一个简单的监听指定端口的程序
  • -p表示导出容器的指定端口,由于没有指定主机端口,因此是随机分配的
  • 外部程序可以通过主机的端口,间接访问容器的4444端口

7 提交(保存)容器到image

# Commit your container to a new named image $ docker commit <container> <some_name> # List your images $ docker images 

剖析:

容器运行一个Image时,是不会对image做修改的,而是在原始image上通过UnionFS增加了一个文件层用于读写,因此如果我们要想复用容器,就需要将容器commit成一个镜像。很多初学者会误以为启动一个容器后,原始镜像就会随之改变。

原文链接:https://yq.aliyun.com/articles/133
关注公众号

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。

持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。

文章评论

共有0条评论来说两句吧...

文章二维码

扫描即可查看该文章

点击排行

推荐阅读

最新文章