docker专题

1. 安装,卸载

方案一:yum 安装,卸载
yum安装源:centos 7 默认的repo源就能安装docker
yum install docker
yum remove docker

完全删除法:
sudo yum remove docker
docker-client
docker-client-latest
docker-common
docker-latest
docker-latest-logrotate
docker-logrotate
docker-selinux
docker-engine-selinux
docker-engine

方案二:rpm包下载离线安装
经过测试,至少要通过yum方式,安装两个包
docker-ce-selinux-17.03.2.ce-1.el7.centos.noarch.rpm
docker-ce-17.03.2.ce-1.el7.centos.x86_64.rpm

wget https://download.docker.com/linux/centos/7/x86_64/stable/Packages/docker-ce-17.03.2.ce-1.el7.centos.x86_64.rpm
wget https://download.docker.com/linux/centos/7/x86_64/stable/Packages/docker-ce-selinux-17.03.2.ce-1.el7.centos.noarch.rpm

yum install 下载好的两个rpm包即可。

方法三:执行以下语句,安装docker最新版本
curl -fsSL https://get.docker.com/ | sh # 风险大,官方不推荐。Using these scripts is not recommended for production environments

参考资料:
docker社区版安装

2. docker三要素组件的理解

1)镜像
Docker 镜像是一个特殊的文件系统,除了提供容器运行时所需的程序、库、资源、配置等文件外,还包含了一些为运行时准备的一些配置参数(如匿名卷、环境变量、用户等)镜像不包含任何动态数据,其内容在构建之后也不会被改变。
ps:docker pull 一个镜像,就像是下载了一个文件。
2)容器
容器的实质是进程,但与直接在宿主执行的进程不同,容器进程运行于属于自己的独立的 命名空间。因此容器可以拥有自己的 root 文件系统、自己的网络配置、自己的进程空间,甚至自己的用户 ID 空间。容器内的进程是运行在一个隔离的环境里,使用起来,就好像是在一个独立于宿主的系统下操作一样。

镜像(Image)和容器(Container)的关系,就像是面向对象程序设计中的类和实例 一样,镜像是静态的定义,容器是镜像运行时的实体。

ps:按照 Docker 最佳实践的要求,容器不应该向其存储层内写入任何数据,容器存储层要保持无状态化。所有的文件写入操作,都应该使用 数据卷(Volume)、或者绑定宿主目录,在这些位置的读写会跳过容器存储层,直接对宿主(或网络存储)发生读写,其性能和稳定性更高。
数据卷的生存周期独立于容器,容器消亡,数据卷不会消亡。因此,使用数据卷后,容器删除或者重新运行之后,数据却不会丢失。

3)仓库
提供集中存储,分发仓库的服务。

2. docker 配置文件和日志文件地址

docker配置文件地址,一般位于:/etc/docker/daemon.json
/etc/docker/daemon.json ==1.12版本后万能配置文件==
如没有该文件,请自行创建,测试方法:
文件中增加选项:
{
"graph": "/opt/docker" #设置Docker运行时根目录
}
service docker restart # 默认生成/opt/docker文件夹和内容作为根目录

3. 容器hub注册添加方法

Docker 中国官方镜像加速
即,在/etc/docker/daemon.json文件中,添加如下内容
{
"registry-mirrors": ["https://registry.docker-cn.com"]
}

创建私有仓库的办法:
参考资料:
Docker 私有仓库最简便的搭建方法 ps: centos 7 测试可用
Docker Hub 仓库使用,及搭建 Docker Registry ps: centos 7 测试可用

4. docker启动方式

ps: centos 7,尽量使用systemctl命令,以取代service和chkconfig命令。
必须root用户启动,centos 7,root用户下


参考资料:
Docker 后台进程参数-------更改Docker运行根目录的方法

5. docker常见命令

基本分类
1). 版本信息:info,version
2). 镜像仓库:login,pull,push,search
3). 本地镜像管理:images,rmi,tag,build,history,save,import
4). 容器生命周期管理:run,start/stop/restart,kill,rm,pause/unpause,create,exec
5). 容器运维操作:ps,inspect,top,attach,events,logs,wait,export,port
6). 容器rootfs命令:commit,cp,diff

常用命令说明

1) 版本信息,info显示docker系统信息,而version显示版本信息
例如:docker info
Containers: 12
Images: 41
Storage Driver: aufs
 Root Dir: /var/lib/docker/aufs
 Backing Filesystem: extfs
 Dirs: 66
 Dirperm1 Supported: false
