嵌入式Linux下运行 DotNet 应用简单示例

By Toradex秦海

1). 简介

嵌入式 Linux 逐渐成为嵌入式设备的主流操作系统,但是应用开发工程师很多更熟悉 Microsoft C# 开发,得益于 Microsoft .Net Framework 的跨平台支持,本文就简单示例在 Embedded Linux 环境运行 .NET 应用。

本文所演示的平台来自于Toradex Apalis iMX8 嵌入式平台,基于 NXP iMX8 系列 ARM 处理器,核心为 Cortex-A52/A53 。

2 ) . 硬件 准备

a). Apalis iMX8 ARM 核心版配合 Apalis Eva Board 载板,并连接调试串口和网口以便测试。

3). 部署 Microsoft .Net Framework 运行库到 Embedded Linux BSP

a). Apalis iMX8 模块标准 Ycoto Linux BSP 中默认没有包含 Microsoft .Net Framework 相关 runtime 运行库支持,可以参考这里 Microsoft 官方文档通过 script 方式安装,不过为了方便管理和部署,本文演示通过 Ycoto Project/Openembedded 编译方式来添加相关库文件,Ycoto Project .Net Framework runtime 由下面 meta-dotnet-core layer 来提供,详细说明可以参考项目 ++++README++++ 的说明。

https://github.com/RDunkley/meta-dotnet-core

b). 首先需要在 Linux编译开发主机部署 Ycoto 编译环境,然后参考如下步骤部署。

./ 下载 meta-dotnet-core layer


$ cd .../oe_core/layers

$ git clone https://github.com/RDunkley/meta-dotnet-core.git


./ 修改 build/conf/bblayer.conf 文件添加相关 layer


--- a/build/conf/bblayers.conf 2023-03-30 11:13:22.946533642 +0800

+++ b/build/conf/bblayers.conf 2023-11-17 16:03:01.666129480 +0800

@@ -35,6 +35,7 @@

${TOPDIR}/../layers/meta-freescale-distro \

${TOPDIR}/../layers/meta-toradex-demos \

${TOPDIR}/../layers/meta-qt5 \

  • ${TOPDIR}/../layers/meta-dotnet-core \

\

\

${TOPDIR}/../layers/meta-toradex-distro \


./修改 build/conf/local.conf 文件,增加 .NET 相关库组件,如果需要可以选择指定 .NET runtime 版本,本文编译测试没有指定,默认是支持的最高版本,当前是 7.0.11 版本


add dotnet runtime

IMAGE_INSTALL:append = " dotnet-core"

Optional - specify dotnet runtime version

PREFERRED_VERSION_dotnet-core = "6.0.0"


当然也可以选择添加 ASP .NET (aspnet-core) 和 Visual Studio Remote Debugger (vsdbg) 组件,需要注意 ASP .NET runtime 会包含 .NET runtime,因此两者不要同时添加


add asp dotnet runtime

IMAGE_INSTALL:append = " aspnet-core"

add VS remote debugger

IMAGE_INSTALL:append = " vsdbg"


./ 重新编译生成 Ycoto Linux BSP Image


$ MACHINE="apalis-imx8" PARALLEL_MAKE="-j 4" BB_NUMBER_THREADS="4" bitbake tdx-reference-multimedia-image


c). 参考这里的说明将上述修改下重新编译生成的 Ycoto Linux Image 通过 Toradex Easy Installer 更新到 Apalis iMX8 模块。

4 ). 生成 .NET 7.0 Console 测试应用

a). 可以通过 Virtual Studio 或者 Virtual Studio Code IDE 来生成这个 Hello World Console 应用,本文参考这里的说明使用 VS Code来生成,VS Code Terminal 操作如下


$ dotnet --list-sdks

7.0.114 [/usr/lib/dotnet/sdk]

$ dotnet new console -f net7.0

欢迎使用 .NET 7.0!


SDK 版本: 7.0.114


已安装 ASP.NET Core HTTPS 开发证书。

若要信任该证书,请运行 "dotnet dev-certs https --trust" (仅限 Windows 和 macOS)。

