>>> 目录 <<<

  • Docker简介
  • Docker优势
  • Docker基本概念
  • Docker安装使用
  • Docker常用命令
  • Docker镜像构建
  • Docker本地仓库
  • Docker与图形管理工具Portainer
  • Docker与集群管理工具Swarm
  • Docker与持续集成工具Jenkins
  • Docker后续问题
  • Docker报错解决

>>> 正文 <<<

一、    Docker简介

   Docker是一个开源的应用容器引擎,开发者可以打包自己的应用到容器里面,然后迁移到其他机器的docker应用中,可以实现快速部署。

   简单的理解,docker就是一个软件集装箱化平台,就像船只、火车、卡车运输集装箱而不论其内部的货物一样,软件容器充当软件部署的标准单元,其中可以包含不同的代码和依赖项。

   按照这种方式容器化软件,开发人员和 IT 专业人员只需进行极少修改或不修改,即可将其部署到不同的环境,如果出现的故障,也可以通过镜像,快速恢复服务。

二、    Docker优势

  1.   特性优势

2.  资源优势

 

三、    Docker基本概念

Client(客户端):是Docker的用户端,可以接受用户命令和配置标识,并与Docker daemon通信。

Images(镜像):是一个只读模板,含创建Docker容器的说明,它与操作系统的安装光盘有点像。

Containers(容器):镜像的运行实例,镜像与容器的关系类比面向对象中的类和对象。

Registry(仓库):是一个集中存储与分发镜像的服务。最常用的Registry是官方的Docker Hub 。

四、    Docker安装使用

  • 操作系统:CentOS 7

1、安装依赖

yum install -y yum-utils device-mapper-persistent-data lvm2

2、添加软件源

yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

3、安装docker-ce

yum clean all  yum makecache fast        # 重新生成缓存

yum -y install docker-ce docker-ce-cli containerd.io

4、设置自启并启动

systemctl enable docker

systemctl start docker

5、查看版本

docker version

  

  • 运行示例:Nginx

1、搜索并下载镜像

docker search nginx

docker pull nginx

2、启动一个容器并映射端口到本地

docker run -d -p 8080:80 --name Nginx nginx

3、访问本地映射端口

五、    Docker常用命令

  1.     镜像控制

 搜索镜像:docker  search  [OPTIONS]  TERM

上传镜像:docker  push  [OPTIONS]  NAME[:TAG]

下载镜像:docker  pull  [OPTIONS]  NAME[:TAG]

提交镜像:docker  commit [OPTIONS]  CONTAINER  NAME[:TAG]

构建镜像:docker  build  [OPTIONS]  PATH

删除镜像:docker  rmi [OPTIONS]  IMAGE  [IMAGE...]

增加镜像标签:docker  tag  SOURCE_IMAGE[:TAG]  TARGET_IMAGE[:TAG]

查看镜像:docker  images  [OPTIONS]  [REPOSITORY[:TAG]]

  2.     容器控制

启动/重启容器:docker start/restart CONTAINER_ID/CONTAIN_NAME

停止/强停容器:docker stop/ kill CONTAINER_ID/CONTAIN_NAME

删除容器:docker rm [OPTIONS] CONTAINER [CONTAINER...]

重命名容器:docker rename CONTAIN_OLD CONTAIN_NEW

进入容器:docker exec -it CONTAINER_ID bash

查看容器日志:docker logs [OPTIONS] CONTAINER

查看容器:docker ps [OPTIONS]

  

  3.     容器启动

docker  run  [OPTIONS]  IMAGE  [COMMAND]  [ARG...]

-d : 后台运行容器,并返回容器ID

-i以交互模式运行容器,通常与 -t 同时使用

-t为容器重新分配一个伪输入终端,通常与 -i 同时使用

-v绑定挂载目录

--name="mycontainer": 为容器指定一个名称

--net="bridge": 指定容器的网络连接类型,支持如下:

  bridge / host / none / container:<name|id>

-p/-P :端口映射,格式如图:

    

   4.     其他命令

查看docker信息:docker info

docker命令帮助:docker run --help

复制文件到容器:docker cp custom.conf Nginx:/etc/nginx/conf.d/

更新容器启动项:docker container update --restart=always nginx

查看docker日志:tail -f /var/log/messages

六、    Docker镜像构建

  1.     Docker commit(三步构建)

a)   运行容器

docker run -dit -p 8080:80 --name Nginx nginx

