一、测试环境
系统: ubuntu 14.04
docker 1.6.2
二、安装docker并下载镜像(不到200M)
sudo apt install docker docker.io
sudo docker pull centos:latest
三、配置centos7
sudo su -
docker run -itd cnetos:latest /bin/bash
docker ps
yum -y install passwd openssl openssh-server
#启动sshd会报错。
passwd root
/usr/sbin/sshd
#使用以下命令,也可以关闭UsePAM no(注意看上面一大段的英文说明)。
ssh-keygen -t rsa -f /etc/ssh/ssh_host_rsa_key
ssh-keygen -t ecdsa -f /etc/ssh/ssh_host_ecdsa_key
ssh-keygen -t ed25519 -f /etc/ssh/ssh_host_ed25519_key
systemctl enable sshd
/usr/sbin/sshd -D
Ctrl + p + q //退出但不停止容器。
#可以先docker stop 容器ID,也可以直接commit
docker commit <CONTAINER ID> centos:7.3
docker rm <CONTAINER ID>
docker rmi <IMAGE ID> //删除centos:latest
docker run -itd centos:7.3 /usr/sbin/sshd -D
#可以docker attach <CONTAINER> 看看IP ,用ping 看看一般是上个容器IP末位+1
ssh root@172.17.0.5 //输入设置好的密码就进入了centos7
四、常用命令
杀死所有正在运行的容器
docker kill $(docker ps -a -q)
删除所有已经停止的容器
docker rm $(docker ps -a -q)
删除所有未打 dangling 标签的镜像
docker rmi $(docker images -q -f dangling=true)
删除所有镜像
docker rmi $(docker images -q)
还有一些网上找了的东东
其中<>阔起来的参数为必选,[]阔起来为可选
- docker version 查看docker的版本号,包括客户端、服务端、依赖的Go等
- docker info 查看系统(docker)层面信息,包括管理的images, containers数等
- docker search 在docker index中搜索image
- docker pull 从docker registry server 中下拉image
- docker push 推送一个image或repository到registry
- docker push :TAG 同上,指定tag
- docker inspect 查看image或container的底层信息
- docker images TODO filter out the intermediate image layers (intermediate image layers 是什么)
- docker images -a 列出所有的images
- docker ps 默认显示正在运行中的container
- docker ps -l 显示最后一次创建的container,包括未运行的
- docker ps -a 显示所有的container,包括未运行的
- docker logs 查看container的日志,也就是执行命令的一些输出
- docker rm 删除一个或多个container
- docker rm `docker ps -a -q` 删除所有的container
- docker ps -a -q | xargs docker rm 同上, 删除所有的container
- docker rmi 删除一个或多个image
- docker start/stop/restart 开启/停止/重启container
- docker start -i 启动一个container并进入交互模式
- docker attach attach一个运行中的container
- docker run 使用image创建container并执行相应命令,然后停止
- docker run -i -t /bin/bash 使用image创建container并进入交互模式, login shell是/bin/bash
- docker run -i -t -p 将container的端口映射到宿主机的端口
- docker commit [repo:tag] 将一个container固化为一个新的image,后面的repo:tag可选
- docker build
- 寻找path路径下名为的Dockerfile的配置文件,使用此配置生成新的image
- docker build -t repo[:tag] 同上,可以指定repo和可选的tag
- docker build - 使用指定的dockerfile配置文件,docker以stdin方式获取内容,使用此配置生成新的image
- docker ps 也可以看到