了解 HTTPS: https://aka.ms/dotnet-https


编写你的第一个应用: https://aka.ms/dotnet-hello-world

查找新增功能: https://aka.ms/dotnet-whats-new

浏览文档: https://aka.ms/dotnet-docs

在 GitHub 上报告问题和查找源: https://github.com/dotnet/core

使用 "dotnet --help" 查看可用命令或访问: https://aka.ms/dotnet-cli


已成功创建模板"控制台应用"。

正在处理创建后操作...

正在还原 /home/simon/local/project/vscode/DotNetExample/DotNetExample.csproj:

Determining projects to restore...

Restored /home/simon/local/project/vscode/DotNetExample/DotNetExample.csproj (in 95 ms).

已成功还原。

$ dotnet run

Hello, World!

$ dotnet publish

MSBuild version 17.4.8+6918b863a for .NET

Determining projects to restore...

All projects are up-to-date for restore.

DotNetExample -> /home/simon/local/project/vscode/DotNetExample/bin/Debug/net7.0/DotNetExample.dll

DotNetExample -> /home/simon/local/project/vscode/DotNetExample/bin/Debug/net7.0/publish/


5 ). 在Apalis iMX8 Embedded Linux 下测试 .NET 7.0 Console 应用

a). 通过 scp 将 publish 的 .NET 7.0 应用传输到 Apalis iMX8 模块

./ Apalis iMX8 测试上面章节3 部署的 .NET runtime 环境


root@apalis-imx8-06738378:~# dotnet --info

Host:

Version: 7.0.11

Architecture: arm64

Commit: ecb34f85ec

.NET SDKs installed:

No SDKs were found.

.NET runtimes installed:

Microsoft.NETCore.App 7.0.11 [/usr/share/dotnet/shared/Microsoft.NETCore.App]

Other architectures found:

None

Environment variables:

Not set

global.json file:

Not found

Learn more:

https://aka.ms/dotnet/info

Download .NET:

.NET Downloads (Linux, macOS, and Windows)


./ 将示例 .NET 应用从开发主机复制到 Apalis iMX8


create app folder on Apalis iMX8

root@apalis-imx8-06738378:~# cd ~

root@apalis-imx8-06738378:~# mkdir DotNetExample

scp published app to apalis iMX8

$ scp -r /home/simon/local/project/vscode/DotNetExample/bin/Debug/net7.0/publish/* root@<apalis_imx8_ipaddress>:/home/root/DotNetExample


b). 运行测试应用


root@apalis-imx8-06738378:~# cd DotNetExample/

root@apalis-imx8-06738378:~/DotNetExample# dotnet DotNetExample.dll

Hello, World!


6 ). 总结

本文基于嵌入式 Linux 简单演示了 .NET runtime 的部署和示例应用运行。

相关推荐
林政硕(Cohen0415)3 分钟前
Linux驱动开发进阶(三)- 热插拔机制
linux·驱动开发·热插拔
wangjun51595 分钟前
linux,物理机、虚拟机,同时内外网实现方案;物理机与虚拟机互通网络;
linux·服务器·网络
杰克崔10 分钟前
分析sys高问题的方法总结
linux·运维·服务器
WSSWWWSSW10 分钟前
安装nfs客户端(centos)
linux·运维·centos
李迟1 小时前
跨系统平台实践:在内网自建kylin服务版系统yum源
linux
AI.NET 极客圈1 小时前
AI与.NET技术实操系列(四):使用 Semantic Kernel 和 DeepSeek 构建AI应用
人工智能·.net
odoo-卜永1 小时前
ubuntu22.04连接爱普生打印机型号L385
linux·经验分享·ubuntu
源之缘-OFD先行者2 小时前
GMap.NET + WPF:构建高性能 ADS-B 航空器追踪平台
.net·wpf·ads-b
小麦嵌入式2 小时前
Linux驱动开发实战(十一):GPIO子系统深度解析与RGB LED驱动实践
linux·c语言·驱动开发·stm32·嵌入式硬件·物联网·ubuntu
刘若水2 小时前
Linux: 进程信号初识
linux·运维·服务器