devops简介

DevOps是Development和Operations两个词的缩写,引用百度百科的定义:

DevOps是一种方法或理念,它涵盖开发、测试、运维的整个过程。

DevOps是提高软件开发、测试、运维、运营 等各部门的沟通与协作质量的方法和过程,DevOps强调软件开发人员与软件测试、软件运维、质量保障(QA)部 门之间有效的沟通与协作,强调通过自动化的方法去管理软件变更、软件集成,使软件从构建到测试、发布更加快捷、可靠,最终按时交付软件。
在这工程中会使用到一堆的工具,比如git,maven,docker,Jenkins等
最终达到提升开发,测试,运维的效果.

devops-Docker学习

开发即运维-开发可以做运维事情,开发出来的东西就是要快速部署东西

devops-Docker学习

使用一系列工具完成自动处理,达到开发出来就是要拿去部署.解决开发环境和部署的环境不一致而导致反复部署过程.虽然增加了开发人员工作量,对整个公司有好处,提高了运维效率,降低了公司成本.

Docker简介

学习Docker我们需要 先了解虚拟化

虚拟化

在计算机中,虚拟化(英语:Virtualization)是一种资源管理技术,是将计算机的各种实体资源,如服务器、网络、内存及存储等,予以抽象、转换后呈现出来,打破实体结构间的不可切割的障碍,使用户可以比原本的组态更好的方式来应用这些资源。

在实际的生产环境中,虚拟化技术主要用来解决高性能的物理硬件产能过剩和老的旧的硬件产能过低的重组重用,透明化底层物理硬件,从而最大化的利用物理硬件 对资源充分利用

虚拟化技术种类很多,例如:软件虚拟化、硬件虚拟化、内存虚拟化、网络虚拟化(vip)、桌面虚拟化、服务虚拟化、虚拟机等等。

Docker是什么

devops-Docker学习
容器化虚拟技术,和vm相比一个天上一个地下.
集装箱的思想. 安装自行车–直接装好发给你

Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的 Linux或Windows 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口

容器与虚拟机比较

1)本质上的区别-共享操作系统

不需要安装额外操作系统

2)使用上的区别-虚拟机已死,容器才是未来。

devops-Docker学习

Docker特点

1)上手快。只需要几分钟,就可以把自己的程序“Docker化”。可以说达到“随心所致,代码即改”的境界

2)职责的逻辑分类。 Docker设计的目的就是要加强开发人员写代码的开发环境与应用程序要部署的生产环境一致性。

3)快速高效的开发生命周期。Docker的目标之一就是缩短代码从开发、测试到部署、上线运行的周期,让你的应用程序具备可移植性,易于构建,并易于协作。

4)鼓励使用面向服务的架构。 Docker还鼓励面向服务的体系结构和微服务架构。

Docker组件

devops-Docker学习
Docker镜像-模板

镜像是构建Docker的基石。用户基于镜像来运行自己的容器。镜像也是Docker生命周期中的“构建”部分。镜像是基于联合文件系统的一种层式结构,由一系列指令一步一步构建出来。

也可以将镜像当作容器的“源代码”。镜像体积很小,非常“便携”,易于分享、存储和更新。

Registry(注册中心)-存放镜像

Docker用Registry来保存用户构建的镜像。Registry分为公共和私有两种。Docker公司运营公共的Registry叫做Docker Hub。用户可以在Docker Hub注册账号,分享并保存自己的镜像(说明:在Docker Hub下载镜像巨慢,可以自己构建私有的Registry)。

Docker容器-跑镜像

Docker可以帮助你构建和部署容器,你只需要把自己的应用程序或者服务打包放进容器即可。容器是基于镜像启动起来的,容器中可以运行一个或多个进程。

我们可以认为,镜像是Docker生命周期中的构建或者打包阶段,而容器则是启动或者执行阶段。

器基于镜像启动,一旦容器启动完成后,我们就可以登录到容器中安装自己需要的软件或者服务。

所以Docker容器就是:

一个镜像格式;

一些列标准操作;

一个执行环境。

Docker安装与启动

Docker官方建议在Ubuntu中安装,因为Docker是基于Ubuntu发布的,而且一般Docker出现的问题Ubuntu是最先更新或者打补丁的。

CentOS安装Docker

使用yum命令在线安装(一定要保证能够ping通外网)

yum install docker

安装成功后查看Docker版本

docker version

启动与停止Docker

systemctl命令是系统服务管理器指令,它是 service 和 chkconfig 两个命令组合。

  1. 启动docker:systemctl start docker
  2. 停止docker:systemctl stop docker
  3. 重启docker:systemctl restart docker
  4. 查看docker状态:systemctl status docker
  5. 开机启动:systemctl enable docker
  6. 查看docker概要信息:docker info
  7. 查看docker帮助文档:docker --help

Docker镜像操作

什么是Docker镜像

Docker镜像是由文件系统叠加而成(是一种文件的存储形式)。最底端是一个文件引导系统,即bootfs,这很像典型的Linux/Unix的引导文件系统。Docker用户几乎永远不会和引导系统有什么交互。实际上,当一个容器启动后,它将会被移动到内存中,而引导文件系统则会被卸载,以留出更多的内存供磁盘镜像使用。Docker容器启动是需要的一些文件,而这些文件就可以称为Docker镜像。

