(转载)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.04docker [container] commit CONTAINER IMAGE_NAME:TAG:导出容器CONTAINER的镜像IMAGE_NAME:TAGdocker 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:tagdocker 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

浙公网安备 33010602011771号