>>> 目录 <<<

  • 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. Xadmin查询

    目录 深浅coopy运用 ModelForm的补充 提取模型当中相关属性 getattr和get_field的区别 __ str__,get_field,getattr初识 str ,当用getatt ...

  2. Windows 10 更新后VMware Workstation pro无法运行 (无需卸载原版本VM)

    问题 描述:当前Windows版本是win10-1903,VMware版本比较老旧是VMware Workstation Pro 15.0.4:国庆节后微软推送了一个新的更新补丁,10月10日更新之后 ...

  3. Switch-case语句的应用

    /** switch语句有关规则    • switch(表达式)中表达式的值必须是下述几种类型之一:byte,short, char,int,枚举 (jdk 5.0),String (jdk 7.0 ...

  4. SQL SERVER数据库,按年、月、日、时、分、秒计算两个时间字段之间的间隔时间样例

    使用DATEDIFF(取值,时间字段1,时间字段2) 举例: SELECT DATEDIFF(YEAR,DRYSJ,DCYSJ),* FROM YXHIS2019..TBZYBR2019 --SQL ...

  5. Node Sass could not find a binding for your current environment: OS X 64-bit with Node.js 10.x

    运行Reac项目报: Node Sass could not find a binding for your current environment: OS X 64-bit with Node.js ...

  6. .NET LINQ分析AWS ELB日志避免996

    前言 小明是个单纯的.NET开发,一天大哥叫住他,安排了一项任务: "小明,分析一下我们超牛逼网站上个月的所有AWS ELB流量日志,这些日志保存在AWS S3上,你分析下,看哪个API的响 ...

  7. (19)ASP.NET Core EF创建模型(包含属性和排除属性、主键、生成的值)

    1.什么是Fluent API? EF中内嵌的约定将POCO类映射到表.但是,有时您无法或不想遵守这些约定,需要将实体映射到约定指示外的其他对象,所以Fluent API和注解都是一种方法,这两种方法 ...

  8. Python多线程多进程那些事儿看这篇就够了~~

    自己以前也写过多线程,发现都是零零碎碎,这篇写写详细点,填一下GIL和Python多线程多进程的坑~ 总结下GIL的坑和python多线程多进程分别应用场景(IO密集.计算密集)以及具体实现的代码模块 ...

  9. Mongoose-modified-at 时间自动记录插件介绍

    Mongoose-modified-at 是一款自动更新字段变化时间并记录到数据库中的 Mongoose 插件,类似 Mongoose 自带的 timestamps 功能. 使用场景 让我们考虑一个场 ...

  10. redis之Scan

    scan 相比keys 具备有以下特点:1.复杂度虽然也是 O(n),但是它是通过游标分步进行的,不会阻塞线程;2.提供 limit 参数,可以控制每次返回结果的最大条数,limit 只是一个 hin ...