docker容器管理和数据管理

1、概念

容器类似于一个linux环境,是通过镜像创建启动的,可以理解为在镜像的最上一层创建一个可读写层,镜像本身是只读的,容器的读写不会改变镜像。

2、容器管理

2.1容器的创建

#docker run -itd --name nginx1 nginx:latest
基本的创建携带 i t d这三个参数即可,表示的意义分别如下;
-i: 以交互模式运行容器,通常与 -t 同时使用;
-d: 后台运行容器,并返回容器ID;
-t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用;

nginx1和nginx:latest分别表示创建的容器名和所使用的镜像,创建完成后使用 docker ps 命令即可看到新建并运行的容器

#docker run -itd --name nginx2 -p 8080:80 nginx:latest
指定映射端口,将容器中的80端口映射到宿主机的8080端口上;这样就可以通过访问宿主机的8080端口达到访问容器的目的

#docker run -itd --name nginx3 --cpus 1 nginx:latest
限制cpu最大可用核数

#docker run -itd --name nginx5 --cpu-shares 512 nginx:latest
设置cpu的权重,默认值为1024;不设置或将其设置为0,均使用默认值;如果5个容器都是默认值1024,则平均分配

#docker run -itd --name nginx4 -m 100m nginx:latest
限制最大可用内存

#docker run -itd --name nginx6 -m 100m --oom-kill-disable nginx:latest
默认情况下,在出现out-of-memory(OOM)错误时,系统会杀死容器内的进程来获取更多的内存空间;在使用了-m限制容器内存后可以将oom-kill禁用

2.2容器的查询

#docker ps
查询当前运行的容器

#docker ps -a
这里我们先用docker stop nginx1关闭nginx1容器,再使用-a可以看到所有容器信息

#docker ps -aq
查询所有容器的id号

#docker log nginx2
查看容器的日志信息

#docker inspect nginx2
用来查询容器的详细信息,包含cpu、内容、端口、目录等信息

#docker top nginx2
查询容器的进程信息

#docker port nginx2
查看容器的端口映射

#docker stats nginx2
实时查看容器的资源利用率

2.3操作容器

#docker exec -it nginx2 bash
进入容器,退出后容器仍然为运行状态

#docker cp /tmp/test.txt nginx2:/tmp
拷贝文件到nginx2容器的/tmp目录下;将容器内的文件拷贝到宿主机则相反

#docker start|stop|restart nginx2
即启动、停止、重启容器

#docker rm nginx2
删除重启,在执行前需要保证容器为停止状态,否则rm失败

#docker commit nginx2 nginx:v2
将容器提交成为一个镜像,当前容器的改动会持久化到nginx:v2镜像中

3、数据管理

3.1 volumes方式

#docker volume create nginx-vol
创建volume,指定名称为nginx-vol

#docker volume ls
查询已经创建的volume

#docker volume inspect nginx-vol
查看volume的详细信息,可以看到对于的挂载路径

#docker run -itd --name nginxvol-test -p:8081:80 --mount src=nginx-vol,dst=/usr/share/nginx/html nginx:latest
使用volume创建容器,指定容器挂载目录为/usr/share/nginx/html

此时查看nginx-vol会发现容器中挂载目录下的html文件;在volume下新增文件也会同步到容器中

Docker inepct命令可以看到容器的volume信息

#docker volume rm nginx-vol
nginx-vol非使用时才可以执行删除操作

3.2 bind方式

#docker run -itd --name nginxBind-test -p:8082:80 --mount type=bind,src=/root/www/,dst=/usr/share/nginx/html nginx:latest
创建容器时携带type=bind,并指定src和dst目录

docker insepct 命令可以看到该容器的bind信息

原文地址:https://blog.51cto.com/14129044/2427893

时间: 2024-10-08 12:36:05

docker容器管理和数据管理的相关文章

[CoreOS 转载] CoreOS实践指南(七):Docker容器管理服务

转载:http://www.csdn.net/article/2015-02-11/2823925 摘要:当Docker还名不见经传的时候,CoreOS创始人Alex就预见了这个项目的价值,并将其做为CoreOS支持的第一套应用程序隔离方案.本文将主要介绍在具体的场景下,如何在CoreOS中恰当地管理Docker容器. 注:本文首发于CSDN,转载请标明出处. [编者按]在“漫步云端:CoreOS实践指南”系列的前几篇文章中,ThoughtWorks的软件工程师林帆主要介绍了CoreOS及其相关

