(转载)docker
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使用
# 映射8000端口:用于调试服务器
docker run -p 20000:22 -p 8000:8000 --name AAA -itd XXX:XXX
docker attach AAA # 进入创建的docker容器
passwd # 设置root密码
docker容器需要挂起,如果关闭docker容器则不能通过ssh登录
docker容器也需要安装ssh服务
去云平台控制台中修改安全组配置,放行端口20000
。
即可在本地通过ssh
直接登录自己的docker
容器:
ssh root@xxx.xxx.xxx.xxx -p 20000 # 将xxx.xxx.xxx.xxx替换成自己租的服务器的IP地址
最后,可以参考ssh,创建工作账户并配置docker容器的别名和免密登录。
为容器添加新的端口映射
将容器先打包回镜像,再重新生成。
作者:yxc
链接:https://www.acwing.com/blog/content/10878/
来源:AcWing