b)   修改容器

docker cp custom.conf Nginx:/etc/nginx/conf.d/

c)   将容器保存为新的镜像

docker commit Nginx zwx/nginx

  

2.     Dockerfile(两步运行)

a)   编写Dockerfile文件

vim Dockerfile

b)   执行Dockerfile文件

docker build -t zwx/nginx .                                                    

  

3.     Dockerfile 常用指令

七、    Docker本地仓库

  1、拉取镜像仓库

docker pull registry

2、启动镜像服务

docker run -d -p 5000:5000 --name=Registry \

--restart=always \                # 自动重启

--privileged=true \              # 增加安全权限

-v /usr/local/docker_registry:/var/lib/registry  docker.io/registry

3、注册https协议

vim /etc/docker/daemon.json

{ "insecure-registries":[" localhost:5000"] }

4、新增tag指明仓库地址

docker tag zwx/nginx localhost:5000/zwx/nginx

5、上传镜像到本地仓库

docker push localhost:5000/zwx/nginx

6、查看本地仓库

curl -XGET http://localhost:5000/v2/_catalog

  >>> 更多可以参考:docker 搭建本地私有仓库

八、    Docker与图形管理工具Portainer

  1.     简介

    Portainer是Docker的图形化管理工具,提供状态显示面板、应用模板快速部署、容器镜像网络数据卷的基本操作(包括上传下载镜像,创建容器等操作)、

    事件日志显示、容器控制台操作、Swarm集群和服务等集中管理和操作、登录用户管理和控制等功能。功能十分全面,基本能满足中小型单位对容器管理的全部需求。

    

  2.     安装使用

a) 下载镜像

docker pull portainer/portainer

b) 单机版运行

docker run -d -p 9000:9000 -v /var/run/docker.sock:/var/run/docker.sock \

--restart=always --name Prtainer portainer/portainer

c) 访问http://localhost:9000

  首次登陆需要注册用户,给admin用户设置密码,然后单机版选择local连接即可。

d) 控制管理

     

      >>> 更多可以参考:Portainer介绍

九、    Docker与集群管理工具Swarm

  1.     简介

    Swarm是Docker官方提供的一款集群管理工具,其主要作用是把若干台Docker主机抽象为一个整体,并且通过一个入口统一管理这些Docker主机上的各种Docker资源。

    

  2.     安装使用

    ……待续,可先参考:【Docker】 Swarm简单介绍

十、    Docker与持续集成工具Jenkins

  

十一、    Docker后续问题

    • 集群环境
    • 网络安全
    • 存储管理
    • 日志收集
    • 实时监控
    • 性能调优
    • ……

十二、Docker报错解决

Docker常见报错解决方法记录

    • 【问题一】OCI runtime exec failed......executable file not found in $PATH": unknown
    • 【问题二】http: server gave HTTP response to HTTPS client
    • 【问题三】getsockopt: connection refused
    • 【问题四】Cannot connect to the Docker daemon at unix:///var/run/docker.sock. Is the docker daemon running?

【解决】Got permission denied while trying to connect to the Docker daemon socket at......dial unix /var/run/docker.sock: permission denied

如果想更详细,更深入了解Docker,推荐 >>> Docker最全教程——从理论到实战(一)

