在阿里云函数计算上部署.NET Core 3.1

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
.cn 域名,1个 12个月
函数计算FC,每月15万CU 3个月
简介:

在阿里云函数计算上部署.NET Core 3.1

使用阿里云ECS或者其他常见的VPS服务部署应用的时候,需要手动配置环境,并且监测ECS的行为,做补丁之类的,搞得有点复杂。好在很多云厂商(阿里云、Azure等)提供了Serverless服务,借助于Serverless,开发人员可以更加专注于代码的开发,减少运维的成本。

Azure的部署直接集成在了VS中,非常方便,本文主要介绍一下使用ASP.NET CORE 3.1部署在阿里云Serverless(函数计算)的内容。

准备#
阿里云的函数计算提供了很多运行库,对.NET的支持现在到ASP.NET CORE 2.1,如果我们需要自定义runtime,那么需要使用到函数计算的custom runtime功能。

首先准备好一个ASP.NET CORE 3.1程序,保证其可以正常运行(Release模式下能够正常工作)。然后做以下改动:

修改端口#
阿里云函数计算自定义runtime使用的是固定的监听端口9000,因此,需要修改Program.cs文件

Copy
public static IWebHostBuilder CreateWebHostBuilder(string[] args) =>

WebHost.CreateDefaultBuilder(args)
//指定监听9000端口
       .UseUrls("http://*:9000")
       .UseStartup<Startup>();

设置发布选项#
VS右键点击工程,点发布,选择高级。

由于目标是linux系统,因此需要选择目标运行时为linux-64,部署模式选择独立。(阿里云暂时没有配置.NET Core 3.1 Runtime,需要自带运行组件,但是不要选择单一文件,实测有问题)。

发布完成之后,转到对应的publish目录,将应用程序名称相同的一个无拓展名的文件,重命名为bootstrap。

windows默认的情况下,这个文件就是可以执行的,如果是其他系统,需要确保这个文件有可执行权限。

部署#
这里需要借助阿里云函数计算的工具fun.exe,在正式部署之前,需要先运行fun.exe config进行配置。具体的使用方式可以参考阿里云的文档。

部署需要一个配置的文件,我的文件配置如下:

Copy
ROSTemplateFormatVersion: '2015-09-01'
Transform: 'Aliyun::Serverless-2018-04-03'
Resources:
MonitorService:

Type: 'Aliyun::Serverless::Service'
Properties:
  Description: 'rsystem'
RSystemApi:
  Type: 'Aliyun::Serverless::Function'
  Properties:
    Handler: index.handler
    Runtime: custom
    CodeUri: 'RSystemApi/RSystemApi/bin/Release/netcoreapp3.1/publish/'
  Events:
    httpTrigger:
      Type: HTTP
      Properties:
        AuthType: ANONYMOUS
        Methods:
          - GET
          - POST
          - PUT 
          - PATCH
          - DELETE 

使用powershell执行fun.exe deploy -t deploy.yml,一路下一步,等待提示完成,就可以在函数计算中心看到新部署的服务。

服务可以通过阿里云的控制台进行访问,但是不推荐,容易有各种各样的问题。建议大家使用自定义域名的方式进行访问,详情见文末参考资料。

注意:

尽量控制文件压缩后的大小在50M以内,否则部署不会成功,如果需要更大文件的部署,那么可以使用NAS服务。
fun config可以设置超时时间,文件比较大的情况,deploy超时时间段可能会造成部署失败。(我设置了120s)
以上步骤也适用于其他语言环境应用custom的情况。详情见https://help.aliyun.com/document_detail/132044.html
顺便吐槽一下阿里云,官方提供custom runtime示例里面有F#,里面是基于.NET CORE 3.1的,直接原生支持多好。
常见问题:#
对于.NET Core 3.1的调试,大多数情况本地能行,那么生产服务器也就可以,当然也有一些例外情况。

提示CAFileNotFound#
Copy
{

"ErrorCode": "CAFileNotFound",
"ErrorMessage": "The CA process cannot be started due to missing files:ContainerStartDuration:100000000. CA process cannot be started due to missing file: invalid header field value \"oci runtime error: container_linux.go:247: starting container process caused \\\"exec: \\\\\\\"/code/bootstrap\\\\\\\": stat /code/bootstrap: no such file or directory\\\"\\n\"Error response from daemon: invalid header field value \"oci runtime error: container_linux.go:247: starting container process caused \\\"exec: \\\\\\\"/code/bootstrap\\\\\\\": stat /code/bootstrap: no such file or directory\\\"\\n\""

}
检查一下是不是没有将主文件改名成bootstrap

提示CAExited#
检查一下代码是不能够在本地正常运行,有没有代码里面强行限制为localhost的情况。

提示404错误#
使用阿里云的控制台调用的时候,经常出现本地调用成功,远程调用报404的问题。需要注意,阿里云给的调试地址是:
https://xxxxxxxxxxxxxxxx.cn-shanghai.fc.aliyuncs.com/2016-08-15/proxy/[ServiceName]/[FuctionName]/xxx的地址模式。这个大概率和我们提供的路由解析规则不符。因此,请尽量使用自定义域名。

自定义域名必须是已经备案的域名才可以,而且解析需要在阿里云才行。可是暂时不知道什么方法可以单独搞到备案的域名,比较通用的方式是申请域名,并且解析到ECS进行备案,等备案完成,再解析到函数计算服务。

参考资料:#
https://yq.aliyun.com/articles/731985

作者: 波多尔斯基

出处:https://www.cnblogs.com/podolski/p/12847037.html

