《Docker 技术入门与实战 》读书笔记 ( CentOS 安装 Docker )

原博: https://blog.csdn.net/u011314442/article/details/80958318
PS :个人所有读书笔记只记录个人想要的内容,很可能原书大量内容没有纳入笔记中… …

以下全文内容出自书目:《 Docker 技术入门与实战 》
●笔记 - docker -《Docker 技术入门与实战 》

  1. Docker 镜像:一个只读模板,是创建容器的基础 。

  2. Docker 容器:从镜像创建运行的实例 ,可以看作是一个简易版本的 Linux 系统环境 。

  3. Docker 仓库:集中存放镜像文件的场所 。

  4. Docker 目前只能运行在 64 位平台上,并要求内核版本不低于 3.10 (可用 uname -a 或者 cat /proc/version 查看自己内核详情)。

  5. Ubuntu 安装 Docker :apt-get install -y docker-engine ( 见书P12 ) 。

  6. CentOS 安装 Docker :
    ●笔记 - docker -《Docker 技术入门与实战 》

  7. docker 服务开启/重启方式:systemctl start docker.service 、 service docker restart 。

  8. 查看 docker 版本信息: docker version 。

  9. 查看镜像 : docker images

    -a : 列出所有镜像。
     
    --digests=true|false :列出镜像数字摘要,默认为否。
     
    -f ,--filter=[] : 过滤列出镜像,如 dangling=true 只显示没有被使用的镜像 。
     
    --format="TEMPLATE":控制输出格式,如 ID 代表 ID 信息, .Repository 代表仓库信息 。
     
    --no-trunc=true|false : 是否截断输出结果中太长的部分 。
     
    -q ,--quiet=true|false : 仅输出 ID ,默认为否 。

-------------------------------------- 以下更新于2018.7.9 --------------------------------------

  1. 查看镜像创建过程: docker history 镜像名。

  2. 删除镜像: docker rmi 镜像名、镜像ID(当镜像只剩下一个 tag 时会彻底删除镜像,命令 docker images 可查看镜像)。

  3. 查看所有容器 : docker ps -a 。

  4. 镜像导出到本地文件:docker save -o xxx.tar 原镜像名。

  5. 镜像导入: docker load < 镜像名 或 docker load --input 镜像名,如 docker load < xxx.tar 。

    ( A导出 + B导入 + run 可以把一个工程从服务器 A 拷贝到服务器 B 并部署运行,见第 20、21 点 。)

  6. 上传镜像到仓库 :docker push ,默认是上传到 Docker Hub 官方仓库 。

  7. 创建容器 : docker create 镜像名,参数如下: (另一种创建方式见第 28 点。)

  -d:后台运行。

  -i:保持标准输入打开,默认为 false 。

  --net="bridge" :指定容器网络模式 。

  --rm=true :容器退出后自动删除 ( 不能和 -d 同时使用 )。

  -t: 分配一个伪终端,默认为 false 。

  -v | --volume=本机目录 : 容器目录 : 挂载主机上文件卷到容器 。

  --volume-from=[ ]  : 从其它容器挂载卷 。

  -w | --workdir=" "  : 容器的默认工作目录 。 

  -e | --env=[ ] :指定容器环境变量 。

  -h | --hostname=" "  : 指定容器内的主机名 。 

  --link=[ < name or id >:alias ] :链接到其它容器 。 

  --name=" " :指定容器名 。 
  1. 终止运行中的容器 : docker stop 。

  2. 进入容器以便可以执行任意命令: docker exec 容器名、id,如:docker exec -it 镜像id /bin/bash 。参数如下:

    --privileged=true :给执行命令以最高权限,默认为 false 。
 
    -u | --user=" " :执行命令的用户名或 ID 。
 
    -i : 开启标准输入 。 
 
    -t:分配伪终端,默认为 false 。

19 . 删除容器:docker rm ,参数如下:


    -f: 强行终止并删除运行中的容器 。
 
    -l | --link=false : 删除容器链接,但保留容器 。
 
    -v | --volumes=false :删除容器挂载的数据卷 。
  1. 导出容器:docker export 。
