镜像相关的命令
镜像名称分为两部分组成:[repository]:[tag],tag就是镜像的版本。如果tag没有指定默认就是latest,表示最新版本的镜像。
data:image/s3,"s3://crabby-images/47acf/47acf8975f2db2c77c4faff24debfc139b3960b5" alt=""
查看docker命令的帮助信息
docker --help
具体某条命令的帮助信息
docker images --help
案例一:从DockerHub中拉取一个nginx镜像并查看
拉取docker nginx镜像命令:docker pull nginx
docker images 查看所有镜像命令
data:image/s3,"s3://crabby-images/8ace4/8ace4e4a416f19e698b6c2670facdc999be6a186" alt=""
docker images | grep nginx查找nginx镜像的命令
data:image/s3,"s3://crabby-images/abf42/abf429f3ab9527ee2731afae2b81d65caaa64c9c" alt=""
docker save -o nginx.tar nginx:latest 保存nginx镜像为tar压缩文件命令
data:image/s3,"s3://crabby-images/fc7ca/fc7ca16942473fdef80287b80f6d504271d1d9ad" alt=""
docker rmi [repository]:[tag] 删除镜像命令
docker rmi 容器id 也可以删除镜像命令
data:image/s3,"s3://crabby-images/820d2/820d2d979a21590f1004fcaa69046bd688686d4e" alt=""
docker load -i nginx.tar加载压缩文件为镜像文件
data:image/s3,"s3://crabby-images/ea670/ea670888d32f41ef11a0c57f24bcf5fbf3cf2cb5" alt=""
容器相关命令
data:image/s3,"s3://crabby-images/8c3b0/8c3b0dd787b3f13e0fb20af2b5429ed2c502afc2" alt=""
创建并运行一个容器命令:
docker run --name containerName -p 80:80 -d nginx
docker run 创建并运行一个容器
--name 给容器起一个名字
-p 宿主机端口:容器映射端口
-d 后台运行容器
nginx 镜像名称,没写tag,表示nginx:latest
data:image/s3,"s3://crabby-images/838f9/838f97e5bf62efc971142969f55e48a71df71d70" alt=""
docker ps 命令查看所有启动的容器命令
docker ps -a 命令查看所有容器命令
docker ps -a | grep nginx 命令查看所有与nginx相关的容器命令
data:image/s3,"s3://crabby-images/35742/35742a271d8f17ef090eadc088aae471a23887b4" alt=""
data:image/s3,"s3://crabby-images/98efb/98efb65750da5f8b86678b8e1c9365cd640080b2" alt=""
查看容器日志命令:docker logs 容器名
data:image/s3,"s3://crabby-images/9a766/9a7665cc03f55055805ce403d17799d090bc0c73" alt=""
持续不断地输出日志命令:docker logs 容器名 -f
data:image/s3,"s3://crabby-images/07d58/07d58e810b46eb88ccf1a41c7d0b96f884dfaafe" alt=""
**案例二:**进入nginx容器,修改html文件内容,添加"卷土重来"。
进入容器命令: docker exec -it 容器名称 bash
docker exec 进入容器内部执行一个命令。
-it 给当前进入容器创建一个标准的输入、输出终端,允许我们与容器交互。
bash 进入容器后执行的命令,bash是一个linux终端交互命令。
data:image/s3,"s3://crabby-images/e201e/e201eb6364060d7169070fc510895ecc93bb387d" alt=""
data:image/s3,"s3://crabby-images/b3750/b3750f2a3dbe3f6c69e0b9dab769bbd3a33a9953" alt=""
**问题:**进入容器后发现vi命令无法使用,因为容器是一个阉割版的linux。
执行修改内容命令:
sed -i 's#Welcome to nginx#卷土重来#g' index.html
sed -i 's#<head>#<head><meta charset="utf-8">#g' index.html
data:image/s3,"s3://crabby-images/b0ed8/b0ed800f98c9c99580ddb798a83da684de34bfc0" alt=""
data:image/s3,"s3://crabby-images/9229d/9229d583fc15264118bf55f28cedc10d01f70c3c" alt=""
docker rm 容器名称
不能删除正在运行中的容器。可以采用强制删除命令:docker rm -f 容器名称
data:image/s3,"s3://crabby-images/66d4a/66d4a61daa40dacdc3e49b5c6d3122aae87880ea" alt=""
启动并创建redis容器的命令:
docker run --name myredis -p 16379:6379 -d redis redis-server --appendonly yes
redis-server --appendonly yes redis持久化方式AOF
data:image/s3,"s3://crabby-images/596f4/596f43b625072222e96654d84e0a5190b7cabed4" alt=""
进入redis容器,并执行redis-cli客户端命令, 存入num的值为666:
data:image/s3,"s3://crabby-images/fa1ee/fa1ee0e48ac3d55d01f6cd5439fc7156c44b7528" alt=""