Docker你入门了吗?一套骚指令带你入门!

287 阅读5分钟

在学习docker之前是比较困惑的总感觉很难,后来尝试了之后发现还是比较简单的,使用一下命令大概就懂了,先分享一下入门类的文章吧,后期将更新出docker的一些硬核知识(应该比较久嘿嘿)

引言

为什么会出现Docker?

Docker的出现,解决的是部署环境的问题,以及在平时开发中常常会遇到过那些,在我的电脑上可以使用到了你那边就不能使用的情况。

最重要的还是集群的环境部署问题。一台电脑同时部署MySQL,Redis,RabbitMQ,ZK,ES等就已经非常麻烦了,如果是上百台服务器呢?而且有些时候环境出错还要重来。这个是比较费事费时费力的。所以Docker上线了。

Docker是什么?

Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从 Apache2.0 协议开源。

Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。

容器是完全使用沙箱机制,相互之间不会有任何接口(类似 iPhone 的 app),更重要的是容器性能开销极低。

Docker有什么优点?

Docker 是一个用于开发,交付和运行应用程序的开放平台。Docker 使您能够将应用程序与基础架构分开,从而可以快速交付软件。借助 Docker,您可以与管理应用程序相同的方式来管理基础架构。通过利用 Docker 的方法来快速交付,测试和部署代码,您可以大大减少编写代码和在生产环境中运行代码之间的延迟。 1、快速,一致地交付您的应用程序 2、响应式部署和扩展 3、在同一硬件上运行更多工作负载 4、轻巧

Docker思想

类似于集装箱的性质,每一个集装箱都是隔离的,容器化。 紧接着容器化又涉及了一些虚拟化。

虚拟化技术

里面内核,lib,app应用等内存占用是非常大的。 在这里插入图片描述 容器化技术

里面的容器直接运行在内核之上,它可以最大程度上节省服务器资源。每个容器间是互相隔离的。每个容器内都有一个属于自己的文件系统。互不影响 在这里插入图片描述

Docker架构组成

在这里插入图片描述 镜像(images): 镜像就好比是一个模板,可以通过一个模板创建容器服务。一个容器服务无限克隆部署在其他电脑上使用。简化部署环境的问题。 容器(container): docker利用容器化技术,独立运行一个或者运行一组应用,通过镜像来创建 仓库(repository): 类似于github

Docker常用命令

Linux安装(建议)

curl -sSL https://get.daocloud.io/docker | sh

在这里插入图片描述

docker版本号

docker -v

在这里插入图片描述

启动docker(通过系统)

sudo systemctl start docker

sudo systemctl status docker

在这里插入图片描述

docker详细版本

docker version

在这里插入图片描述

docker详细信息

docker info

在这里插入图片描述

docker帮助信息

docker --help

在这里插入图片描述

镜像信息

##列出本地images
docker images

## REPOSITORY:表示镜像的仓库源

## TAG:镜像的标签

## IMAGE ID:镜像ID

## CREATED:镜像创建时间

## SIZE:镜像大小

##含中间映像层
docker images -a

##只显示镜像ID
docker images -q

##含中间映像层
docker images -qa  

##显示镜像摘要信息(DIGEST列)
docker images --digests

##显示镜像完整信息
docker images --no-trunc 

搜索仓库MySQL镜像

docker search mysql

## --filter=stars=600:只显示 starts>=600 的镜像  这里就不截图了  这个就是过滤一下
docker search --filter=stars=600 mysql

## --no-trunc 显示镜像完整 DESCRIPTION 描述
docker search --no-trunc mysql

## --automated :只列出 AUTOMATED=OK 的镜像
docker search  --automated mysql

在这里插入图片描述

镜像下载(比如Redis)

##下载Redis官方最新镜像,相当于:docker pull redis:latest
docker pull redis

##下载仓库所有Redis镜像
docker pull -a redis

##下载私人仓库镜像
docker pull bitnami/redis

在这里插入图片描述

镜像删除(这个就不演示了)

##单个镜像删除,相当于:docker rmi redis:latest
docker rmi redis

##强制删除(针对基于镜像有运行的容器进程)
docker rmi -f redis

##多个镜像删除,不同镜像间以空格间隔
docker rmi -f redis tomcat nginx

##删除本地全部镜像
docker rmi -f $(docker images -q)

镜像构建

##(1)编写dockerfile
cd /docker/dockerfile
vim mycentos

##(2)构建docker镜像
docker build -f /docker/dockerfile/mycentos -t mycentos:1.1

