概述:
(1)架构
docker server:服务进程,管理所有容器,接受客户端操作。
docker client:远程控制器,远程控制服务器行为
通常二者在同一个机器上
(2)名词
镜像:容器运行的只读模板,由层构成,经过提交相应的层更新生成不同的容器
一般镜像构建过程:基础镜像——》中间件镜像 ——》应用镜像
容器:由镜像创建的程序运行环境,每次操作生成不同的层
layer 层: docker 每执行一条命令,就会生成一层,可以基于层提交生成具有不同操作的镜像。
仓库:存放镜像的地方。有本地仓库,远程仓库,共有仓库,私有仓库。
一 镜像
(1)搜索镜像
命令:docker search centos
$ docker search centos
NAME DESCRIPTION STARS OFFICIAL AUTOMATED
centos The official build of CentOS. 2877 [OK]
ansible/centos7-ansible Ansible on Centos7 90 [OK]
jdeathe/centos-ssh CentOS-6 6.8 x86_64 / CentOS-7 7.2.1511 x8... 47 [OK]
jdeathe/centos-ssh-apache-php CentOS-6 6.8 x86_64 - Apache / PHP / PHP M... 23 [OK]
nimmis/java-centos This is docker images of CentOS 7 with dif... 18 [OK]
gluster/gluster-centos Official GlusterFS Image [ CentOS-7 + Glu... 14 [OK]
million12/centos-supervisor Base CentOS-7 with supervisord launcher, h... 12 [OK]
|
(2)获取镜像
命令:docker pull centos
(3)查看镜像
命令: docker images
$ docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
centos java a10d7da10519 45 hours ago 1.447 GB
centos latest 0584b3d2cf6d 3 weeks ago 196.5 MB
|
(4)删除镜像
命令:docker rmi <REPOSITORY>:<TAG>
$ docker rmi centos:datauser
Untagged: centos:datauser
Deleted: sha256:febb9fe5ad20d8ea9c5680807b82c234b0bf8c3c91ca1ac04e33a3d920f6be42
Deleted: sha256:09f1f145834352976cf5433bb549886a05eb6f3b83536bca562af8e6c8fb5ac6
|
二 容器
(1)由镜像创建容器并启动
命令:docker run -tid —name <CONTAINER NAME> <REPOSITORY>:<TAG>
例如:docker run -tid —name java centos:latest
说明:
-t:docker 分配一个维终端并绑定到容器标准输入之上
-i: 让容器的标准输入保持打开,接收操作
-d:守护进程的方式连接
其他:由镜像启动一个容器并运行程序
docker run centos echo "hello world"
hello world
|
(2)连接容器
命令: docker exec -ti <容器id或名称> /bin/bash
(3)查看容器
a)查看运行的容器
命令: docker ps
$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
4712b78f0e5a centos:latest "/bin/bash" 8 hours ago Up 8 hours dataUser
|
b)查看所有容器
命令:docker ps -a
$ docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
4712b78f0e5a centos:latest "/bin/bash" 8 hours ago Up 8 hours dataUser
789ab62382eb centos:latest "/bin/bash" 8 hours ago Exited (127) 8 hours ago test
5387312fc962 centos:latest "/bin/bash" 8 hours ago Exited (137) 8 hours ago dataVol
|
(4)启动一个已存在的容器
命令:docker start <容器id | 容器名称>
(5)停止容器
命令:docker stop <容器id | 容器名称>
(6)删除容器
命令:docker rm <容器id | 容器名称>
(7)提交容器到镜像
命令:docker commit <容器ID | 容器名称> <仓库名称>:<Tag>
$ docker commit dataUser centos:datauser
sha256:febb9fe5ad20d8ea9c5680807b82c234b0bf8c3c91ca1ac04e33a3d920f6be42
|
三 端口映射
启动时映射宿主机和容器端口
命令:docker run -p <宿主机端口>:<容器端口> <镜像名称>
-p 指定的集中形式
(1)ip:hostPort:containerPort :指定宿主机ip指定端口映射容器的端口
(2)ip::containerPort:指定宿主机ip,系统随机分配端口,映射到容器端口
(3)hostPort:containerPort:宿主机任意ip,指定端口,映射到容器端口
(4)containerPort:系统随机分配端口,映射到容器端口
检测命令:
docker port $container_id | $container_name
注:
1)容器要增加端口,需要提交成镜像,然后重新绑定端口,原先绑定的端口在启动镜像时需要重新绑定
2)查看端口要使用 docker port , docker ps 显示的不靠谱
开四个端口映射样例
$ docker run -itd -p 9200:9200 -p 9201:9201 -p 9300:9300 -p 9301:9301 --name search centos:java
e54a6dfc3a8d430fa8b7c2a7bdd65949423cb4da5c7a6013b6871b9e490ac039
$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
e54a6dfc3a8d centos:java "/bin/bash" 4 seconds ago Up 3 seconds 0.0.0.0:9200-9201->9200-9201/tcp, 0.0.0.0:9300-9301->9300-9301/tcp search
$ docker port search
9200/tcp -> 0.0.0.0:9200
9201/tcp -> 0.0.0.0:9201
9300/tcp -> 0.0.0.0:9300
9301/tcp -> 0.0.0.0:9301
|
四 拷贝数据
命令: docker cp [OPTIONS] CONTAINER:SRC_PATH DEST_PATH|-
docker cp [OPTIONS] SRC_PATH|- CONTAINER:DEST_PATH
1)向容器内拷贝:docker cp [本地路径] [容器名]:[容器路径]
例如:docker cp /tmp/test.txt d8f7c83ba660:/tmp
2)从容器内拷出:docker cp [容器名]:[容器路径] [本地路径]
例如:docker cp d8f7c83ba660:/tmp/test.txt /tmp
五 加载数据卷
(1)挂载目录
启动镜像时,将宿主机指定目录挂载到指定镜像的指定目录上
docker run -tid -v /tmp:/tmp —name data centos:latest
说明:通过-v参数,冒号前为宿主机目录,必须为绝对路径,冒号后为镜像内挂载的路径,此时默认开放读写权限。
需要指定权限如下:
docker run -tid -v /tmp:/tmp:ro —name data centos:latest
如果需要挂载多个目录,调用多次 -v进行挂载
(2)挂在数据卷
数据卷:普通 docker容器,用于供其他容器挂在使用。
a)创建数据卷:同上
docker run -tid -v /tmp:/tmp --name dataVol centos:latest
b)挂载数据卷:
docker run -tid --volumes-from dataVol --name dataUser centos:latest
附录:其他
(1) Docker 容器Root密码
yum install passwd 安装passwd软件;
执行passwd命令,修改root用户密
相关推荐
Docker 初步命令
随着云计算和容器化技术的快速发展,传统的软件部署方式正在逐步被更加高效、灵活的容器化部署所...通过本文的介绍和案例分析,相信读者已经对Docker和Docker Compose有了初步的认识,并能够在自己的项目中加以应用。
初步学习
初步了解学习Docker
IT 技术进阶:初步认识 Docker Docker 是什么? ---------------- Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用程序以及依赖包到一个可移植的容器中,该容器包含了应用程序的代码、运行环境、...
VirtualBox、centos中初步安装使用docker建立仓库等实验报告
主要简述Docker容器的安全知识分享,并讲解了一些安全规则,以及怎么构建Docker的防御体系,对应初步学习Docker的同学有很大的帮助,尤其是关注Docker的安全入门用户有一定的技能提升。
主要讲了如何使用Docker,Docker的一些基本知识 如何编写Dockerfile等等, 主要适合初步学习Docker的人群,
大致介绍了docker的原理及使用,从整体到细节,帮忙同学们了解。
本人不了解go语言,对docker 也只是初步的学习了基本使用,因为想学习点hadoop东西,用实验室电脑配置太低,用虚拟机搭建hadoop集群太卡,所以用docker 尝试搭建一个3个节点的最简单的集群:1个namenode(192.168.0.2...
Docker作为目前流行的开源应用容器引擎,广泛用于快速部署应用,但在使用过程中可能会遇到Docker无法正常启动的情况。了解和掌握Docker无法启动的原因及相应的解决办法,对于提高工作效率和维护系统稳定性具有重要...
使用场景及目标:通过本文的学习,能够熟练地完成 Docker 的安装、初步设置及简单的故障排查工作。这为日后利用 Docker 技术提高应用程序部署效率打下坚实的基础。 其他说明:本文不仅详细记录了每个操作系统的具体...
官方为我们提供了针对不同系统的Docker版本,今天我们基于windows系统简单介绍下如何使用。 Windows部署Docker 目前官方发布的Docker桌面版,仅支持Windows 10 64-bit: Pro, Enterprise(企业版), Education(教育版
初步测试表明,PhantomJS项目本身提供的一些运行良好,但这并不意味着它将适用于所有用例。 :warning: 用法 docker run -ti --rm fgrehm/phantomjs2 --help 在本地构建 git clone ...
适合人群:初学者以及希望快速了解Docker基本功能和技术要点的技术爱好者或者有初步经验想要深入学习的专业人士。 使用场景及目标:适用于需要在一个稳定可控环境下开发测试软件项目的人群,特别是云计算从业者;其...
初步,安装依赖工具 git // brew安装git Docker [ ] Docker-compose [ ] 第二步,获取项目代码 $ git clone https://github.com/helingfeng/Docker-LNMP.git 第三步,运行容器编排 $ cd Docker-LNMP // 进入项目根...
gpu-rest-engine, 使用 Docker 和的Caffe的REST API 简介这个库展示了如何使用 NVIDIA gpu实现低延迟图像分类( 推理)的REST服务器。 这是对 GRE软件的初步演示,可以让你构建自己的加速 microservices 。演示使用了...
克隆存储库和初步步骤将此存储库克隆到系统中的某个位置: git clone https://github.com/frappe/frappe_docker.gitcd frappe_docker生产设置它会注意以下事项: 设置所需的Frappe / ERPNext版本。 设置所有系统要求...