镜像就相当于操作系统iso文件,可以安装多个操作系统. 一个镜像可以启动多个容器

操作镜像

1)列出docker下的所有镜像:docker images

  1. REPOSITORY:镜像所在的仓库名称
  2. TAG:镜像标签
  3. IMAGE ID:镜像ID
  4. CREATED:镜像的创建日期(不是获取该镜像的日期)
  5. SIZE:镜像大小

这些镜像都是存储在Docker宿主机的/var/lib/docker目录下

2)搜索镜像:docker search 镜像名称

  1. NAME:仓库名称
  2. DESCRIPTION:镜像描述
  3. STARS:用户评价,反应一个镜像的受欢迎程度
  4. OFFICIAL:是否官方

AUTOMATED:自动构建,表示该镜像由Docker Hub自动构建流程创建的63.4拉取镜像

3)拉取镜像:

使用命令拉取:docker pull centos:7

阿里镜像加速器

devops-Docker学习

4)删除镜像

  1. 删除指定镜像:docker rmi $IMAGE_ID
  2. 删除所有镜像:docker rmi docker images -q

Docker容器操作

1)查看容器

  1. 查看正在运行容器:docker ps
  2. 查看所有的容器(启动过的历史容器):docker ps –a 高版本才支持
  3. 查看最后一次运行的容器:docker ps –l
  4. 查看停止的容器:docker ps -f status=exited

2)创建与启动容器

  1. 创建容器常用的参数说明:
  2. 创建容器命令:docker run
  3. -i:表示运行容器
  4. -t:表示容器启动后会进入容器命令行(交互式)。加入这两个参数后,容器创建就能登录进去。即分配一个伪终端。
  5. –name :为创建的容器命名。
  6. -v:表示目录映射关系(前者是宿主机目录,后者是映射到宿主机上的目录),可以使用多个-v做多个目录或文件映射。注意:最好做目录映射,在宿主机上做修改,然后共享到容器上。
  7. -d:在run后面加上-d参数,则会创建一个守护式容器在后台运行(这样创建容器后不会自动登录容器,如果只加-i -t两个参数,创建后就会自动进去容器)。
  8. -p:表示端口映射,前者是宿主机端口,后者是容器内的映射端口。可以使用多个-p做多个端口映射

3)停止与启动容器

  1. 停止正在运行的容器:docker stop $CONTAINER_NAME/ID
  2. 启动已运行过的容器:docker start $CONTAINER_NAME/ID

4)文件拷贝

​ 1.如果我们需要将文件拷贝到容器内可以使用cp命令

docker cp 需要拷贝的文件或目录 容器名称:容器目录

​ 2.也可以将文件从容器内拷贝出来

docker cp 容器名称:容器目录 需要拷贝的文件或目录

5)目录挂载

我们可以在创建容器的时候,将宿主机的目录与容器内的目录进行映射,这样我们就可以通过修改宿主机某个目录的文件从而去影响容器。

创建容器 添加-v参数 后边为 宿主机目录:容器目录

docker run -di -v /usr/local/myhtml:/usr/local/myhtml --name=mycentos2 centos:7

如果你共享的是多级的目录,可能会出现权限不足的提示。
devops-Docker学习
这是因为CentOS7中的安全模块selinux把权限禁掉了,我们需要添加参数 --privileged=true 来解决挂载的目录没有权限的问题

6)查看容器IP地址

1.通过以下命令查看容器运行的各种数据

docker inspect mycentos2

2.也可以直接执行下面的命令直接输出IP地址

docker inspect --format=’{{.NetworkSettings.IPAddress}}’ mycentos2

7)删除容器

  1. 删除指定的容器( 注意,只能删除停止的容器):docker rm $CONTAINER_ID/NAME
  2. 删除所有容器:docker rm docker ps -a -q

交互式容器

创建一个交互式容器并取名为mycentos

docker run -it --name=mycentos centos:7 /bin/bash

这时我们通过ps命令查看,发现可以看到启动的容器,状态为启动状态

devops-Docker学习
使用exit命令 退出当前容器
devops-Docker学习
然后用ps -a 命令查看发现该容器也随之停止:
devops-Docker学习
退出容器马上停止.

启动容器执行容器中的shell:

… /bin/bash -c ‘java -jar /usr/local/java/demo-0.0.1-SNAPSHOT.jar’

守护式容器

创建一个守护式容器:如果对于一个需要长期运行的容器来说,我们可以创建一个守护式容器。命令如下(容器名称不能重复):

docker run -di --name=mycentos2 centos:7

登录守护式容器方式:

docker exec -it container_name (或者 container_id) /bin/bash(exit退出时,容器不会停止)

devops-Docker学习
进去以后出来不会关闭
命令如下(容器名称不能重复):
docker run -di --name=mycentos2 centos:7

登录守护式容器方式:
docker exec -it container_name (或者 container_id) /bin/bash(exit退出时,容器不会停止)
devops-Docker学习
进去以后出来不会关闭

相关文章:

  • 2021-05-27
  • 2021-08-18
  • 2021-09-08
  • 2022-12-23
  • 2021-07-25
  • 2021-05-18
猜你喜欢
  • 2021-04-03
  • 2021-04-05
  • 2021-07-03
  • 2021-04-17
  • 2021-10-19
  • 2022-03-07
  • 2021-08-08
相关资源
相似解决方案