容器启动

tip:此时使用"docker ps -a"会发现容器已经退出。这是docker的机制:要使Docker容器后台运行,就必须有一个前台进程。解决方案:将你要运行的程序以前台进程的形式运行。

##新建并启动容器,参数:-i  以交互模式运行容器;-t  为容器重新分配一个伪输入终端;--name  为容器指定一个名称
docker run -i -t --name mycentos

##后台启动容器,参数:-d  已守护方式启动容器
docker run -d mycentos

容器进程

##top支持 ps 命令参数,格式:docker top [OPTIONS] CONTAINER [ps OPTIONS]
##列出redis容器中运行进程
docker top redis

##查看所有运行容器的进程信息
for i in  `docker ps |grep Up|awk '{print $1}'`;do echo \ &&docker top $i; done

容器日志

##查看redis容器日志,默认参数
docker logs redis

##查看redis容器日志,参数:-f  跟踪日志输出;-t   显示时间戳;--tail  仅列出最新N条容器日志;
docker logs -f -t --tail=20 redis
##查看容器redis从2019年05月21日后的最新10条日志。
docker logs --since="2019-05-21" --tail=10 redis

容器的进入与退出

##使用run方式在创建时进入
docker run -it centos /bin/bash

##关闭容器并退出
exit

##仅退出容器,不关闭
快捷键:Ctrl + P + Q

##直接进入centos 容器启动命令的终端,不会启动新进程,多个attach连接共享容器屏幕,参数:--sig-proxy=false  确保CTRL-D或CTRL-C不会关闭容器
docker attach --sig-proxy=false centos 

##在 centos 容器中打开新的交互模式终端,可以启动新进程,参数:-i  即使没有附加也保持STDIN 打开;-t  分配一个伪终端
docker exec -i -t  centos /bin/bash

##以交互模式在容器中执行命令,结果返回到当前终端屏幕
docker exec -i -t centos ls -l /tmp

##以分离模式在容器中执行命令,程序后台运行,结果不会反馈到当前终端
docker exec -d centos  touch cache.txt 

查看容器

##查看正在运行的容器
docker ps
##查看正在运行的容器的ID
docker ps -q
##查看正在运行+历史运行过的容器
docker ps -a
##显示运行容器总文件大小
docker ps -s
##显示最近创建容器
docker ps -l
##显示最近创建的3个容器
docker ps -n 3
##不截断输出
docker ps --no-trunc 
##获取镜像redis的元信息
docker inspect redis
##获取正在运行的容器redis的 IP
docker inspect --format='{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' redis

容器的停止与删除

##停止一个运行中的容器
docker stop redis
##杀掉一个运行中的容器
docker kill redis
##删除一个已停止的容器
docker rm redis
##删除一个运行中的容器
docker rm -f redis
##删除多个容器
docker rm -f $(docker ps -a -q)
docker ps -a -q | xargs docker rm
## -l 移除容器间的网络连接,连接名为 db
docker rm -l db 
## -v 删除容器,并删除容器挂载的数据卷
docker rm -v redis

生成镜像

##基于当前redis容器创建一个新的镜像;参数:-a 提交的镜像作者;-c 使用Dockerfile指令来创建镜像;-m :提交时的说明文字;-p :在commit时,将容器暂停
docker commit -a="DeepInThought" -m="my redis" [redis容器ID]  myredis:v1.1

容器与主机间的数据拷贝

##将rabbitmq容器中的文件copy至本地路径
docker cp rabbitmq:/[container_path] [local_path]
##将主机文件copy至rabbitmq容器
docker cp [local_path] rabbitmq:/[container_path]/
##将主机文件copy至rabbitmq容器,目录重命名为[container_path](注意与非重命名copy的区别)
docker cp [local_path] rabbitmq:/[container_path]

底层原理

Run运行流程

在这里插入图片描述

Docker是怎么工作的?

Docker是一个Client - Server结构的系统,Docker的守护进程运行在主机上。通过Socket从客户端访问! DockerServer接收到Docker-Client的指令,就会执行这个命令! 在这里插入图片描述

Docker为什么比vm快?

  1. Docker有着比虚拟机更少的抽象层
  2. Docker利用的是宿主机的内核,vm需要是Guest OS。 在这里插入图片描述

所以,新增一个容器的时候,docker不需要像虚拟机一样重新加载一个操作系统的内核,避免引导! 在这里插入图片描述

今后用到的将持续更新...