Docker实战总结的更多相关文章

  1. 【原创】Docker实战 Dockerfile最佳实践&&容器之间通信

    官方最佳实践文档 https://docs.docker.com/develop/develop-images/dockerfile_best-practices/#from Docker实战(三十) ...

  2. Docker03 Docker基础知识、Docker实战

    1 Docker基础知识 1.1 什么是Docker Docker是一个可以装应用的容器,就像杯子可以装水.书包可以装书一样:docker官网 Docker是Docker公司开发的,并开源到GitHu ...

  3. Ubuntu Server下docker实战 02: docker进阶配置

    在上一篇文章里<Ubuntu Server下docker实战 01: 安装docker>,我们已经把docker安装起来了,并运行了一个hello-world 这一篇,我们继续讲进阶配置. ...

  4. [置顶] Docker学习总结(1)——Docker实战之入门以及Dockerfile(一)

    一.Docker是什么? 首先Docker是软件工业上的集装箱技术 回顾,在没有集装箱出现以前,传统运输行业中,会存在这些问题: 在运输过程中,货物损坏 装卸.运输货物,效率低下 运输手续繁多及运输环 ...

  5. Docker 实战—使用 Dockerfile 构建镜像

    Dockerfile 指令详解请访问:https://www.cnblogs.com/cloudfloating/p/11737447.html 使用 Alpine Linux 作为基础镜像 Alpi ...

  6. netcore 创建腾讯云私有镜像 发布到docker 实战

    上一篇博客写的 netcoer上传到docker ,编译 并发布,传送门:FineUICore基础版部署到docker实战 这是一种笨方法,理想的方法是,在本地编译成镜像,然后推送到镜像仓库,服务器的 ...

  7. Docker实战之Redis-Cluster集群

    概述 接上一篇Docker实战之MySQL主从复制, 这里是Docker实战系列的第二篇,主要进行Redis-Cluster集群环境的快速搭建.Redis作为基于键值对的NoSQL数据库,具有高性能. ...

  8. Docker实战之Consul集群

    前言 最近参加了几场 Java 面试,发现大多数的微服务实践还是 Eureka 偏多,鉴于笔者的单位选型 Consul,这里对 Consul 做简单总结. 该篇是 Docker 实战系列的第三篇.传送 ...

  9. Docker实战之Zookeeper集群

    1. 概述 这里是 Docker 实战系列第四篇.主要介绍分布式系统中的元老级组件 Zookeeper. ZooKeeper 是一个开源的分布式协调服务,是 Hadoop,HBase 和其他分布式框架 ...

  10. Docker实战 | 第二篇:IDEA集成Docker插件实现一键自动打包部署微服务项目,一劳永逸的技术手段值得一试

    一. 前言 大家在自己玩微服务项目的时候,动辄十几个服务,每次修改逐一部署繁琐不说也会浪费越来越多时间,所以本篇整理通过一次性配置实现一键部署微服务,实现真正所谓的一劳永逸. 二. 配置服务器 1. ...

随机推荐

  1. 服务网关Spring Cloud Zuul

    Spring Cloud Zuul 开发环境 idea 2019.1.2 jdk1.8.0_201 Spring Boot 2.1.9.RELEASE Spring Cloud Greenwich S ...

  2. spring boot通过Spring Data Redis集成redis

    在spring boot中,默认集成的redis是Spring Data Redis,Spring Data Redis针对redis提供了非常方便的操作模版RedisTemplate idea中新建 ...

  3. Beautiful Soup 4.2.0 文档(一)

    Beautiful Soup 是一个可以从HTML或XML文件中提取数据的Python库.它能够通过你喜欢的转换器实现惯用的文档导航,查找,修改文档的方式.Beautiful Soup会帮你节省数小时 ...

  4. Web安全之url跳转漏洞及bypass总结

    0x01 成因 对于URL跳转的实现一般会有几种实现方式: META标签内跳转 javascript跳转 header头跳转 通过以GET或者POST的方式接收将要跳转的URL,然后通过上面的几种方式 ...

  5. 代码审计-phpcms9任意文件读取

    漏洞文件: /phpcms/modules/content/down.php download函数 这个函数开始几行代码的作用和init函数中的几乎一样,都是从parse_str 解析传入的a_k参数 ...

  6. msf之hash攻击

    使用hashdump抓取密码(需要系统管理权限) 另外一个更强大的模块 smart_hashdump 如果目标是win7 就需要先绕过UAC 还可以使用msf内置的mimikatz抓取hash msv ...

  7. [Abp vNext 源码分析] - 11. 用户的自定义参数与配置

    一.简要说明 文章信息: 基于的 ABP vNext 版本:1.0.0 创作日期:2019 年 10 月 23 日晚 更新日期:暂无 ABP vNext 针对用户可编辑的配置,提供了单独的 Volo. ...

  8. POJ 1276 Cash Machine(多重背包的二进制优化)

    题目网址:http://poj.org/problem?id=1276 思路: 很明显是多重背包,把总金额看作是背包的容量. 刚开始是想把单个金额当做一个物品,用三层循环来 转换成01背包来做.T了… ...

  9. (转)python中@property详解

    转:https://www.cnblogs.com/zhangfengxian/p/10199935.html

  10. 时序数据库InfluxDB(I)- 搭建与采集信息demo操作

    搭建环境:vmware workstation pro15.5.0, ubuntu18.04.3 实践时间:2019.10.12-10.27 (一)时序数据库InfluxDB准备 (1)安装 曾出现问 ...