Docker基本控制命令(二)

Docker基本控制命令(二)

资源控制

CPU使用率控制

限制该镜像本次建立的容器最大只能占总资源的10%

docker run --cpu-quota 10000 centos

按比例分配

创建两个容器为c1和c2,若只有这两个容器,设置容器的权重,使得c1和c2的CPU资源占比为33.3%和66. 7%

docker run -itd --name c1 --cpu-shares 512 centos(镜像名)
docker run -itd --name c2 --cpu-shares 1024 centos(镜像名)

限制容器使用指定的CPU

为该镜像指定四个CPU的使用

docker run --name c3 --cpuset-cpus 0001,0010,0100,1000 centos

内存使用限制
限制建立的容器最多只能使用1gb内存
docker run --name c4 -m 1gb centos

限制容器读取磁盘\设备的数据量
限制该容器仅能读取sda磁盘的100mb的数据
docker run -d --device-read-bps /dev/sda:100mb centos

限制容器写入磁盘\设备的数据量
限制该容器仅能写入sda磁盘的100mb的数据
docker run -d --device-write-bps /dev/sda:100mb centos

限制容器读取磁盘\设备的次数
限制该容器仅能读取sda磁盘10次
docker run -d --device-read-iops /dev/sda:10 centos

限制容器写入磁盘\设备的次数
限制该容器仅能写入sda磁盘的10次
docker run -d --device-write-iops /dev/sda:10 centos

Docker数据卷、数据卷容器

建立数据卷(容器目内录与宿主机目录之间实现数据共享)

以交互模式建立数据卷

docker run -v 本地目录:容器目录 --name 容器名 -it 镜像名 /bin/bash

“-v” 指定数据卷

“-name” 新建立的容器名称

/var/www:/data1 前面为宿主目录,后者为容器目录(整体为建立关联过程)

建立数据卷容器(两个容器之间实现数据共享,与宿主机环境无关)

以交互模式建立容器并提供其中目录作为数据卷容器载体

docker run -v 容器内目录 ...... --name 容器名 -it 镜像名 /bin/bash

挂载提供空间的容器的数据卷到新容器中建立数据卷容器

docker run --volumes-from 提供空间的镜像名 --name 容器名 -it 镜像名 /bin/bash

Docker个人镜像创建

基于现有镜像创建新的镜像

基于本地模板创建新的镜像

基于Dockerfile创建新的镜像

基于现有镜像创建新的镜像

#创建容器
docker create -it centos /bin/bash
#生成新的镜像
docker commit -m "new" -a "zhy" -p ccbd1395fce9(容器ID/名称) ccos:new(生成的新镜像名称:标签)
●-m说明信息
●-a作者信息
●-p生成过程中停止容器的运行

基于本地模板创建新的镜像

#下载镜像模板
wget http://download.openvz.org/teuplate/precreated/debian-7.0-x86-minimal.tar.gz
#生成新的镜像
cat debian-7.0-x86-minimal.tar.gz | docker import - daoke:new

基于Dockerfile创建新的镜像

mkdir apache
cd apache

vim Dockerfile
#基于的基础镜像
FROM centos
#维护镜像的用户信息
MAINTAINER The porject <cloud- [email protected] org>
#镜像操作指令安装apache软件
RUN yum- y update
RUN yum -y install httpd
#开启80端口
EXPOSE 80
#复制网站首页文件
ADD index. html /var/www/html/index. html
#将执行脚本复制到镜像中
ADD run. sh /run. sh
RUN chmod 755 /run. sh
#启动容器时执行脚本.
CMD[" /run. sh"]

