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

相关推荐
韩楚风2 小时前
【linux 多进程并发】linux进程状态与生命周期各阶段转换,进程状态查看分析,助力高性能优化
linux·服务器·性能优化·架构·gnu
陈苏同学2 小时前
4. 将pycharm本地项目同步到(Linux)服务器上——深度学习·科研实践·从0到1
linux·服务器·ide·人工智能·python·深度学习·pycharm
Ambition_LAO2 小时前
解决:进入 WSL(Windows Subsystem for Linux)以及将 PyCharm 2024 连接到 WSL
linux·pycharm
Pythonliu73 小时前
茴香豆 + Qwen-7B-Chat-Int8
linux·运维·服务器
你疯了抱抱我3 小时前
【RockyLinux 9.4】安装 NVIDIA 驱动,改变分辨率,避坑版本。(CentOS 系列也能用)
linux·运维·centos
追风赶月、3 小时前
【Linux】进程地址空间(初步了解)
linux
栎栎学编程3 小时前
Linux中环境变量
linux
挥剑决浮云 -3 小时前
Linux 之 安装软件、GCC编译器、Linux 操作系统基础
linux·服务器·c语言·c++·经验分享·笔记
小O_好好学4 小时前
CentOS 7文件系统
linux·运维·centos
x晕x5 小时前
Linux dlsym符号查找疑惑分析
linux·运维·服务器