架构师修炼之微服务部署 - Docker简介

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
注册配置 MSE Nacos/ZooKeeper,118元/月
任务调度 XXL-JOB 版免费试用,400 元额度,开发版规格
简介:

架构师修炼之微服务部署 - Docker简介

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

Docker 最初是 dotCloud 公司创始人 Solomon Hykes 在法国期间发起的一个公司内部项目,它是基于 dotCloud 公司多年云服务技术的一次革新,并于2013 年 3 月以 Apache 2.0 授权协议开源,主要项目代码在
GitHub上进行维护。Docker 项目后来还加入了 Linux 基金会,并成立推动开放容器联盟(OCI)。

Docker 自开源后受到广泛的关注和讨论,至今其 GitHub 项目已经超过 4 万 6 千个星标和一万多个 fork。甚至由于 Docker 项目的火爆,在 2013 年底,dotCloud 公司决定改名为 Docker。Docker 最初是在 Ubuntu 12.04 上开发实现的;Red Hat 则从 RHEL 6.5 开始对 Docker 进行支持;Google 也在其 PaaS 产品中广泛应用 Docker。

Docker 使用 Google 公司推出的Go 语言进行开发实现,基于 Linux 内核的cgroup,namespace,以及AUFS类的Union FS等技术,对进程进行封装隔离,属于操作系统层面的虚拟化技术。由于隔离的进程独立于宿主和其它的隔离的进程,因此也称其为容器。最初实现是基于LXC,从 0.7 版本以后开始去除 LXC,转而使用自行开发的libcontainer,从 1.11 开始,则进一步演进为使用runC和containerd。

Docker 在容器的基础上,进行了进一步的封装,从文件系统、网络互联到进程隔离等等,极大的简化了容器的创建和维护。使得 Docker 技术比虚拟机技术更为轻便、快捷。

容器(Containers) 虚拟主机(Virtual Machines)

容器内应用进程直接运行于宿主的内核,容器内没有自己的内核,而且也没有进行硬件虚拟。 虚拟出一套硬件后,在其上运行一个完整操作系统,在该系统上再运行所需应用进程。缺点:消耗硬件资源;配置和启动都慢。
内部架构

组成部分:

Docker客户端
Docker服务端
daemon 守护进程
image 镜像
container 容器
Docker镜像仓库
概念
Docker客户端
发布操作指令给Docker服务端进行容器与镜像操作,类似Xshell,Teraterm。

Daemon守护进程
daemon在服务端宿主主机后台运行,接受来自客户的请求,并处理这些请求(创建、运行、分发容器)。

DockerFile文件
一个用来构建镜像的文本文件,包含了一条条构建镜像所需要的指令和说明。

镜像(image)
创建容器的模板,一般程序员通过编译DockerFile文件创建。

镜像是一个特殊的文件系统,除了提供容器运行时所需的程序、库、资源、配置等文件外,还包含了一些为运行时准备的一些配置参数(如匿名卷、环境变量、用户等)。镜像不包含任何动态数据,其内容在构建之后也不会被改变。无法对镜像进行修改。--简书

容器(Container)
镜像实例-标准化的应用,可以进入容器进行修改。一个镜像可以创建多个独立运行的容器。

容器的实质是进程,但与直接在宿主执行的进程不同,容器进程运行于属于自己的独立的命名空间。因此容器可以拥有自己的root文件系统、自己的网络配置、自己的进程空间,甚至自己的用户 ID 空间。容器内的进程是运行在一个隔离的环境里,使用起来,就好像是在一个独立于宿主的系统下操作一样。这种特性使得容器封装的应用比直接在宿主运行更加安全。--简书

仓库(Repository)
集中化存储镜像的地方,一般使用Docker Registry构建自己的私有仓库。而官方的DockerHub提供操作系统、数据库、web服务或者其他公开的镜像。

镜像构建完成后,可以很容易的在当前宿主机上运行,但是,如果需要在其它服务器上使用这个镜像,我们就需要一个集中的存储、分发镜像的服务,Docker Registry 就是这样的服务。--简书