vim run.sh
#!/bin/bash
rm -rf /run/httpd/*
exec /usr/sbin/apachectl -D FOREGROUP
echo "web test" > index.html
//生成镜像
docker build -t httpd:centos .
//新镜像运行容器
docker run -d -p 1216:80 httpd:centos

Docker端口映射

容器内随机端口进行映射(映射范围:49000~49900)

[[email protected] ~]# docker run -d -P httpd:centos
0820d042e62294c0db107eef0fea8c2c1fca737acb8d91306a6d40e134332bde
[[email protected] ~]# docker ps -a
CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS                      PORTS                   NAMES
0820d042e622        httpd:centos        "/run.sh"           2 seconds ago       Up 1 second                 0.0.0.0:32768->80/tcp   epic_jennings

容器内指定端口进行映射

[[email protected] ~]# docker run -d -p 5566:80 httpd:centos
9f65fc007070f36df88304515232a0d5fa357e55926a5f06b48cdf359e6ec9b8
[[email protected] ~]# docker ps -a
CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS                      PORTS                  NAMES
9f65fc007070        httpd:centos        "/run.sh"           4 seconds ago       Up 4 seconds                0.0.0.0:5566->80/tcp   intelligent_nightingale

容器之间互联

docker run -itd -P --name web1 centos /bin/bash                      //创建并运行容器取名web1,端口号自动映射
docker run -itd -P --name web2 --link web1:web1 centos /bin/bash                    //创建并运行容器取名web2,

Docker私有仓库

[[email protected] tomcat]# docker pull registry              //下载私有仓库注册表
[[email protected] nginx]# vim /etc/docker/daemon.json
//添加私有仓库地址
{
  "insecure-registries" : ["192.168.142.77:5000"],                       //私有仓库地址
  "registry-mirrors" : ["https://abc123.mirror.aliyuncs.com"]
}

//重启docker
[[email protected] nginx]# systemctl stop docker
[[email protected] nginx]# systemctl start docker

//基于仓库镜像建立容器
[[email protected] nginx]# docker create -it registry /bin/bash
96f91f83a1d58ddee147fe3d141d27d69fa7d3d76c46e3783bef7c1c5d0339bb
[[email protected] nginx]# docker ps -a
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS                                                                                                                PORTS               NAMES
96f91f83a1d5        registry            "/entrypoint.sh /bin…"   5 seconds ago       Created                                                                                                                                   sweet_almeida

[[email protected] nginx]# docker run -d -p 5000:5000 -v /data/registry:/tmp/registry registry

//更改镜像标签(地址填写仓库地址)
[[email protected] nginx]# docker tag nginx:zhy 192.168.142.77:5000/nginx:zhy

//上传即可
[[email protected] nginx]# docker push 192.168.142.77:5000/nginx:zhy

原文地址:https://blog.51cto.com/14484404/2461754

时间: 2024-08-01 01:46:46

Docker基本控制命令(二)的相关文章

Docker基本控制命令(资源控制、数据卷及数据卷容器、镜像创建、端口映射、私有仓库)

一.资源控制 1.CPU使用率控制 限制该镜像本次建立的容器最大只能占总资源的10% docker run --cpu-quota 10000 centos 2.按比例分配 创建两个容器为c1和c2,若只有这两个容器,设置容器的权重,使得c1和c2的CPU资源占比为33.3%和66. 7% docker run -itd --name c1 --cpu-shares 512 centos(镜像名)docker run -itd --name c2 --cpu-shares 1024 centos

Docker基本部署及基本控制命令

一.Docker概述 Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的 Linux或Windows 机器上,也可以实现虚拟化.容器是完全使用沙箱机制,相互之间不会有任何接口,两者之间完全独立. 二.与虚拟机的比较 三.Docker核心概念 镜像(Image): 类似虚拟机镜像 容器(Container): 类似linux系统环境,运行和隔离应用.容器从镜像启动的时候,docker会在镜像的最上一层创建一个可写层,镜像本身是只读

Docker基本部署及基本控制命令(理论篇)

Docker基本部署及基本控制命令 Docker概述 ? Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的 Linux或Windows 机器上,也可以实现虚拟化.容器是完全使用沙箱机制,相互之间不会有任何接口,两者之间完全独立. 与虚拟机的比较 特性 容器 虚拟机 启动速度 秒级 分钟级 硬盘使用 一般为MB 一般为GB 性能 接近原生 弱于原生 系统支持量 单击支持上千个容器 一般几十个 隔离性 完全屏蔽底层 相对独立 Do

Docker入门教程(二)命令

Docker入门教程(二)命令 [编者的话]DockerOne组织翻译了Flux7的Docker入门教程,本文是系列入门教程的第二篇,介绍了Docker的基本命令以及命令的用法和功能. 在Docker系列教程的第一篇文章中,我们了解了Docker的基础知识,知道了它是如何工作以及如何安装的.在这篇文章中,我们将学习15个Docker命令,并通过实践来学习它是如何工作的. 首先,让我们通过下面的命令来检查Docker的安装是否正确: docker info  如果没有找到这条命令,则表示Docke

docker简明教程(二)

前言这篇博文承接我的上一篇<docker简明教程一> http://9399369.blog.51cto.com/9389369/1758576 相对于上一篇来说这篇所讲到的知识会高深一点因为学习的过程不就是一步步的由简单到复杂嘛但是我的风格没变用简单的文字让朋友们学习高深的docker技术.如果觉得我写的好的话顶我上推荐希望能让跟多人看到.学习和受益. 二十二.Docker导出容器到本地文件 不管是容器不是处于运行状态都可以导出 首先查看那容器状态 [[email protected] ~]

Matlab绘图基本控制命令

图形的控制与表现 (Figure control and representation) MATLAB提供的用于图形控制的函数和命令:   axis:  人工选择坐标轴尺寸.    clf:清图形窗口. ginput: 利用鼠标的十字准线输入.   hold: 保持图形.    shg:显示图形窗口.subplot: 将图形窗口分成N块子窗口.1.图形窗口(figure window)(1). 图形窗口的创建和选择(Creating and selecting of figure window)

Sass控制命令及函数知识整理

2017-07-07  20:17:17 最底部附结构图(实在是结构图太长了没办法) 2017-06-22  09:11:43 一.Sass的控制命令 [email protected]语句 @if 指令是一个 SassScript,它可以根据条件来处理样式块,如果条件为 true 返回一个样式块,反之 false 返回另一个样式块. 在 Sass 中除了 @if 之,还可以配合 @else if 和 @else 一起使用. 示例::控制一个元素隐藏或显示的代码, 原理:定义一个混合宏,通过 @

docker常用术语命令

镜像(Image) vs Dockerfile 这组概念很少会让人产生疑惑,但是这两者的区别非常重要.Docker在镜像(image)中运行你的代码,而不是Dockerfile.Dockerfile是通过docker build命令来编译镜像的配置文件. 如果你去浏览一下public index的话,你将会看到那里罗列了很多镜像文件.但是,也许有些奇怪的是,你将看不到任何编译出它们的dockerfile.镜像文件就是从Dockerfile编译而得到的不透明资产(opaque asset ). 当

docker基础及命令

1.启动docker sudo systemctl start docker sudo systemctl restart docker sudo systemctl stop docker sudo systemctl status docker 2.查看docker信息 sudo docker info Containers: 1 Running: 0 Paused: 0 Stopped: 1 Images: 2 Server Version: 17.03.1-ce Storage Driv