Execution Driver: native-0.2
Logging Driver: json-file
Kernel Version: 3.13.0-32-generic
Operating System: Ubuntu 14.04.1 LTS
CPUs: 1
Total Memory: 1.954 GiB
Name: iZ23mtq8bs1Z
ID: M5N4:K6WN:PUNC:73ZN:AONJ:AUHL:KSYH:2JPI:CH3K:O4MK:6OCX:5OYW

2) 镜像仓库的操作
例如: docker login/logout  # 登录官方镜像仓库,登录后,才能push成功
例如:docker pull repos   # 获取镜像
           docker pull public_registry/repos:tag
例如:docker push repos
           docker push your_registry/repos:tag
3)本地镜像管理
docker images   # 显示本地所有镜像
docker rmi          # 删除镜像

docker tag          # 很重要的命令,常见用法
docker tag [OPTIONS] IMAGE[:TAG] [REGISTRYHOST/][USERNAME/]NAME[:TAG]

docker build       # 使用dockerfile创建镜像,如何写dockerfile则是另一个问题
docker history    # 显示你的镜像创建历史

docker save       # 将你的镜像保存为tar文档
例如:docker save -o my_ubuntu_v3.tar runoob/ubuntu:v3

docker import     # 将你的镜像从tar文档中,导入本地系统使用

docker commit  # 从容器生成一个镜像
常见用法:
docker commit -a "作者" -m "提示" container_id  image:tag 
4). 容器生命周期管理
docker run       # 最常见的重要命令,从镜像创建一个新的容器
常见用法:
docker run -it nginx:latest /bin/bash # 交互模式,启动一个容器,并进入shell进行交互
docker run --name mynginx -d nginx:latest  # 后台模式,启动一个容器,并命名为mynginx
docker run -p 80:80 -v /data:/data -d nginx:latest # -p选项,将容器端口映射到主机端口80,将/data映射到主机/data目录
docker run -P -d nginx:latest  # -P, 将容器可用端口,随机映射到主机某个端口上,具体可以通过docker ps命令查看

docker create  # 创建一个容器,但是不启动它,与run有所区别
常见用法:
docker create  --name myrunoob  nginx:latest 

docker start/stop/restart  CONTAINER    # 启动,关闭,重启一个容器

docker kill/rm CONTAINER  # 杀死一个运行中的容器/删除一个容器

docker pause/unpause # 暂停/恢复容器中所有进程

docker exec # 在容器中执行命令
常见用法:
docker exec -it mynginx /bin/sh /root/runoob.sh  # 在交互终端中执行一条命令并输出结果
docker exec -i -t  mynginx /bin/bash    # 打开交互终端

5). docker容器运维操作
docker ps  # 列出容器
常见用法:
docker ps  # 列出运行中的容器
docker ps -a # 列出所有容器,包括关闭的
docker ps -q # 列出所有容器id

docker inspect # 获取容器/镜像的元数据
常见用法:
docker inspect -f {{ .name }} container

docker top # 查看运行中的进程信息
docker top container  # 可以获得对应容器在系统中的进程ID

docker attach # 进入容器,但是该做法已经不再推荐,建议改用docker exec

docker events # 实时输出Docker服务器端的事件,包括容器的创建,启动,关闭等。

docker logs # 用于查看容器的日志,它将输出到标准输出的数据作为日志输出到docker logs命令的终端上。常用于后台型容器

docker export # --将容器的文件系统打包成tar文件
常见用法:
docker -o xxx.tar container

docker port # 查看容器端口
常见用法:
docker port container # 查看某个容器的所有对外端口

综合而言,ps,top和port个人认为是三个必须关注的命令

6. docker 数据卷问题

要点记忆:
为了能够保存(持久化)数据以及共享容器间的数据,Docker提出了Volume的概念。

简单来说,Volume就是目录或者文件,它可以绕过默认的联合文件系统,而以正常的文件或者目录的形式存在于宿主机上。

在Docker中,只读层及在顶部的读写层的组合被称为Union File System(联合文件系统)。

docker文件系统的工作方式:

1)Docker镜像是由多个文件系统(只读层)叠加而成。
2)容器启动,Docker会加载只读镜像层并在其上(译者注:镜像栈顶部)添加一个读写层。ps:所以再启动一个容器,不影响已启动容器,同时删除容器,所做更改消失。
3)如果运行中的容器修改了现有的一个已经存在的文件,那该文件将会从读写层下面的只读层复制到读写层,该文件的只读版本仍然存在,只是已经被读写层中该文件的副本所隐藏。

参考资料:
Docker 安装 MySQL

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,098评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,213评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,960评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,519评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,512评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,533评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,914评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,574评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,804评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,563评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,644评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,350评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,933评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,908评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,146评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,847评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,361评论 2 342

推荐阅读更多精彩内容