相关实践学习
【文生图】一键部署Stable Diffusion基于函数计算
本实验教你如何在函数计算FC上从零开始部署Stable Diffusion来进行AI绘画创作,开启AIGC盲盒。函数计算提供一定的免费额度供用户使用。本实验答疑钉钉群:29290019867
建立 Serverless 思维
本课程包括: Serverless 应用引擎的概念, 为开发者带来的实际价值, 以及让您了解常见的 Serverless 架构模式
相关文章
|
26天前
|
人工智能 Java Serverless
阿里云函数计算助力AI大模型快速部署
随着人工智能技术的快速发展,AI大模型已经成为企业数字化转型的重要工具。然而,对于许多业务人员、开发者以及企业来说,探索和利用AI大模型仍然面临诸多挑战。业务人员可能缺乏编程技能,难以快速上手AI模型;开发者可能受限于GPU资源,无法高效构建和部署AI应用;企业则希望简化技术门槛,以更低的成本和更高的效率利用AI大模型。
111 12
|
24天前
|
开发框架 .NET 开发者
简化 ASP.NET Core 依赖注入(DI)注册-Scrutor
Scrutor 是一个简化 ASP.NET Core 应用程序中依赖注入(DI)注册过程的开源库,支持自动扫描和注册服务。通过简单的配置,开发者可以轻松地从指定程序集中筛选、注册服务,并设置其生命周期,同时支持服务装饰等高级功能。适用于大型项目,提高代码的可维护性和简洁性。仓库地址:&lt;https://github.com/khellang/Scrutor&gt;
39 5
|
2月前
|
开发框架 .NET C#
在 ASP.NET Core 中创建 gRPC 客户端和服务器
本文介绍了如何使用 gRPC 框架搭建一个简单的“Hello World”示例。首先创建了一个名为 GrpcDemo 的解决方案,其中包含一个 gRPC 服务端项目 GrpcServer 和一个客户端项目 GrpcClient。服务端通过定义 `greeter.proto` 文件中的服务和消息类型,实现了一个简单的问候服务 `GreeterService`。客户端则通过 gRPC 客户端库连接到服务端并调用其 `SayHello` 方法,展示了 gRPC 在 C# 中的基本使用方法。
46 5
在 ASP.NET Core 中创建 gRPC 客户端和服务器
|
1月前
|
开发框架 缓存 .NET
GraphQL 与 ASP.NET Core 集成:从入门到精通
本文详细介绍了如何在ASP.NET Core中集成GraphQL,包括安装必要的NuGet包、创建GraphQL Schema、配置GraphQL服务等步骤。同时,文章还探讨了常见问题及其解决方法,如处理复杂查询、错误处理、性能优化和实现认证授权等,旨在帮助开发者构建灵活且高效的API。
27 3
|
8天前
|
开发框架 算法 中间件
ASP.NET Core 中的速率限制中间件
在ASP.NET Core中,速率限制中间件用于控制客户端请求速率,防止服务器过载并提高安全性。通过`AddRateLimiter`注册服务,并配置不同策略如固定窗口、滑动窗口、令牌桶和并发限制。这些策略可在全局、控制器或动作级别应用,支持自定义响应处理。使用中间件`UseRateLimiter`启用限流功能,并可通过属性禁用特定控制器或动作的限流。这有助于有效保护API免受滥用和过载。 欢迎关注我的公众号:Net分享 (239字符)
25 0
|
18天前
|
弹性计算 Cloud Native Serverless
阿里云 SAE 邀您参加 Serverless 高可用架构挑战赛,赢取精美礼品
阿里云 SAE 邀您参加 Serverless 高可用架构挑战赛,赢取精美礼品。
|
2月前
|
开发框架 监控 .NET
【Azure App Service】部署在App Service上的.NET应用内存消耗不能超过2GB的情况分析
x64 dotnet runtime is not installed on the app service by default. Since we had the app service running in x64, it was proxying the request to a 32 bit dotnet process which was throwing an OutOfMemoryException with requests >100MB. It worked on the IaaS servers because we had the x64 runtime install
|
3月前
|
人工智能 弹性计算 运维
触手可及:阿里云函数计算助力AI大模型的评测
阿里云推出的面向AI服务器的功能计算(Functional Computing, FC),专为AI应用提供弹性计算资源。该服务支持无服务器部署、自动资源管理和多语言支持,极大简化了AI应用的开发和维护。本文全面评测了FC for AI Server的功能特性、使用体验和成本效益,展示了其在高效部署、成本控制和安全性方面的优势,并通过具体应用案例和改进建议,展望了其未来发展方向。
201 4
|
3月前
|
监控 网络安全 调度
Quartz.Net整合NetCore3.1,部署到IIS服务器上后台定时Job不被调度的解决方案
解决Quartz.NET在.NET Core 3.1应用中部署到IIS服务器上不被调度的问题,通常需要综合考虑应用配置、IIS设置、日志分析等多个方面。采用上述策略,结合细致的测试和监控,可以有效地提高定时任务的稳定性和可靠性。在实施任何更改后,务必进行充分的测试,以验证问题是否得到解决,并监控生产环境的表现,确保长期稳定性。
138 1
|
4月前
|
人工智能 自然语言处理 Serverless
阿里云函数计算 x NVIDIA 加速企业 AI 应用落地
阿里云函数计算与 NVIDIA TensorRT/TensorRT-LLM 展开合作,通过结合阿里云的无缝计算体验和 NVIDIA 的高性能推理库,开发者能够以更低的成本、更高的效率完成复杂的 AI 任务,加速技术落地和应用创新。
185 13