0. 学习的一些疑问

  • 如何热更新镜像(images)?(你可以快速启动或者销毁容器。这种时间几乎是实时的)
  • 如何热更新游戏服?
  • 好处在于各个应用之间环境相互独立,即使某一个容器崩溃也不会影响到其它容器;
  • 每个容器使用端口如何维护?(方法1写在Dockerfile里面,不灵活;方法2在run的时候-p指定);
  • 那这样的话,会存在好多linux用户,相当于每一个容器就要维护一个物理机(虚拟);
  • 需要一套工具来管理维护镜像、容器的操作和状态;
  • 目前主流使用docker都是应用到哪些场景中?

1. docker的二个软件

  • Docker: 开源的容器虚拟化平台;
  • Docker Hub: Software-as-a-Service平台,用来共享和管理docker容器。

2. docker的三大模块

  • Docker images.(镜像)
  • Docker registries.(仓库)
  • Docker container.(容器)

3. 常用命令

3.1. 常用镜像命令

  • docker image(查看镜像信息)
  • docker build(创建镜像)
    • Dockerfile

      • '#注释'
      • FROM 基于哪个镜像为基础
      • MAINTAINER 维护者信息
      • RUN 运行指令
      • ADD 复制本地文件到镜像
      • EXPOSE 设置开放端口
      • CMD 容器启动后允许的程序
      • WORKDIR 切换工作目录
    • -t 添加tag
    • build后面需要接路径

3.2. 少用镜像命令

  • docker pull(获取镜像)
  • docker push(上传镜像)
  • docker search(搜索镜像)
    • -s N 只搜索指定星级以上的镜像
  • docker rmi(删除镜像)
  • docker tag [id] [new name:tag] (修改tag)
  • docker save(保存镜像)
  • docker load(加载镜像)
    • docker load --input xxx.tar
    • docker load < xxx.tar
    • load与import的区别,镜像是完整的与快照是丢弃历史记录和元数据信息的
  • docker rmi $(docker images -q -f "dangling=true")(清理所有未打过标签的本地镜像)

3.3. 常用容器命令

  • docker run([下载镜像并]启动容器)

    • -t 分配一个伪终端
    • -i 打开标准输入
    • -d 后台运行
    • -v 创建并挂载数据卷(可有多个)
    • --volumes-from 挂载数据卷(可有多个)
    • -p 指定映射端口 (ip:port:containerPort/udp|ip::containerPort|port:containerPort)
    • -P 随机映射端口
    • --name 自定义容器名字
    • --rm 终止后立即删除容器
    • --link : 容器互联
  • docker start(启动已终止容器)
  • docker stop(终止容器)
  • nsenter(进入容器)(推荐)
    • PID=$(docker inspect --format "{{ .State.Pid }}" )
    • nsenter --target $PID --mount --uts --ipc --net --pid

3.4. 少用容器命令

  • docker commit(提交容器)

    • -m --massage="" 提交信息
    • -a --author="" 作者信息
    • -p --pause=true 提交时暂停容器运行
  • docker attach(进入容器)
  • docker ps(查看正在运行的容器)
    • -a 查看已终止
  • docker logs [container ID or NAMES] 查看(后台)运行日志
  • docker export(导出容器为文件)
    • docker export > xxx.tar
  • docker import(文件快照导入镜像)
    • cat xxx.tar | docker import - test/name:v1.0
    • docker import http://xxx.tgz test/name
  • docker rm(删除容器)
    • 默认不会删除运行中的容器
    • docker rm $(docker ps -a -q) 清理所有处于终止状态的容器
    • -v 同时删除数据卷

4. 安装

4.1. 在CentOS7中安装

curl -sSL https://get.docker.com/ | sh        //下载官服脚本按照
chkconfig docker on //设置开机自动启动

4.2. 在CentOS6中安装

4.2.1. 添加yum软件源

tee /etc/yum.repo.d/docker.repo << 'EOF'
[dockerrepo]
name=Docker Repository
baseurl=https://yum.dockerproject.org/repo/main/centos/$releasever/
enabled=
gpgcheck=
gpgkey=https://yum.dockerproject.org/gpg
EOF

4.2.2. 安装docker

yum update
yum install -y docker-engine

4.2.3. No module named yum

如果在执行yum update的时候出现了No module named yum错误,可能是存在与yum不对应的python版本引起。可以通过修改yum和yum-updatest的执行脚本(/usr/bin/yum/usr/bin/yum-updatest)的注释来指定python版本。譬如:

#!/usr/bin/python
修改为
#!/usr/bin/python2.

5. 基础环境

可以下载bashrc_docker文件,加载到环境.bashrc中,其可以提供一些方便的命令用于做一些比较复杂的过程。

