docker环境安装完毕之后,建议到 http://dashboard.daocloud.io 注册一下,这是一个国内的同步了 官方dockerHub所有镜像的库,另外还集成了一些社区镜像等等,同时也支持组织私有镜像库,当然后者是收费的。
从这个源下载镜像的速度会快不少,否则直连docker.io速度实在感人。拉取镜像前需要在命令行docker login daocloud.io
登陆,所以要保存好账户和密码。
在linux命令行执行以下命令,将--registry-mirror加入或替换到docker配置文件/etc/docker/daemon.json 中。
curl -sSL https://get.daocloud.io/daotools/set_mirror.sh | sh -s http://f1361db2.m.daocloud.io
PS:也可以考虑阿里云的容器镜像服务,原理相同。
启动容器
docker image list = docker images
docker images [OPTIONS] [NAME]
OPTIONS说明:
-a :列出本地所有的镜像(含中间映像层,默认情况下,过滤掉中间映像层);
--digests :显示镜像的摘要信息;
-f :显示满足条件的镜像;
--format :指定返回值的模板文件;
--no-trunc :显示完整的镜像信息;
-q :只显示镜像ID。
docker run [OPTIONS] IMAGE [COMMAND] [ARG...]
OPTIONS说明:
-a stdin: 指定标准输入输出内容类型,可选 STDIN/STDOUT/STDERR 三项;
-d: 后台运行容器,并返回容器ID;
-i: 以交互模式运行容器,通常与 -t 同时使用;
-t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用;
--name="nginx-lb": 为容器指定一个名称;
--dns 8.8.8.8: 指定容器使用的DNS服务器,默认和宿主一致;
--dns-search example.com: 指定容器DNS搜索域名,默认和宿主一致;
-h "mars": 指定容器的hostname;
-e username="ritchie": 设置环境变量;
--env-file=[]: 从指定文件读入环境变量;
--cpuset="0-2" or --cpuset="0,1,2": 绑定容器到指定CPU运行;
-m :设置容器使用内存最大值;
--net="bridge": 指定容器的网络连接类型,支持 bridge/host/none/container: 四种类型;
--link=[]: 添加链接到另一个容器;
--expose=[]: 开放一个端口或一组端口;
进入容器的四种方式
一、docker exec -it 容器id或名称 bash
docker exec -it redis bash
这种方式个人比较推荐
- -i 只用-i时,由于没有分配伪终端,看起来像pipe执行一样。但是执行结果、命令
返回值都可以正确获取。 - -t 表示分配一个交互式伪终端,可以输入命令,但获取不到返回结果
- redis是容器名称,即containerId或启动镜像时指定的-name
- bash的进入容器后执行/bin/bash,打开一个命令行
所以一般 -i 和 -t 一起用
二、docker attach 容器id或名称 bash
docker attach -it redis bash
可以attach到一个已经运行的容器的stdin,然后进行命令执行的动作。
官方解释:attach Attach local standard input, output, and error streams to a running container
谷歌翻译:attach 附加将本地标准输入,输出和错误流附加到正在运行的容器
通俗解释:将终端依附到容器上(其实就是进入容器)
可以认为这是一个过时的命令,更多的docker用户会考虑使用docker exec来实现相同的功能,但是出于docker官方并没有删除这个命令,我们还是有必要学习一下的。
但是需要注意的是,如果从这个stdin中exit,会导致容器的停止。而且所有和这个容器的stdin是共享的,一个 终端阻塞时,其他终端也会阻塞。所以,非常不建议这个用法。
三、ssh docker容器的ip
需要给容器安装ssh server,能保证多人进入容器且相互之间不受干扰。但据说不建议使用。
四、使用nsenter进入Docker容器
nsenter可以访问另一个进程的名称空间,使用docker inspect来拿到容器的进程id。
但安装是个较麻烦的过程。
综上,exec大法好!
停止容器
docker ps|grep 容器名
得到容器id containerId
docker stop {containerId}
重新启动已创建的容器
docker ps|grep 容器名
得到容器id containerId
docker start {containerId}
nginx容器操作示例
一、从容器库拉取容器
Nginx DaoCloud地址
注册后在宿主机用以下命令登陆
docker login daocloud.io
拉取镜像
docker pull daocloud.io/library/nginx:perl
启动镜像
1.--name 指定别名
2.-p 将容器在DockerFile中expose的80端口链接到宿主机的81端口,可使用多个-p链接多个端口
3.-v 绑定volume,将容器内nginx的静态文件地址链接到宿主机的某个地址(不存在将自动创建),将容器内的该目录/文件,替换为宿主机的该目录/文件内容,修改宿主机文件可以立即体现到容器中,反之在容器中修改也可以立即体现到宿主机中。可使用多个-v链接挂载多个文件。docker推荐挂载目录,不推荐挂载文件。
4.-d 后台启动
docker run --name my-nginx -p 81:80 -p 82:80 -v /my/html:/usr/share/nginx/html -d daocloud.io/nginx
查看容器
docker ps | grep my-nginx
进入容器
docker exec -it my-index bash