一、安装docker
yum install docker
查一下安装版本
docker --version
二、启动docker
selinux须要关闭
systemctl enable docker.service
systemctl start docker.servicehtml
vi /etc/docker/daemon.json
{
"registry-mirrors": ["https://registry.docker-cn.com"]
}
须要重启docker生效node
docker images
其中咱们能够根据REPOSITORY来判断这个镜像是来自哪一个服务器linux
若是没有 / 则表示官方镜像,相似于username/repos_name表示Github的我的公共库,相似于regsistory.example.com:5000/repos_name则表示的是私服。nginx
IMAGE ID列实际上是缩写,要显示完整则带上--no-trunc选项web
docker search nginx
搜索的范围是官方镜像和全部我的公共镜像。NAME列的 / 后面是仓库的名字。docker
docker pull nginxjson
docker rmi image-id
须要先删除应用这个镜像的dockerbash
交互式
docker -ti run --restart=always --name nginx1 -d -p 6378:80 -v /tmp/nginx:/tmp/:ro nginx服务器
--name 运行一个名字为nginx1的容器 nginx 使用nginx镜像 -p 将Docker中的nginx的80端口映射到本机的6378端口。 -d 后台执行 --restart=always 自动重启容器 -t:进入终端 -i:得到一个交互式的链接,经过获取container的输入
-v 将主机上的目录挂载到容器的目录
#不指定的时候默认是rw模式,能够用docker inspect查看容器的属性,能够看到关于挂载目录的详细参数。spa
1. 默认状况不使用:rw :ro选项,Mode的值就是空字符串,可是rw是true“。
2. 使用:rw选项,Mode的值就是”rw”。
3. 使用:ro选项,Mode的值就是”ro”。
rw:宿主主机和docker互相均可以读写同步,均可以写,均可以互相同步。
ro:这个时候docker内不能写,宿主主机写了能够同步到容器内。
docker stop container-name/container-id
经过容器名称或者容器id启动/中止容器
docker ps -a #显示全部容器,包括不运行的
docker ps #显示运行中的容器
docker info #查看容器和镜像的数量、以及docker的基本信息等资料
docker rm container-name/container-id
只能删除已经不是up状态的docker
使用container命令,当退出container后,container仍然在后台运行,命令使用方法以下: docker exec -it goofy_almeida /bin/bash 退出容器能够用crtl+D或者exit命令退出 日常的容器通常均可以执行/bin/bash,非常alpine没有,改为 docker exec -it 镜像id sh 就行了。 -u root #进入容器的用户
journalctl -u docker.service #能够加-f实时查看日志
docker logs 容器名 #查看容器运行日志,也能够加参数-t 带上时间戳
docker top 容器名
Docker的镜像和容器能够有两种方式来导出
docker save #ID or #Name docker export #ID or #Name
docker save和docker export的区别:
对于Docker Save方法,会保存该镜像的全部历史记录 对于Docker Export 方法,不会保留历史记录,即没有commit历史 docker save保存的是镜像(image),docker export保存的是容器(container); docker load用来载入镜像包,docker import用来载入容器包,但二者都会恢复为镜像; docker load不能对载入的镜像重命名,而docker import能够为镜像指定新名称。
save命令:
docker save [options] images [images...] 示例 docker save -o nginx.tar nginx:latest 或 docker save > nginx.tar nginx:latest 其中-o和>表示输出到文件,nginx.tar为目标文件,nginx:latest是源镜像名(name:tag)
load命令:
docker load [options] 示例 docker load -i nginx.tar 或 docker load < nginx.tar 其中-i和<表示从文件输入。会成功导入镜像及相关元数据,包括tag信息
export命令:
docker export [options] container 示例 docker export -o nginx-test.tar nginx-test #导出为tar docker export #ID or #Name > /home/export.tar 其中-o表示输出到文件,nginx-test.tar为目标文件,nginx-test是源容器名(name)
import命令:
docker import [options] file|URL|- [REPOSITORY[:TAG]] 示例 docker import nginx-test.tar nginx:imp 或 cat nginx-test.tar | docker import - nginx:imp
ocker cp :用于容器与主机之间的数据拷贝。
将主机/www/runoob目录拷贝到容器96f7f14e99ab的/www目录下。 docker cp /www/runoob 96f7f14e99ab:/www/ 将主机/www/runoob目录拷贝到容器96f7f14e99ab中,目录重命名为www。 docker cp /www/runoob 96f7f14e99ab:/www 将容器96f7f14e99ab的/www目录拷贝到主机的/tmp目录中。 docker cp 96f7f14e99ab:/www /tmp/
docker exec -d registry touch /123.txt
docker exec命令能够在容器内部额外的启动新进程,-d后面要加容器名以及要执行的命令
docker volume --help Commands: create 建立一个数据卷 inspect 打印一个或多个数据卷的详细信息 ls 列出全部数据卷 prune 删除全部未使用的数据卷 rm 删除一个或多个数据卷
建立一个volume
docker volume create www-data
查看数据卷在宿主机上的路径:
[root@node1 volumes]# docker inspect www-data [ { "Driver": "local", "Labels": {}, "Mountpoint": "/var/lib/docker/volumes/www-data/_data", "Name": "www-data", "Options": {}, "Scope": "local" } ] [root@nod
注:每建立一个volume,docker会在/var/lib/docker/volumes/下建立一个子目录,默认状况下目录名是一串UUID。若是指定了名称,则目录名是volume名称。volume里的数据都存储在这个子目录的_data目录下。
把卷挂载到容器
docker run --rm --name web -p 80:80 -v www-data:/usr/share/nginx/html:ro -d nginx
--privileged=false
container内的root拥有真正的root权限。不然,container内的root只是外部的一个普通用户权限。privileged启动的容器,能够看到不少host上的设备,而且能够执行mount。甚至容许你在docker容器中启动docker容器。