使用阿里云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文件
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进行配置。具体的使用方式可以参考阿里云的文档。
部署需要一个配置的文件,我的文件配置如下:
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
{ "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的地址模式。这个大概率和我们提供的路由解析规则不符。因此,请尽量使用自定义域名。