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(镜像名)

3、限制容器使用指定的CPU

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

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

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

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

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

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

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

二、Docker数据卷、数据卷容器

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

以交互模式建立数据卷

docker run -v 本地目录:容器目录 --name 容器名 -it 镜像名 /bin/bash
“-v” 指定数据卷
“-name” 新建立的容器名称
/var/www:/data1 前面为宿主目录,后者为容器目录(整体为建立关联过程)

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

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

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

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

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

三、Docker个人镜像创建

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

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

3、基于Dockerfile创建新的镜像

(1)基于现有镜像创建新的镜像

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

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

下载镜像模板
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

(3)基于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端口映射

1、容器内随机端口进行映射(映射范围: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

2、容器内指定端口进行映射

[[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

3、容器之间互联

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/14475593/2462885

时间: 2024-10-11 08:27:43

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

Docker镜像创建及建立私有仓库

Docker镜像创建方法 创建镜像的方法有三种,分别是基于已有的镜像创建.基于本地模板创建.基于Dockerfile 创建,下面着重介绍这三种创建镜像的方法. ? 基于已有镜像创建 首先将镜像加载到容器,将容器里面运行的程序及运行环境打包起来生成新的镜像,需要记住该容器的ID号. 命令格式: docker commit [选项] 容器ID/名称 仓库名称:[标签] 常用选项: -m:说明信息 ? -a:作者信息 ? -p:生成过程中停止容器的运行 # docker create -it nick

docker 创建和使用私有仓库

通过官方的registry镜像来简单搭建一套本地私有仓库环境: docker run -d -p 5000:5000 registry 上述命令执行完成之后,会自动下载一个registry容器,创建本地的私有仓库服务. 默认情况下,会将仓库创建在容器的/tmp/registry目录下,可以通过-v参数来将镜像文件存放在本地的指定路径上. docker run -d -p 5000:5000 -v /opt/data/registry:/tmp/registry registry 将上传的镜像放到

Docker将自己的镜像发布到个人私有仓库

Docker将自己的镜像发布到个人私有仓库 1.注册dockerhub账户 docker提供了一个类似于github的仓库dockerhub, 网址https://hub.docker.com/需要注册使用 2.在服务器上登录账号 docker login 3.修改正确的镜像名 注意要保证image的tag是账户名,如果镜像名字不对,需要改一下tag 语法是: docker tag 仓库名 用户名/仓库名 docker tag zero/centos-vim 用户名/centos-vim 4.推

Docker(三)资源控制

Docker资源控制 Cgroup是Control group的简写,是Linux内核提供的一种限制所使用物理资源的机制,这些资源主要包括CPU.内存.blkio.下面就这三个方面说一下Docker是如何使用Cgroup机制进行管理 1:限制CPU使用速率 在Docker中可以通过 --cpu-quota选项来限制CPU使用速率,CPU的百分比是以1000为单位 查看CPU使用率 [[email protected] apache] docker stats CONTAINER CPU % ME

使用iptables为docker容器动态添加端口映射

1.将当前iptables的配置写入保存到/etc/sysconfig/iptables 2.保存 /etc/init.d/iptables sava 3.修改iptables配置(vi /etc/sysconfig/iptables): 在适当位置增加下面红色的三行,然后重启iptables即可.(30612 是容器对外提供服务的端口) -A FORWARD -i docker0 -o docker0 -j ACCEPT -A DOCKER -d 172.17.0.10/32 ! -i doc

Docker基础-搭建本地私有仓库

1.使用registry镜像创建私有仓库 安装Docker后,可以通过官方提供的registry镜像来简单搭建一套本地私有仓库环境: docker run -d -p 5000:5000 registry 这条命令将自动下载并启动一个registry容器,创建本地的私有仓库服务.默认会将仓库创建在容器的/tmp/registry目录下.可以通过-v参数来将镜像文件存放在本地指定路径 例如:将上传的镜像放到/opt/data/registry目录: docker run -d -p 5000:50

搭建和使用Docker私有仓库

需要注意的是,从Docker Pool下载的镜像文件,与官方镜像文件是完全一致的. 安装Docker之后,可以是使用官方提供的registry镜像来搭建一套本地私有仓库环境: docker run –d –p 5000:5000 registry 输入之后就可以等待了,其实本地仓库本身就是容器,这句命令会下载并创建一个registry容器,创建本地的私有仓库. 默认情况下,会将仓库创建在容器的tmp/registry目录下,当然,可以通过-v参数将镜像文件存放到本地的指定路径上. docker 

docker 搭建本地私有仓库

1.使用registry镜像创建私有仓库 安装docker后,可以通过官方提供的 registry 镜像来简单搭建一套本地私有仓库环境: docker run -d -p 5000:5000 registry:2 这将自动下载并启动一个 registry 容器,创建本地的私有仓库服务. 默认情况下,仓库会被创建在容器的 /var/lib/registry 目录下.可以通过 -v 参数来将镜像文件存放在本地的指定路径.例如下面的例子将上传的镜像放到 /opt/data/registry 目录: d

Docker+DokcerFile 简单命令和简单镜像配置----Tomcat+jdk+centos7

宿主机描述:docker info (自身的描述)docker --helpdocker images(查看所有镜像)docker images -adocker images -q(显示镜像ID)docker images --digests(镜像说明:备注)docker images -- digests --no-trunc(查看完整ID)docker rmi 镜像ID(删除镜像)搜索:docker search 镜像名docker search -s (点赞数) 镜像名下载:docker

docker学习-常用命令1

一.容器管理 1.1 Docker start/stop/restart/rm 命令实例:启动|停止|重启|删除 容器mydb01# docker start|stop|restart|rm mydb01 1.2 Docker kill 命令,杀掉一个运行中的容器.OPTIONS说明: -s :向容器发送一个信号 例:杀掉运行中的容器mydb01# docker kill -s KILL mydb01 1.3 Docker rm 命令,删除一个或多少容器OPTIONS说明: -f :通过SIGK