在Linux环境下部署和运行.NET应用,需要先完成运行环境配置,再通过发布后的应用文件启动服务,整个过程操作逻辑清晰,适配大多数主流Linux发行版。

一、准备Linux运行环境
首先需要在Linux服务器上安装.NET运行时,不同发行版的安装命令略有差异,以下是常见发行版的安装方式。
1. Ubuntu/Debian系统安装
先添加微软的包源,再安装对应的运行时版本,这里以.NET 8运行时为例:
# 安装系统依赖 sudo apt-get update && sudo apt-get install -y apt-transport-https # 添加微软包源密钥 wget https://packages.microsoft.com/config/ubuntu/22.04/packages-microsoft-prod.deb -O packages-microsoft-prod.deb sudo dpkg -i packages-microsoft-prod.deb rm packages-microsoft-prod.deb # 安装.NET 8运行时 sudo apt-get update && sudo apt-get install -y dotnet-runtime-8.0
2. CentOS/RHEL系统安装
CentOS系统需要通过yum包管理器完成安装:
# 添加微软包源 sudo rpm -Uvh https://packages.microsoft.com/config/centos/7/packages-microsoft-prod.rpm # 安装.NET 8运行时 sudo yum install -y dotnet-runtime-8.0
安装完成后可以执行dotnet --version命令验证运行时是否安装成功,如果返回对应的版本号说明环境配置完成。
二、发布.NET应用
在本地开发环境完成应用编码后,需要将应用发布为适配Linux系统的版本,有两种常用的发布方式。
1. 框架依赖发布
这种方式发布的应用体积小,依赖目标机器的.NET运行时,执行以下命令发布:
# 进入项目根目录 cd /path/to/your/project # 发布为Linux-x64框架依赖版本 dotnet publish -c Release -r linux-x64 --self-contained false
发布后的文件会存放在bin/Release/net8.0/linux-x64/publish目录下,将该目录下的所有文件上传到Linux服务器的指定目录即可。
2. 独立发布
这种方式会将运行时一同打包到发布文件中,目标机器不需要提前安装.NET运行时,执行以下命令:
dotnet publish -c Release -r linux-x64 --self-contained true
三、运行.NET应用
将发布文件上传到Linux服务器后,进入发布文件所在目录,执行以下命令启动应用:
# 进入发布目录 cd /var/www/dotnet_app/publish # 启动应用,假设应用入口文件是MyApp.dll dotnet MyApp.dll --urls=http://0.0.0.0:5000
其中--urls参数用于指定应用监听的端口,设置为http://0.0.0.0:5000可以让应用监听所有网络接口的5000端口,方便外部访问。
四、配置系统服务实现开机自启
直接使用dotnet命令启动的应用会在终端关闭后停止运行,因此需要配置systemd服务让应用后台稳定运行。
首先创建服务文件:
sudo vim /etc/systemd/system/dotnet_app.service
在服务文件中添加以下内容:
[Unit] Description=Dotnet App Service After=network.target [Service] Type=simple User=www-data WorkingDirectory=/var/www/dotnet_app/publish ExecStart=/usr/bin/dotnet /var/www/dotnet_app/publish/MyApp.dll --urls=http://0.0.0.0:5000 Restart=always RestartSec=10 [Install] WantedBy=multi-user.target
其中User是运行服务的用户,WorkingDirectory是发布文件所在目录,ExecStart是启动应用的命令,根据实际路径修改即可。
保存文件后执行以下命令启动服务并设置开机自启:
# 重新加载systemd配置 sudo systemctl daemon-reload # 启动服务 sudo systemctl start dotnet_app # 设置开机自启 sudo systemctl enable dotnet_app # 查看服务运行状态 sudo systemctl status dotnet_app
五、常见问题解决
- 如果启动时报错提示缺少依赖,需要安装对应的系统依赖库,比如
libicu-dev等 - 如果端口无法访问,需要检查Linux防火墙是否开放了对应端口,执行
sudo ufw allow 5000/tcp开放5000端口 - 如果服务启动失败,可以通过
sudo journalctl -u dotnet_app -f查看服务日志定位问题