嵌入式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 的部署和示例应用运行。

相关推荐
梅见十柒20 分钟前
wsl2中kali linux下的docker使用教程(教程总结)
linux·经验分享·docker·云原生
Koi慢热23 分钟前
路由基础(全)
linux·网络·网络协议·安全
传而习乎33 分钟前
Linux:CentOS 7 解压 7zip 压缩的文件
linux·运维·centos
soulteary35 分钟前
突破内存限制:Mac Mini M2 服务器化实践指南
运维·服务器·redis·macos·arm·pika
我们的五年43 分钟前
【Linux课程学习】:进程程序替换,execl,execv,execlp,execvp,execve,execle,execvpe函数
linux·c++·学习
霍先生的虚拟宇宙网络1 小时前
.net 支持跨平台(桌面)系列技术汇总
.net
IT果果日记1 小时前
ubuntu 安装 conda
linux·ubuntu·conda
djk88881 小时前
.net的winfrom程序 窗体透明&打开窗体时出现在屏幕右上角
.net
Python私教1 小时前
ubuntu搭建k8s环境详细教程
linux·ubuntu·kubernetes
羑悻的小杀马特1 小时前
环境变量简介
linux