RHEL 10 で .NET 8.0 を使い始める
Red Hat ドキュメントへのフィードバック (英語のみ) リンクのコピーリンクがクリップボードにコピーされました!
Red Hat ドキュメントに関するご意見やご感想をお寄せください。また、改善点があればお知らせください。
Jira からのフィードバック送信 (アカウントが必要)
- Jira の Web サイトにログインします。
- 上部のナビゲーションバーで Create をクリックします。
- Summary フィールドにわかりやすいタイトルを入力します。
- Description フィールドに、ドキュメントの改善に関するご意見を記入してください。ドキュメントの該当部分へのリンクも追加してください。
- ダイアログの下部にある Create をクリックします。
第1章 .NET 8.0 の概要 リンクのコピーリンクがクリップボードにコピーされました!
.NET は、自動メモリー管理と最新のプログラミング言語を備えた汎用開発プラットフォームです。.NET を使用すると、高品質のアプリケーションを効率的に構築できます。一般に、.NET は、認定済みのコンテナーを介して Red Hat Enterprise Linux (RHEL)および OpenShift Container Platform で利用できます。
.NET には次の機能があります。
- マイクロサービスベースのアプローチに従う機能。一部のコンポーネントは .NET で構築され、他のコンポーネントは Java で構築されますが、すべてが RHEL および OpenShift Container Platform でサポートされている共通のプラットフォームで実行できます。
- Microsoft Windows で新しい .NET ワークロードをより簡単に開発する機能。RHEL または Windows Server のいずれかにアプリケーションをデプロイして実行できます。
- 異機種環境のデータセンター。基盤となるインフラストラクチャーが Windows Server にのみ依存することなく .NET アプリケーションを実行できます。
第2章 .NET 8.0 のインストール リンクのコピーリンクがクリップボードにコピーされました!
.NET 8.0 は、RHEL 10 の AppStream リポジトリーに含まれています。AppStream リポジトリーは、RHEL 10 システムでデフォルトで有効になっています。
.NET 8.0 ランタイムは、最新の .NET Software Development Kit (SDK)でインストールできます。新しい SDK が .NET 8.0 で利用可能になったら、dnf を使用してインストールできます。
前提条件
サブスクリプションを割り当てて、RHEL 10 をインストールして登録します。
詳細は、インストールメディアからの RHEL の対話型インストール を参照してください。
手順
.NET 8.0 とそのすべての依存関係をインストールします。
sudo dnf install dotnet-sdk-8.0 -y
$ sudo dnf install dotnet-sdk-8.0 -yCopy to Clipboard Copied! Toggle word wrap Toggle overflow
検証
インストールを確認します。
dotnet --info
$ dotnet --infoCopy to Clipboard Copied! Toggle word wrap Toggle overflow 出力は、.NET インストールおよび環境の関連情報を返します。
第3章 .NET 8.0 を使用したアプリケーションの作成 リンクのコピーリンクがクリップボードにコピーされました!
C# "Hello World" アプリケーションを作成する方法を学びます。
手順
my-appという名前のディレクトリーに、新しい Console アプリケーションを作成します。dotnet new console --output <my-app>
$ dotnet new console --output <my-app>Copy to Clipboard Copied! Toggle word wrap Toggle overflow プロジェクトを実行します。
dotnet run --project <my-app>
$ dotnet run --project <my-app>Copy to Clipboard Copied! Toggle word wrap Toggle overflow 返される出力は以下のとおりです。
Hello World!
Hello World!Copy to Clipboard Copied! Toggle word wrap Toggle overflow
第4章 .NET 8.0 でのアプリケーションの公開 リンクのコピーリンクがクリップボードにコピーされました!
.NET 8.0 アプリケーションを公開して、共有されたシステム全体で使用される .NET を使用するか、.NET を追加できます。
.NET 8.0 アプリケーションを公開するには、以下の方法があります。
- SCD (自己完結型デプロイメント): アプリケーションには .NET が含まれます。この方法では、Microsoft が構築したランタイムを使用します。
- フレームワーク依存デプロイメント (FDD): アプリケーションは、共有されたシステム全体の .NET バージョンを使用します。
RHEL にアプリケーションを公開する場合、Red Hat では FDD を使用することを推奨しています。これは、アプリケーションが、Red Hat が構築した最新バージョンの .NET を使用していることを保証するためです。これは、特定のネイティブ依存関係のセットを使用します。
前提条件
既存の .NET アプリケーション。
.NET アプリケーションの作成方法は、.NET を使用したアプリケーションの作成 を参照してください。
4.1. .NET 8.0 アプリケーションの公開 リンクのコピーリンクがクリップボードにコピーされました!
以下の手順では、フレームワーク依存アプリケーションを公開する方法を概説します。
手順
フレームワーク依存アプリケーションを公開します。
dotnet publish <my-app> -f net8.0
$ dotnet publish <my-app> -f net8.0Copy to Clipboard Copied! Toggle word wrap Toggle overflow 注記<my-app>は、公開するアプリケーションの名前に置き換えます。任意: アプリケーションが RHEL 専用の場合は、次のコマンドを使用してその他のプラットフォームに必要な依存関係を削除します。
dotnet publish <my-app> -f net8.0 -r rhel.10-architecture --self-contained false
$ dotnet publish <my-app> -f net8.0 -r rhel.10-architecture --self-contained falseCopy to Clipboard Copied! Toggle word wrap Toggle overflow architecture は、使用しているプラットフォームに基づいて置き換えます。
-
Intel の場合:
x64 -
IBM Z および LinuxONE の場合:
s390x -
64 ビット Arm の場合:
arm64 -
IBM Power の場合:
ppc64le
-
Intel の場合:
第5章 コンテナーでの .NET 8.0 アプリケーションの実行 リンクのコピーリンクがクリップボードにコピーされました!
ubi8/dotnet-80-runtime イメージを使用して、.NET コンテナーで事前コンパイルされたアプリケーションを実行します。
以下の例では Podman を使用しています。
手順
mvc_runtime_exampleという名前のディレクトリーに新しい MVC プロジェクトを作成します。dotnet new mvc --output mvc_runtime_example
$ dotnet new mvc --output mvc_runtime_exampleCopy to Clipboard Copied! Toggle word wrap Toggle overflow プロジェクトを公開します。
dotnet publish mvc_runtime_example -f net8.0 /p:PublishProfile=DefaultContainer /p:ContainerBaseImage=registry.access.redhat.com/ubi8/dotnet-80-runtime:latest
$ dotnet publish mvc_runtime_example -f net8.0 /p:PublishProfile=DefaultContainer /p:ContainerBaseImage=registry.access.redhat.com/ubi8/dotnet-80-runtime:latestCopy to Clipboard Copied! Toggle word wrap Toggle overflow イメージを実行します。
podman run -rm -p8080:8080 mvc_runtime_example
$ podman run -rm -p8080:8080 mvc_runtime_exampleCopy to Clipboard Copied! Toggle word wrap Toggle overflow コンテナーで実行されているアプリケーションを表示します。
xdg-open http://127.0.0.1:8080
$ xdg-open http://127.0.0.1:8080Copy to Clipboard Copied! Toggle word wrap Toggle overflow
第6章 以前のバージョンの .NET からの移行 リンクのコピーリンクがクリップボードにコピーされました!
6.1. .NET バージョンからの移行 リンクのコピーリンクがクリップボードにコピーされました!
Microsoft 社は、ほとんどの以前の .NET Core バージョンから移行する手順を提供します。
サポート対象外になったバージョンの .NET を使用している場合や、新しいバージョンの .NET に移行して機能を拡張する場合は、以下のアーティクルを参照してください。
- ASP.NET Core 8.0 から 9.0 への移行
- ASP.NET Core 7.0 から 8.0 への移行
- ASP.NET Core 6.0 から 7.0 への移行
- ASP.NET Core 5.0 から 6.0 への移行
- ASP.NET Core 3.1 から 5.0 への移行
- ASP.NET Core 3.0 から 3.1 への移行
- ASP.NET Core 2.2 から 3.0 への移行
- ASP.NET Core 2.1 から 2.2 への移行
- .NET Core 2.0 から 2.1 への移行
- ASP.NET から ASP.NET Core への移行
- project.json からの .NET Core プロジェクトの移行
- project.json から .csproj 形式への移行
.NET Core 1.x から 2.0 に移行する場合は、Migrate from ASP.NET Core 1.x to 2.0 の最初のいくつかのセクションを参照してください。これらのセクションでは、.NET Core 1.x から 2.0 への移行パスに適した概略を説明しています。
6.2. .NET Framework からの移植 リンクのコピーリンクがクリップボードにコピーされました!
.NET Framework から移行する場合は、次の Microsoft の記事を参照してください。
- 一般的なガイドラインは、Porting to .NET Core from .NET Framework を参照してください。
- ライブラリーの移植は、Porting to .NET Core - Libraries を参照してください。
- ASP.NET Core への移行は、Migrating to ASP.NET Core を参照してください。
.NET Framework に存在するいくつかの技術と API は、.NET Core および .NET では使用できません。アプリケーションまたはライブラリーにこれらの API が必要な場合は、代わりの方法を検討するか、.NET Framework の使用を継続してください。.NET Core および .NET では、次の技術と API はサポートされません。
- Windows Forms や WPF (Windows Presentation Foundation) などのデスクトップアプリケーション
- Windows Communication Foundation (WCF) サーバー (WCF クライアントがサポートされています)
- .NET リモート処理
さらに、多くの .NET API は、Microsoft Windows 環境でのみ使用できます。次のリストでは、この Windows 固有の API の例を示しています。
-
Microsoft.Win32.Registry -
System.AppDomains -
System.Security.Principal.Windows
.NET のデフォルトバージョンでサポートされない一部の API は、Microsoft.Windows.Compatibility NuGet パッケージで利用できます。この NuGet パッケージを使用するときは注意してください。提供される API の一部 (Microsoft.Win32.Registry など) は Windows でのみ動作するため、アプリケーションは Red Hat Enterprise Linux と互換性がありません。