容器管理之---数据管理

前面学习了镜像的管理.容器的管理,今天学习数据的管理,毕竟一个服务或一个程序的发布是离不开数据的,数据才是企业的核心. # 一.数据的存放形式我们在部署容器的时候往往将数据是存放宿主机目录的,你想如果把数据存放容器上,一不小心删除了容器,就哭瞎眼了:而且放宿主机更便于维护和管理.将数据从宿主机挂载到容器中的三种方式:1. Volume:Docker会管理宿主机文件系统的一部分(/var/lib/docker/volumes),保存数据的最佳方式. 2.Bind Mounts:将宿主机上的任意位置

Docker容器管理

创建容器: docker create -it [NAME]:[TAG] 启动容器: docker start ID 创建并启动容器: docker run -it [NAME]:[TAG] COMMAND [PARAMS] -i:让容器的标准输入保持打开. -t:让Docker分配一个伪终端. -d:让Docker容器在后台以守护态形式运行. 停止容器: docker stop ID 首先向容器发送SIGTERM信号,等待一段时间后再发送SIGKILL信号终止容器. docker kill I

Docker容器管理之Kubernetes

Kubernetes是Google开源的容器集群管理系统.它构建于docker技术之上,为容器化的应用提供资源调度.部署运行.服务发现.扩 容缩容等整一套功能,本质上可看作是基于容器技术的mini-PaaS平台.本文旨在梳理Kubernetes的架构.概念及基本工作流,并且通过运行一 个简单的示例应用来介绍如何使用Kubernetes. 总体概览 如下图所示是我初步阅读文档和源代码之后整理的总体概览,基本上可以从如下三个维度来认识Kubernetes. 操作对象 Kubernetes以RESTF

四.docker容器管理

试验机192.168.181.144 用户root 密码123456 主机名[email protected]:/# hostnameweb docker container run -d --name web2 -P nginx #-P :发布容器中声明EXPOSE端口到宿主机的随机端口:#docker ps -l #列出最新创建的容器:CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES803a6db849ab nginx "nginx

Docker容器中的数据管理--RHEL7.3

容器中数据管理主要分为两种方式:数据卷 和 数据卷容器 数据卷 数据卷是一个可供容器使用的特殊目录,它绕过文件系统,类似于Linux下对目录执行mount操作 创建一个数据卷 在容器内创建数据卷挂载到/volume目录下,相当于容器间的共享目录: docker run -dti -v /volume1 --name test1 centos:ifconfig /bin/bash 将宿主机目录挂载到容器作为数据卷: docker run -dti -v /test:volume2:ro --nam

Docker-compose 多个Docker容器管理:以MYSQL和Wordpress为例

搬砖的陈大师版权所有,转载请注明:http://www.lenggirl.com/tool/docker-compose.html 环境:Ubuntu [email protected]:~$ uname -a Linux jinhan-chen-110 4.4.0-83-generic #106-Ubuntu SMP Mon Jun 26 17:54:43 UTC 2017 x86_64 x86_64 x86_64 GNU/Linux [email protected]:~$ lsb_rele

Docker容器管理--Dockerfile

前言: docker镜像使用dockerfile文件生成,dockerfile是一个文本文件,通过命令行的执行来组成新的镜像 基本语法 FROM 基于那个镜像构建容器 例:centos:7 任何Dockerfile的第一条指令必须为FROM指令 MAINTAINER 镜像维护者信息 例:unixzhang <[email protected]> 该信息会被写入到镜像的Author属性中 RUN 构建镜像时运行的Shell命令 例:RUN ["yum","insta

docker容器管理基础

1.命令: docker info #查看服务器上docker详细信息 docker search #搜索镜像 docker image pull nginx:1.14-alpine #下载一个镜像 docker image ls #查看镜像 docker rmi -f image id #删除镜像 -f:强制删除 docker rm 容器名 #删除容器 docker run --name b1 -it busybox:latest #启动一个容器 -it:交互运行 b1:名字 docker r