阿里云Windows Server 2016环境Docker试用

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
简介: 前文我们介绍过在本地Windows10环境中,基于Hyper V容器的Docker使用。现在阿里云已经提供了Windows Server 2016支持,我们来亲自体验一下原生的Windows Server容器吧。

14898399945171

前文我们介绍过在本地Windows10环境中,基于Hyper V容器的Docker使用。现在阿里云已经提供了Windows Server 2016支持,我们来亲自体验一下原生的Windows Server容器吧。

系列文章

Windows Server容器与Linux容器非常类似,都是通过命名空间、资源控制等技术实现进程隔离。每个Windows Server容器都与宿主机共享同一个内核。与HyperV容器相比,它的启动速度更快、资源消耗更低。但是Hyper V容器可以借助虚拟化技术提供更好的隔离性。

创建Windows Server 2016 ECS实例

注:由于微软的基础操作系统镜像在大陆下载非常缓慢,建议选择香港区域做实验。

首先我们创建一个Windows Server 2016,请选择型号III的规格,并选择“Windows Server 2016 数据中心版”操作系统镜像。由于Windows镜像都比较大,建议扩大系统盘容量。

14898079126209

创建安全组

因为我希望通过Windows Remote Desktop来访问ECS实例,需要在公网入方向开放RDP端口3389。其配置方法如下:

-w340

-w340

注:从安全角度出发,请按需配置需要对外暴露的端口。

安装配置 Docker Engine

可以访问 Docker Store 来查看安装Windows Server 2016操作系统的Docker Engine说明

14898086313331

在Windows Server的PowerShell中,执行如下命令安装Docker-Microsoft的包管理实现

Install-Module -Name DockerMsftProvider -Repository PSGallery -Force

再安装Docker Engine安装包

Install-Package -Name docker -ProviderName DockerMsftProvider

完成之后,请执行下面命令重启服务器

Restart-Computer -Force

重启完毕,我们就可以通过如下命令查看 Docker Engine 的状态了。

PS C:\Users\Administrator\test> docker version
Client:
 Version:      17.03.0-ee-1
 API version:  1.26
 Go version:   go1.7.5
 Git commit:   9094a76
 Built:        Wed Mar  1 00:49:51 2017
 OS/Arch:      windows/amd64

Server:
 Version:      17.03.0-ee-1
 API version:  1.26 (minimum version 1.24)
 Go version:   go1.7.5
 Git commit:   9094a76
 Built:        Wed Mar  1 00:49:51 2017
 OS/Arch:      windows/amd64
 Experimental: false

PS C:\Users\Administrator\test> docker info
Containers: 0
 Running: 0
 Paused: 0
 Stopped: 0
Images: 2
Server Version: 17.03.0-ee-1
Storage Driver: windowsfilter
 Windows:
Logging Driver: json-file
Plugins:
 Volume: local
 Network: l2bridge l2tunnel nat null overlay transparent
Swarm: inactive
Default Isolation: process
Kernel Version: 10.0 14393 (14393.576.amd64fre.rs1_release_inmarket.161208-2252)
Operating System: Windows Server 2016 Datacenter
OSType: windows
Architecture: x86_64
CPUs: 2
Total Memory: 8 GiB
Name: iZe647ugnmkmq4Z
ID: GMM4:K4QA:KYIC:6KFD:42KP:LKAJ:BNIY:QR7P:GHVH:MRCQ:PGDL:2ZKI
Docker Root Dir: C:\ProgramData\docker
Debug Mode (client): false
Debug Mode (server): false
Registry: https://index.docker.io/v1/
Experimental: false
Insecure Registries:
 127.0.0.0/8
Live Restore Enabled: false

这里我们可以看到服务器端操作系统/架构(OS/Arch)为“windows/amd64”;而容器的“缺省隔离方式”(Default Isolation)为进程 “process”也就是Windows Server Container

配置Docker Hub加速器 (可选)

注:如果ECS部署在国内Region,可以需要配置Docker Hub加速器。在香港和海外Region无需如下配置。

访问 https://cr.console.aliyun.com 获得加速器地址

14897515725110

在PowerShell中执行如下命令

C:\Windows\notepad.exe C:\ProgramData\docker\config\daemon.json

编辑Docker Engine的配置文件,详细配置可以参见官方文档

{
   "registry-mirrors": ["https://xxxx"]
}

重启Docker Engine

Restart-Service docker

注:微软的系统镜像中的层文件并不保存在Docker Hub之上,在国内访问非常痛苦,即使配置了阿里云加速器也无法提升传输效率。可以通过docker save/load的方式加载操作系统基础镜像。

体验Windows Server容器

在测试目录创建如下Dockerfile文件,它会在微软IIS镜像的基础上,添加一个"index.html"

FROM microsoft/iis
RUN echo "Hello World - Windows Container" > c:\inetpub\wwwroot\index.html

构建Docker镜像,并命名为 "myiis"

docker build -t myiis .

执行如下命令,启动

docker run -d -p 80:80 myiis

我们利用浏览器打开ECS主机的地址,就可以看见我们生成的网页了。 (注,需要在安全组配置中创建HTTP协议的公网入方向配置)

-w340

选择隔离级别

Docker从1.12版本之后提供了 isolation 参数,可以由用户选择不同的隔离机制

      --isolation string                      Container isolation technology

比如,在Windows环境可以用如下命令分别以 Windows Server Container 和 HyperV 的隔离方式执行 IIS

docker run --isolation=process -d microsoft/iis
docker run --isolation=hyperv -d microsoft/iis

阿里云环境中,Windows Server本身就是运行在虚拟化环境中,所以目前不支持 HyperV 的容器运行时。

由于Windows Server Container和操作系统共享内核所以它只能运行Windows操作系统镜像,而不能运行Linux的镜像。

总结

在阿里云上利用Windows Server 2016和Docker技术可以敏捷地交付Windows应用,对于企业用户而言有着重要的意义。在之后的文章中,我们会逐渐介绍Windows容器的其他特性比如Swarm模式集群支持等。

阿里云容器服务也在计划提供对Windows容器的支持,了解更多容器服务内容,请访问 https://www.aliyun.com/product/containerservice

目录
相关文章
|
1月前
|
存储 弹性计算 运维
阿里云国际Windows操作系统迁移教程
阿里云国际Windows操作系统迁移教程
|
5天前
|
网络安全 Windows
Windows server 2012R2系统安装远程桌面服务后无法多用户同时登录是什么原因?
【11月更文挑战第15天】本文介绍了在Windows Server 2012 R2中遇到的多用户无法同时登录远程桌面的问题及其解决方法,包括许可模式限制、组策略配置问题、远程桌面服务配置错误以及网络和防火墙问题四个方面的原因分析及对应的解决方案。
|
10天前
|
监控 安全 网络安全
Windows Server管理:配置与管理技巧
Windows Server管理:配置与管理技巧
37 3
|
13天前
|
存储 安全 网络安全
Windows Server 本地安全策略
由于广泛使用及历史上存在的漏洞,Windows服务器成为黑客和恶意行为者的主要攻击目标。这些系统通常存储敏感数据并支持关键服务,因此组织需优先缓解风险,保障业务的完整性和连续性。常见的威胁包括勒索软件、拒绝服务攻击、内部威胁、恶意软件感染等。本地安全策略是Windows操作系统中用于管理计算机本地安全性设置的工具,主要包括用户账户策略、安全选项、安全设置等。实施强大的安全措施,如定期补丁更新、网络分段、入侵检测系统、数据加密等,对于加固Windows服务器至关重要。
|
21天前
|
关系型数据库 MySQL Docker
docker环境下mysql镜像启动后权限更改问题的解决
在Docker环境下运行MySQL容器时,权限问题是一个常见的困扰。通过正确设置目录和文件的权限,可以确保MySQL容器顺利启动并正常运行。本文提供了多种解决方案,包括在主机上设置正确的权限、使用Dockerfile和Docker Compose进行配置、在容器启动后手动更改权限以及使用 `init`脚本自动更改权限。根据实际情况选择合适的方法,可以有效解决MySQL容器启动后的权限问题。希望本文对您在Docker环境下运行MySQL容器有所帮助。
38 1
|
1月前
|
Apache 数据中心 Windows
将网站迁移到阿里云Windows系统云服务器,访问该站点提示连接被拒绝,如何处理?
将网站迁移到阿里云Windows系统云服务器,访问该站点提示连接被拒绝,如何处理?
|
机器学习/深度学习 安全 网络协议
达梦 DM8 数据库安装详细手册(Windows+Linux+Docker)(一)
达梦 DM8 数据库安装详细手册(Windows+Linux+Docker)(一)
达梦 DM8 数据库安装详细手册(Windows+Linux+Docker)(一)
|
安全 测试技术 数据库
达梦 DM8 数据库安装详细手册(Windows+Linux+Docker)(二)
达梦 DM8 数据库安装详细手册(Windows+Linux+Docker)(二)
达梦 DM8 数据库安装详细手册(Windows+Linux+Docker)(二)
|
NoSQL 数据可视化 Linux
Redis安装大全涵盖Windows Linux Docker(2)
Redis安装大全涵盖Windows Linux Docker
123 0
Redis安装大全涵盖Windows Linux Docker(2)
|
NoSQL Linux Redis
Redis安装大全涵盖Windows Linux Docker(1)
Redis安装大全涵盖Windows Linux Docker
148 0
Redis安装大全涵盖Windows Linux Docker(1)
下一篇
无影云桌面