.bashrc_docker(https://raw.githubusercontent.com/yeasy/docker_practice/master/_local/.bashrc_docker) 定义了以下命令

- docker-pid(获取容器pid)
- docker-enter(进入容器)

下载和加载到linux环境中:

wget -P ~ https://raw.githubusercontent.com/yeasy/docker_practice/master/_local/.bashrc_docker
echo "[ -f ~/.bashrc_docker ] && . ~/.bashrc_docker" >> ~/.bashrc;source ~/.bashrc

6. 仓库

6.1. 私有仓库

官服提供了一个docker-registry镜像来供私有仓库的搭建。

docker run -d -p 201: registry

vi /etc/docker/daemon.json
{"insecure-registries":["myregistry.example.com:5000"]} cul http://x.x.x.x:2010/v2/linerl/tags/list

API文档:https://github.com/docker/distribution/blob/master/docs/spec/api.md

7. 学习后的一些结论

  • 本身是虚拟机技术实现的服务器大多数带有随时可扩展升级的性质,没有资源分配的需求,没有必要用到docker;
  • docker适合在做负载均衡的短链接的web服务上面,应用场景都是以镜像、容器为操作单位的最佳;
  • 如果有业务可以做到镜像、容器来维护就可以的,说明这个业务就很合适使用docker。

以上只是本人刚开始学习的一些理解,当然docker的能力我还远远没理解到,适合的场景肯定还有很多。目前的记录只是为了以后查阅和学习巩固。

[Docker]Docker快速上手学习笔记的更多相关文章

  1. gRPC官方快速上手学习笔记(c#版)

    上手前准备工作 支持操作系统:windows.OS X.Linux.实例采用.net..net core sdk. The .NET Core SDK command line tools. The ...

  2. Sass简单、快速上手_Sass快速入门学习笔记总结

    Sass是世界上最成熟.稳定和强大的专业级css扩展语言 ,除了Sass是css的一种预处理器语言,类似的语言还有Less,Stylus等. 这篇文章关于Sass快速入门学习笔记. 资源网站大全 ht ...

  3. FWT快速沃尔什变换学习笔记

    FWT快速沃尔什变换学习笔记 1.FWT用来干啥啊 回忆一下多项式的卷积\(C_k=\sum_{i+j=k}A_i*B_j\) 我们可以用\(FFT\)来做. 甚至在一些特殊情况下,我们\(C_k=\ ...

  4. 【原创】SpringBoot & SpringCloud 快速入门学习笔记(完整示例)

    [原创]SpringBoot & SpringCloud 快速入门学习笔记(完整示例) 1月前在系统的学习SpringBoot和SpringCloud,同时整理了快速入门示例,方便能针对每个知 ...

  5. docker常用命令,学习笔记

    - 常用命令 https://docs.docker.com images > docker images # 查看本地镜像 > docker images -a # 查看所(含中间镜像层 ...

  6. ASP.NET Core快速入门--学习笔记系列文章索引目录

    课程链接:http://video.jessetalk.cn/course/explore 良心课程,大家一起来学习哈! 抓住国庆假期的尾巴完成了此系列课程的学习笔记输出! ASP.NET Core快 ...

  7. Python快速入门学习笔记(二)

    注:本学习笔记参考了廖雪峰老师的Python学习教程,教程地址为:http://www.liaoxuefeng.com/wiki/001374738125095c955c1e6d8bb49318210 ...

  8. 使用 mongodb 的 Docker Image 快速上手系列 lab

    Docker 主要的概念 Dockerfile => 用來產生 docker image 用的(介紹) Image => 可以用來產生 docker container Container ...

  9. FFT 快速傅里叶变换 学习笔记

    FFT 快速傅里叶变换 前言 lmc,ikka,attack等众多大佬都没教会的我终于要自己填坑了. 又是机房里最后一个学fft的人 早背过圆周率50位填坑了 用处 多项式乘法 卷积 \(g(x)=a ...

随机推荐

  1. python Tab自动补全命令设置

    Mac/Windows下需要安装模块儿 pip install pyreadline pip install rlcompleter pip install readline 注意,需要先安装pyre ...

  2. jsp中两种include的区别【转】

    引用文章:http://www.ibm.com/developerworks/cn/java/j-jsp04293/ http://www.cnblogs.com/lazycoding/archive ...

  3. hadoop-2.2.0 的编译安装及HA配置

    一 准备工作 准备工作中要求有 1.centOs 6.4,添加hadoop用户,配置集群内的/etc/hosts文件. 2.安装hadoop用户的ssh,并打通集群内所有机器,(ha执行fencing ...

  4. 1-13 代理ARP和RARP

    一.代理ARP(Proxy ARP) 因为路由器有阻住广播的作用,如果我们要访问一台远端的主机,那么我们封装的并不是远端的目的MAC地址,而是我们网关的MAC地址. 当我们的网关出现故障,就需要给他重 ...

  5. Perl爬取江西失信执行

    #! /usr/bin/perl use strict; use Encode qw(encode decode); binmode(STDIN,":encoding(utf8)" ...

  6. Logstash 父子关系 配置

    最近在使用Lostash的过程中遇到了一个问题:在一个log文件里包含两类数据,而且两类数据之间存在父子关系,那如何使用lostash的configuration实现这个需求呢 思路: 首先定义父事件 ...

  7. (转载)SPRINGMVC表单标签简介

    SpringMVC表单标签简介 在使用SpringMVC的时候我们可以使用Spring封装的一系列表单标签,这些标签都可以访问到ModelMap中的内容.下面将对这些标签一一介绍. 在正式介绍Spri ...

  8. ngx.lua中遇到的小问题2

    用lua+drizzle在数据库中插入数据失败(不能访问数据库) 后面发现原来是nginx配置文件中的drizzle模块部分最后多了一行  content_by_lua 'ngx.say(" ...

  9. cf 733f

    给你很多条边,每条边有一个初始边权w1,然后还有一个值表示把这个边权减一的代价w2,然后给你一个预算budget,然后让你输出怎么选边之后构成的树的边权和最小(在用budget减少了边权之后),输出你 ...

  10. 利用qmake生成Makefile文件

    在linux下写程序,免不了要写Makefile文件,用automake,总感觉比较麻烦,linux人喜欢做麻烦的事,以显得风格迥异. 其实用qmake生成Makefile文件相当简单. 1 装好qm ...