docker可以通过镜像创建一个容器作为程序的虚拟运行环境,并可以将该容器再打包回一个镜像。
在发布程序的同时将该镜像一同发布,这样其他人利用该镜像创建一个完全相同的运行环境,避免本地正常运行,其他人编译到处报错的尴尬情况。
将当前用户添加到docker
用户组
为了避免每次使用docker
命令都需要加上sudo
权限,可以将当前用户加入安装中自动创建的docker
用户组(可以参考官方文档):
sudo groupadd docker #添加docker用户组
sudo gpasswd -a $XXX docker #检测当前用户是否已经在docker用户组中,其中XXX为用户名
sudo gpasswd -a $USER docker #将当前用户添加至docker用户组
newgrp docker #更新docker用户组
镜像(images)
-
docker pull ubuntu:20.04
:拉取一个镜像,ubuntu
是镜像的名称,20.04
是镜像的版本号 -
docker images
:列出本地所有镜像 -
docker image rm ubuntu:20.04
或docker rmi ubuntu:20.04
:删除镜像ubuntu:20.04
-
docker [container] commit CONTAINER IMAGE_NAME:TAG
:导出容器CONTAINER
的镜像IMAGE_NAME:TAG
-
docker save -o ubuntu_20_04.tar ubuntu:20.04
:将镜像ubuntu:20.04
导出到本地文件ubuntu_20_04.tar
中 -
docker load -i ubuntu_20_04.tar
:将镜像ubuntu:20.04
从本地文件ubuntu_20_04.tar
中加载出来- 为镜像添加读权限:
chmod +r XXX
- 将镜像在两个服务器之间迁移:使用
scp
命令,利用本地作为中转(使用scp
在两个服务器之间传输文件需要两个服务器进行相当麻烦的配置)
- 为镜像添加读权限:
容器(container)
-
docker [container] create -it ubuntu:20.04
:利用镜像ubuntu:20.04
创建一个容器。 -
docker ps
:查看本地的所有正在运行的容器,参数-a
显示所有容器 -
docker [container] start CONTAINER
:启动容器 -
docker [container] stop CONTAINER
:停止容器 -
docker [container] restart CONTAINER
:重启容器 -
docker [contaienr] run -it ubuntu:20.04
:创建、启动并进入一个容器,+参数-d
则不会进入该容器 -
docker [container] attach CONTAINER
:进入容器 - 先按
Ctrl+p
,再按Ctrl+q
可以挂起容器;直接按Ctrl+d
则退出并关闭容器 -
docker [container] exec CONTAINER COMMAND
:在容器CONTAINER
中执行命令(需要先启动该容器) -
docker [container] rm CONTAINER
:删除容器 -
docker container prune
:删除所有已停止的容器 -
docker export -o xxx.tar CONTAINER
:将容器CONTAINER
导出到本地文件xxx.tar
中 -
docker import xxx.tar image_name:tag
:将本地文件xxx.tar
导入成镜像,并将镜像命名为image_name:tag
-
docker export/import
与docker save/load
的区别:-
export/import
会丢弃历史记录和元数据信息,仅保存容器当时的快照状态 -
save/load
会保存完整记录,体积更大
-
-
docker top CONTAINER
:查看某个容器内的所有进程 -
docker stats
:查看所有容器的统计信息,包括CPU、内存、存储、网络等信息 -
docker cp xxx CONTAINER:xxx
或docker cp CONTAINER:xxx xxx
:在本地和容器间复制文件(均在本地执行) -
docker rename CONTAINER1 CONTAINER2
:重命名容器 -
docker update CONTAINER --memory 500MB
:修改容器限制
如何将一个镜像创建成可以在本地直接登录的容器
使用`scp`命令将镜像上传到自己租的云端服务器
`ssh server_name` ,登录自己的云端服务器
docker load -i XXX_XXX.tar # 将镜像加载到本地
# 创建并运行由XXX:XXX镜像生成的容器AAA;
# -p 20000:22:将容器的22端口映射到本地20000端口,因为本地的22端口已经被SSH使用
docker run -p 20000:22 --name AAA -itd XXX:XXX
docker attach AAA # 进入创建的docker容器
passwd # 设置root密码
docker容器需要挂起,如果关闭docker容器则不能通过ssh登录
去云平台控制台中修改安全组配置,放行端口20000
。
即可在本地通过ssh
直接登录自己的docker
容器:
ssh root@xxx.xxx.xxx.xxx -p 20000 # 将xxx.xxx.xxx.xxx替换成自己租的服务器的IP地址
最后,可以参考ssh,创建工作账户并配置docker容器的别名和免密登录。
小Tips
如果apt-get下载软件速度较慢,可以参考清华大学开源软件镜像站中的内容,修改软件源。
作者:yxc
链接:https://www.acwing.com/blog/content/10878/
来源:AcWing