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

PS :个人所有读书笔记只记录个人想要的内容,很可能原书大量内容没有纳入笔记中... ... 

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

《 Docker 技术入门与实战 》读书笔记 ( CentOS 安装 Docker )_第1张图片

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 技术入门与实战 》读书笔记 ( CentOS 安装 Docker )_第2张图片

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

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

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

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

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

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

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

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

16. 创建容器 : 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=" " :指定容器名 。 

17. 终止运行中的容器 : docker stop 。

18. 进入容器以便可以执行任意命令: 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 :删除容器挂载的数据卷 。

20. 导出容器:docker export  。    

-o 指定导出的 tar 文件,也可以直接重定向实现

    如: docker export -o test.tar 容器名、id  或 docker export 容器名、id > test.tar 。

21. 导入已导出的 tar 文件生成镜像:docker import 。   

 -c | --change=[ ] 导入时执行对容器进行修改的 Dockerfile 。

    如: docker import test.tar  -test/ubuntu:v1.o 。

22. docker load 和 docker impoer 区别: 

 load 命令导入镜像存储文件到镜像库,将保存完整记录,体积大。

 import 命令导入一个快照到本地镜像库,会丢弃所有历史记录和元数据信息。   

23. 搭建本地私有仓库: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 目录下 。

24. 数据卷是可供容器使用的特殊目录,它将主机操作目录直接映射进容器。

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

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

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

参数说明:

《 Docker 技术入门与实战 》读书笔记 ( CentOS 安装 Docker )_第3张图片

《 Docker 技术入门与实战 》读书笔记 ( CentOS 安装 Docker )_第4张图片

28. docker build 创建容器 :docker build Dockerfile文件名  。

    -t:指定生成镜像的标签名,即 tag 。

    -f:若 Dockerfile 不在当前路径下,可使用 -f 来指定 Dockerfile 路径 。

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

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

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

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

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

33. 安装运行 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 。

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

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

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

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

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

 

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

 

38.   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 :输出版本并退出。

--verbose :输出更多调试信息。

 

你可能感兴趣的:(Docker,读书感念,笔记)