镜像容器创建实操(Windows版)
创建Asp.netCore项目
因为安装VS2019太费时间,所有通过SDK命令来创建项目。

安装Asp.netCore开发环境
因为需要使用模板创建项目,所有需要进入官网(https://dotnet.microsoft.com/download)下载安装.NETCore SDK 3.1

确认是否安装成功
启动cmd命令窗口
输入以下命令
dotnet --version
如果输出为 3.1 打头,代表安装成功
启动cmd窗口,cd到作业目录。输入以下命令创建项目。
dotnet new webapp -o aspnetcoreapp
进入项目目录,运行项目。
D:docker>cd aspnetcoreapp
D:dockeraspnetcoreapp>dotnet restore
D:dockeraspnetcoreappaspnetcoreapp.csproj 的还原在 65.58 ms 内完成。

D:dockeraspnetcoreapp>dotnet run
info: Microsoft.Hosting.Lifetime[0]

Now listening on: https://localhost:5001

info: Microsoft.Hosting.Lifetime[0]

Now listening on: http://localhost:5000

info: Microsoft.Hosting.Lifetime[0]

Application started. Press Ctrl+C to shut down.

info: Microsoft.Hosting.Lifetime[0]

Hosting environment: Development

info: Microsoft.Hosting.Lifetime[0]

Content root path: D:\docker\aspnetcoreapp

进入浏览器,输入地址:https://localhost:5001 或者 http://localhost:5000。如果显示了Welcome,代表创建成功。

创建DockerFile
在作业目录,创建无后缀的文件:DockerFile。内容如下:

备注:如果使用VS2019可以通过右键项目,选择“Docker支持”自动生成此文件。

FROM mcr.microsoft.com/dotnet/core/aspnet:3.1-buster-slim AS base
WORKDIR /app
EXPOSE 80
EXPOSE 443

FROM mcr.microsoft.com/dotnet/core/sdk:3.1-buster AS build
WORKDIR /src
COPY ["aspnetcoreapp/aspnetcoreapp.csproj", "aspnetcoreapp/"]
RUN dotnet restore "aspnetcoreapp/aspnetcoreapp.csproj"
COPY . .
WORKDIR "/src/aspnetcoreapp"
RUN dotnet build "aspnetcoreapp.csproj" -c Release -o /app/build

FROM build AS publish
RUN dotnet publish "aspnetcoreapp.csproj" -c Release -o /app/publish

FROM base AS final
WORKDIR /app
COPY --from=publish /app/publish .
ENTRYPOINT ["dotnet", "aspnetcoreapp.dll"]
创建镜像
安装Docker Desktop for windows.
https://www.docker.com/products/docker-desktop
进入CMD窗口,查看安装版本。(因为是本地演示,必须保证Client和Server都存在)
D:docker>docker version
Client: Docker Engine - Community
Version: 19.03.8
API version: 1.40
Go version: go1.12.17
Git commit: afacb8b
Built: Wed Mar 11 01:23:10 2020
OS/Arch: windows/amd64
Experimental: false

Server: Docker Engine - Community
Engine:
Version: 19.03.8
API version: 1.40 (minimum version 1.12)
Go version: go1.12.17
Git commit: afacb8b
Built: Wed Mar 11 01:29:16 2020
OS/Arch: linux/amd64
Experimental: false
containerd:
Version: v1.2.13
GitCommit: 7ad184331fa3e55e52b890ea95e65ba581ae3429
runc:
Version: 1.0.0-rc10
GitCommit: dc9208a3303feef5b3839f4323d9beb36df0a9dd
docker-init:
Version: 0.18.0
GitCommit: fec3683
CMD窗口进入工作目录,通过DockerFile创建镜像
备注:因为我有缓存Aspnet3.1和sdk3.1,所以没有出现下载信息。

D:docker>dir
驱动器 D 中的卷是 Soft
卷的序列号是 CC3B-E6AD

D:docker 的目录

2020/04/22 15:46

.
2020/04/22 15:46 ..
2020/04/22 13:08 aspnetcoreapp
2020/04/22 15:40 615 DockerFile
        1 个文件            615 字节
        3 个目录 86,923,542,528 可用字节

D:docker>docker build -t aspnetcore .
Sending build context to Docker daemon 6.373MB
Step 1/17 : FROM mcr.microsoft.com/dotnet/core/aspnet:3.1-buster-slim AS base
---> 0661f995e7db
Step 2/17 : WORKDIR /app
---> Running in 361e77bdad90
Removing intermediate container 361e77bdad90
---> add07effc24a
Step 3/17 : EXPOSE 80
---> Running in 9a384d1bd5e4
Removing intermediate container 9a384d1bd5e4
---> bea582d752fc
Step 4/17 : EXPOSE 443
---> Running in 4690332ca309
Removing intermediate container 4690332ca309
---> 47da2ca7d6ce
Step 5/17 : FROM mcr.microsoft.com/dotnet/core/sdk:3.1-buster AS build
---> 3edbb65c61da
Step 6/17 : WORKDIR /src
---> Using cache
---> 5464ff3ac1fb
Step 7/17 : COPY ["aspnetcoreapp/aspnetcoreapp.csproj", "aspnetcoreapp/"]
---> Using cache
---> d9cbfaaf5a1a
Step 8/17 : RUN dotnet restore "aspnetcoreapp/aspnetcoreapp.csproj"
---> Using cache
---> f3fc708d4809
Step 9/17 : COPY . .
---> Using cache
---> c30b51b049a7
Step 10/17 : WORKDIR "/src/aspnetcoreapp"
---> Using cache
---> 089b9f9f7a27
Step 11/17 : RUN dotnet build "aspnetcoreapp.csproj" -c Release -o /app/build
---> Using cache
---> 01728a06901e
Step 12/17 : FROM build AS publish
---> 01728a06901e
Step 13/17 : RUN dotnet publish "aspnetcoreapp.csproj" -c Release -o /app/publish
---> Using cache
---> bf5986a7c2e4
Step 14/17 : FROM base AS final
---> 47da2ca7d6ce
Step 15/17 : WORKDIR /app
---> Running in 098789c69783
Removing intermediate container 098789c69783
---> 373b88783227
Step 16/17 : COPY --from=publish /app/publish .
---> 2a00a6670e90
Step 17/17 : ENTRYPOINT ["dotnet", "aspnetcoreapp.dll"]
---> Running in 94f2bb2fae82
Removing intermediate container 94f2bb2fae82
---> 73ae1ad12839
Successfully built 73ae1ad12839
Successfully tagged aspnetcore:latest
SECURITY WARNING: You are building a Docker image from Windows against a non-Windows Docker host. All files and directories added to build context will have '-rwxr-xr-x' permissions. It is recommended to double check and reset permissions for sensitive files and directories.

D:docker>docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
aspnetcore latest 73ae1ad12839 32 seconds ago 212MB

创建容器
先确认容器列表,然后使用镜像名称创建容器。
-d:表示后台运行;-P:表示自动分配端口(-p 8080:80 形式自定义端口)

D:docker>docker container ls
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES

D:docker>docker run -d -P aspnetcore
4129eb2516af33ea9346c8d6eefec6e1d5d83ec728ab3ddb093a4a3610dd3001

D:docker>docker container ls
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
4129eb2516af aspnetcore "dotnet aspnetcoreap…" 4 seconds ago Up 3 seconds 0.0.0.0:32771->80/tcp, 0.0.0.0:32770->443/tcp elegant_chebyshev
执行结果
打开浏览器,输入地址:http://localhost:32771/

原文地址https://www.cnblogs.com/lixiaobin/p/dockerdescription.html

相关文章
|
1月前
|
消息中间件 监控 RocketMQ
Docker部署RocketMQ5.2.0集群
本文详细介绍了如何使用Docker和Docker Compose部署RocketMQ 5.2.0集群。通过创建配置文件、启动集群和验证容器状态,您可以快速搭建起一个RocketMQ集群环境。希望本文能够帮助您更好地理解和应用RocketMQ,提高消息中间件的部署和管理效率。
238 91
|
1月前
|
存储 NoSQL Redis
Docker 部署 Redis
在使用 Docker 部署 Redis 时,为实现数据持久化,需正确挂载容器内的数据目录到宿主机。推荐命令如下: ``` docker run -d --name redis -v /mnt/data/redis:/data -p 6379:6379 redis ``` 该命令将宿主机的 `/mnt/data/redis` 目录挂载到容器的 `/data` 目录,确保 Redis 数据持久化。此路径更通用,适合大多数场景。避免使用不匹配的挂载路径,如 `/var/lib/redis` 或 `/mnt/data/redis` 到非默认目录,以防止数据无法正确持久化。
|
2月前
|
存储 关系型数据库 MySQL
美团面试:MySQL为什么 不用 Docker部署?
45岁老架构师尼恩在读者交流群中分享了关于“MySQL为什么不推荐使用Docker部署”的深入分析。通过系统化的梳理,尼恩帮助读者理解为何大型MySQL数据库通常不使用Docker部署,主要涉及性能、管理复杂度和稳定性等方面的考量。文章详细解释了有状态容器的特点、Docker的资源隔离问题以及磁盘IO性能损耗,并提供了小型MySQL使用Docker的最佳实践。此外,尼恩还介绍了Share Nothing架构的优势及其应用场景,强调了配置管理和数据持久化的挑战。最后,尼恩建议读者参考《尼恩Java面试宝典PDF》以提升技术能力,更好地应对面试中的难题。
|
22天前
|
人工智能 文字识别 安全
Stirling-PDF:51.4K Star!用Docker部署私有PDF工作站,支持50多种PDF操作,从此告别在线工具
Stirling-PDF 是一款基于 Docker 的本地化 PDF 编辑工具,支持 50 多种 PDF 操作,包括合并、拆分、转换、压缩等,同时提供多语言支持和企业级功能,满足个人和企业用户的多样化需求。
74 6
Stirling-PDF:51.4K Star!用Docker部署私有PDF工作站,支持50多种PDF操作,从此告别在线工具
|
1月前
|
JavaScript 前端开发 Docker
如何通过pm2以cluster模式多进程部署next.js(包括docker下的部署)
通过这些步骤,可以确保您的Next.js应用在多核服务器上高效运行,并且在Docker环境中实现高效的容器化管理。
163 44
|
19天前
|
中间件 关系型数据库 数据库
docker快速部署OS web中间件 数据库 编程应用
通过Docker,可以轻松地部署操作系统、Web中间件、数据库和编程应用。本文详细介绍了使用Docker部署这些组件的基本步骤和命令,展示了如何通过Docker Compose编排多容器应用。希望本文能帮助开发者更高效地使用Docker进行应用部署和管理。
50 19
|
11天前
|
Linux 虚拟化 Docker
Linux服务器部署docker windows
在当今软件开发中,Docker成为流行的虚拟化技术,支持在Linux服务器上运行Windows容器。流程包括:1) 安装Docker;2) 配置支持Windows容器;3) 获取Windows镜像;4) 运行Windows容器;5) 验证容器状态。通过这些步骤,你可以在Linux环境中顺利部署和管理Windows应用,提高开发和运维效率。
63 1
|
3天前
|
Docker Python 容器
Docker——阿里云服务器使用Docker部署python项目全程小记
本文记录了我在阿里云服务器上使用Docker部署python项目(flask为例)的全过程,在这里记录和分享一下,希望可以给大家提供一些参考。
|
2月前
|
监控 Java 应用服务中间件
tomcat相关概念与部署tomcat多实例-zabbix监控(docker部署)
通过上述步骤,您可以在Ubuntu系统上成功编译并安装OpenCV 4.8。这种方法不仅使您能够定制OpenCV的功能,还可以优化性能以满足特定需求。确保按照每一步进行操作,以避免常见的编译问题。
66 23
|
2月前
|
SQL Java Maven
docker部署apollo
docker部署apollo步骤