-o 指定导出的 tar 文件,也可以直接重定向实现
 如: docker export -o test.tar 容器名、id  或 docker export 容器名、id > test.tar 。
  1. 导入已导出的 tar 文件生成镜像:docker import 。
 -c | --change=[ ] 导入时执行对容器进行修改的 Dockerfile 。
    如: docker import test.tar  -test/ubuntu:v1.o 。
  1. docker load 和 docker impoer 区别:
 load 命令导入镜像存储文件到镜像库,将保存完整记录,体积大。
 
 import 命令导入一个快照到本地镜像库,会丢弃所有历史记录和元数据信息。   
  1. 搭建本地私有仓库:docker run -d -p 5000:5000 registry ,见书 P49 。

这会自动下载并启动一个 registry 容器,创建本地的私有仓库 。

 -v : 将镜像文件存放在本地指定路径,默认是将仓库创建在 /tmp/registry 目录下 。
如:docker run  -d  -p  5000:5000  -v  /opt/data/registry:tmp/registry  registry 则会将上传的镜像放到 /opt/data/registry 目录下 。
  1. 数据卷是可供容器使用的特殊目录,它将主机操作目录直接映射进容器。
-v 可以在 docker run 运行的容器内创建一个数据卷。多次重复使用则创建多个数据卷。
 
- p 是将容器服务暴露的端口,是自动映射到本地主机的临时端口 。   
如:docker run -d -p --name web -v /webapp train python app.py 

用镜像 train 创建了容器 web ,并创建了一个数据卷挂载到容器的 /webapp 目录 。

-v 也可以指定挂载一个本地已有目录到容器中去作为数据卷 。
挂载数据卷的默认权限是 读写,可以用 ro 指定为只读,这样容器对所挂载数据卷内的内容就不能修改了 。 

如: docker run -d -p --name web -v /src/webapp : /opt/web : ro train python app.py

上面是加载主机的 /src/webapp 目录到容器的 /opt/web 目录 ,并且是只读 。

// 25. 利用数据卷容器来迁移数据见书 P55 。

  1. 安装 ping :apt-get install -yqq inetutils-ping 。

  2. 通常 Dockerfile 分为四部分:基础镜像信息、维护者信息、镜像操作指令、容器启动时执行指令。

参数说明:
●笔记 - docker -《Docker 技术入门与实战 》
●笔记 - docker -《Docker 技术入门与实战 》

  1. docker build 创建容器 :docker build Dockerfile文件名 。
    -t:指定生成镜像的标签名,即 tag 。
 
    -f:若 Dockerfile 不在当前路径下,可使用 -f 来指定 Dockerfile 路径 。

如: docker build -t sshd:docker . 最后一个“.”表示使用当前路径下的 Dockerfile 文件 。

// 29. docker 安装和使用各个操作系统见书 P71 。

  1. 安装 openssh-server : apt-get install openssh-server -y 。

  2. 查看端口占用: netstat -tunlp 。

// 32. Docker Web 服务与应用(Apache、Nginx、Tomcat、Jetty、LAMP、CMS)见书 P83 。

  1. 安装运行 mysql :( 使用官方镜像快速启动一个 mysql 服务实例 )

    docker run --name jy_mysql -e MYSQL_ROOT_PASSWORD=123 -d mysql:latest 。

    执行完,mysql 就在 docker 中安装好了,可用 navicat 直接访问 。

    本地找不到的镜像会自动从Docker 仓库中下载最新版本。

    进入 mysql 容器: docker exec -it jy_mysql bash ,查看日志 :docker logs jy_mysql 。

  2. 安装运行 MongoDB: docker run --name mongoDB -d mongo 。

  3. 安装运行 Redis:docker run --name redis -d redis 。

  4. 安装运行 memcache : docker run --name memcache -d memcached 。

// 37. 搭建 cassandra 集群见书 P109 。

      Docker 快速部署 RabbitMQ、Celery、Hadoop、Spark、Elasticsearch 见书P112 。

-------------------------------------- 以下更新于2018.7.28 --------------------------------------

  1. Docker Compose安装命令:sudo pip install -U docker-compose。
-f | --file :指定 compose 模板文件,默认为 docker-compose.yml ,可多次指定。
 
-p | --projrct-name:指定项目名称,默认使用所在目录名称为项目名。
 
--x-networking :使用 docker 可插拨网络后端特性。
 
--x-network-driver DRIVER :指定网络后端驱动,默认为 brige。
 
-v | --version :输出版本并退出。

作者:微风–轻许–
来源:CSDN
原文:https://blog.csdn.net/jiangyu1013/article/details/80958318
版权声明:本文为博主原创文章,转载请附上博文链接!

相关文章: