博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
品尝阿里云容器服务:初步尝试ASP.NET Core Web API站点的Docker自动化部署
阅读量:6086 次
发布时间:2019-06-20

本文共 2094 字,大约阅读时间需要 6 分钟。

部署场景是这样的,我们基于 ASP.NET Core 2.0 Preview 1 开发了一个用于管理缓存的 Web API ,想通过阿里云容器服务基于 Docker 部署为内网服务。

在这篇博文中分享一下经过实践验证的操作步骤:

一、创建与配置集群

1)首先创建一个 Swarm Mode 的集群(注意创建时不要选择“自动创建负载均衡”,因为我们部署的是内网服务,自动创建的是公网负载均衡,需要手动创建内网负载均衡并绑定到集群):

2)集群创建成功后,会在集群列表中显示下面的信息:

3)接着创建一个内网负载均衡,并将它绑定到刚刚创建的集群。

绑定方法:在集群列表中对应的集群右侧点击“管理”->“负载均衡”,在“负载均衡”中点击“绑定SLB”进行绑定。

4)绑定好之后,为了可以通过自己的域名访问运行在 Docker 容器中的站点,需要进行“域名设置”:

(注:这里只需设置一级域名,设置之后一定要重新部署acsrouting系统应用,详见)

二、创建自己的镜像仓库

1)进入“Docker镜像仓库”管理控制台,创建镜像仓库配置,这里配置为让阿里云容器服务自动从 GitLab 签出 cache-service 项目的代码并基于其中的 Dockerfile 构建镜像。

2)点击镜像仓库的“管理”,进入“构建”,点击“立即构建”,我们这里手动触发镜像的构建。

3)cache-service 项目使用的 Dockerfile 如下,使用的是微软官方提供的专门用于构建 asp.net core 2.0 项目的 Docker 镜像。

FROM microsoft/aspnetcore-build:2.0WORKDIR /appCOPY src .RUN dotnet restore CnblogsCache.sln && cd Cnblogs.Cache.WebApi && dotnet publish -c Release -o ./publish

(注:我们在构建与运行 cache-service 项目时分别用的是不同的微软官方 Docker 镜像 aspnetcore-build:2.0 与 aspnetcore:2.0 )

4)镜像仓库创建好之后,在容器服务控制台的“镜像与方案”->“镜像”->“用户镜像”中会看到。

三、创建编排

进入“镜像与方案”->“编排模板”,点击“创建”进入创建编辑页面,编写如下的编排:

version: '3'services:  cache-service:    image: microsoft/aspnetcore:2.0    depends_on:      - dotnet-publish    volumes:      - share:/app    command: bash -c "cd /app && dotnet Cnblogs.Cache.WebApi.dll"    labels:      aliyun.routing.port_80: cache  dotnet-publish:    image: cnblogs/cache-service:latest     volumes:      - share:/app    command: bash -c "rm -rf /app/* && cd /src/Cnblogs.Cache.WebApi/publish && cp -r * /app && dotnet Cnblogs.Cache.WebApi.dll" volumes:  share:

注:运行 web api 站点时,我们用的微软官方 Docker 镜像是 microsoft/aspnetcore:2.0 ,而 build 时用的是 microsoft/aspnetcore-build:2.0 ,这是两个分别针对运行时与构建时进行优化过的镜像。

编写编排中遇到的问题详见:

四、创建应用 

1)以前一步中创建的“编排”创建应用

2)等一段时间,如果没有遇到问题,应用就会部署成功

3)检查所绑定的负载均衡的运行状态是否是“运行中”

有时在部署或重新部署应用的过程中,负载均衡会处于“已停止”的状态,如果出现这个问题,重新绑定一下负载均衡即可。

五、访问通过阿里云容器服务成功部署在 Docker 容器中的 Web API 站点

1)在一台用于测试的阿里云服务器的 hosts 文件中添加 cache.cnblogs.com 的内网解析,解析到集群所绑定的负载均衡的内网 IP。

2)用 curl 命令测试一下访问 cache service web api:

$ curl -X 'DELETE' --head -s http://cache.cnblogs.com/cache/test

测试结果:

大功告成!使用阿里云容器服务进行生产环境的自动化部署即将梦想成真!

转载于:https://www.cnblogs.com/jjg0519/p/7253713.html

你可能感兴趣的文章
小错误汇总
查看>>
Spring源码系列 — Envoriment组件
查看>>
java正则表达式去除html标签,Java中正则表达式去除html标签
查看>>
使用Cobbler批量部署Linux操作系统
查看>>
【斗医】【5】Web应用开发20天
查看>>
人生的抉择-创业纪录片(二)-起步期
查看>>
设计模式系列-享元模式
查看>>
zabbix企业应用之服务端与客户端的安装
查看>>
软件项目的优先级
查看>>
实例讲解遗传算法——基于遗传算法的自动组卷系统【理论篇】
查看>>
无法在web服务器上启动调试。调试失败,因为没有启用集成windows身份验证
查看>>
java实现大数相加问题
查看>>
C#百万数据查询超时问题
查看>>
2016第10周五
查看>>
使用gson-1.6.jar解析json
查看>>
AC Milan VS Juventus(模拟)
查看>>
CentOS两台服务器利用scp拷贝文件
查看>>
SQL DatePart函数使用
查看>>
asp.net页面后退,重复弹出上一页对话框处理办法
查看>>
docker 学习
查看>>