「Linuxその他 - AppImage」の版間の差分

提供:MochiuWiki : SUSE, EC, PCB
ナビゲーションに移動 検索に移動
 
(同じ利用者による、間の3版が非表示)
8行目: 8行目:
AppImageはユニバーサルソフトウェアパッケージフォーマットであり、AppImageでソフトウェアをパッケージ化することにより、開発者は「すべてを支配する」1つのファイルだけを提供することができる。<br>
AppImageはユニバーサルソフトウェアパッケージフォーマットであり、AppImageでソフトウェアをパッケージ化することにより、開発者は「すべてを支配する」1つのファイルだけを提供することができる。<br>
エンドユーザー、つまり、最新のLinuxディストリビューションのほとんど(全てではないにしても)で使用することができる。<br>
エンドユーザー、つまり、最新のLinuxディストリビューションのほとんど(全てではないにしても)で使用することができる。<br>
<br><br>
== AppImageの特徴 ==
* ディストリビューションに依存しない:さまざまなLinuxディストリビューションで実行可能である。
* ソフトウェアのインストールやコンパイルが不要クリックして再生するだけである。
* root権限不要:システムファイルに触れることはない。
* 移植性が良いため、ライブディスクを含め、どこでも実行可能である。
* ソフトウェア本体は読み取り専用モード
* AppImageファイルを削除するだけでソフトウェアが削除される。
* AppImageでパッケージされたソフトウェアは、デフォルトではサンドボックス化されていない。
<br><br>
== AppImageの注意点 ==
AppImageについては、さらに知っておくべきことがいくつかある。<br>
<br>
* パッケージングが不十分なAppImageは、実行権限があっても実行されない。
*: AppImageのコンセプトは、全ての依存関係をパッケージ自体の中に持つことである。
*: しかし、開発者が依存関係を全てパッケージ化したつもりでも、実際にはそうなっていない場合がある。
*: そのような場合、AppImageを実行してもソフトウェアは起動しない。
*: AppImageにパッケージング上の問題がある場合、開発者に連絡して、その旨を伝える必要がある。
*: <br>
* AppImage Launcherを使用しないデスクトップ統合
*: AppImageを実行すると、ソフトウェアによっては「デスクトップファイルをインストールする」よう求めるメッセージが表示されることがある。
*: 「はい」を選択すると、AppImageは通常インストールされるアプリケーションのようにLinuxシステムに統合される。
*: <br>
* AppImage Launcherを使用しないデスクトップ統合では、削除後に手動でのクリーンアップが必要になる場合がある。
*: デスクトップ統合を選択した場合、システムにいくつかのファイルが作成される。
*: AppImage Launcherとは異なり、AppImageファイルを削除しても、これらのデスクトップファイルはシステムに残る。
*: そのため、そのままにする、または、手動で削除する必要がある。
*: <br>
* アップデートは必ずしもオプションではない。
*: ソフトウェアによっては、自動的にアップデートをチェックして、新しいバージョンが入手可能になったことを通知してくれるものもあるかもしれない。
*: しかし、ほとんどの場合、そうはならない。
*: これは、開発者がこのオプションを提供しているかどうかによる。
<br><br>
<br><br>


23行目: 57行目:
<br><br>
<br><br>


== AppImageファイルの作成 : .NETアプリケーション ==
==== .NETアプリケーションのパブリッシュ ====
.NETアプリケーションをビルドする。<br>
dotnet publish -c:Release                \
                -r:linux-x64              \
                -p:PublishReadyToRun=false \
                -p:PublishSingleFile=true  \
                --self-contained true
<br>
==== AppImageKitのダウンロード ====
まず、[https://github.com/AppImage/AppImageKit/ AppImageKitのGithub]にアクセスして、AppImageKitをダウンロードする。<br>
または、<code>wget</code>コマンド等を使用して、AppImageKitをダウンロードする。<br>
wget https://github.com/AppImage/AppImageKit/releases/download/continuous/appimagetool-x86_64.AppImage
<br>
AppImageKitに実行権限を付加する。<br>
chmod u+x appimagetool-x86_64.AppImage
<br>
==== AppDirの構成 ====
次に、AppDirを構成する。<br>
mkdir <AppImageのルートディレクトリ>
mkdir -p /<AppImageのルートディレクトリ>/{usr/bin,usr/share/applications,usr/share/icon,usr/share/metainfo}
<br>
.NETアプリケーションをusr/binディレクトリにコピーする。<br>
cp <.NETアプリケーションのパス> /<AppImageのルートディレクトリ>/usr/bin
<br>
.NETアプリケーションのアイコンをAppImageのルートディレクトリに配置する。<br>
cp <アイコンファイルのパス> <AppImageのルートディレクトリ>
<br>
デスクトップエントリファイルを作成する。<br>
vi /<AppImageのルートディレクトリ>/<デスクトップエントリファイル名>.desktop
<br>
<syntaxhighlight lang="ini">
# /<AppImageのルートディレクトリ>/<デスクトップエントリファイル名>.desktopファイル
[Desktop Entry]
Type=Application
Name=<任意のアプリケーション名>
GenericName=<汎用的な任意のアプリケーション名>
Comment=<アプリケーションの説明>
Comment[ja_JP]=<アプリケーションの説明>
Exec=<実行ファイル名>
Icon=<アイコンファイル名>
Categories=<任意のカテゴリ  例: Utility>;
Terminal=false  # (オプション) GUIアプリケーションの場合はfalseを指定する
</syntaxhighlight>
<br>
.NETアプリケーションのAppImageを作成する場合は、エントリーポイントの設定が必要なため、AppRunファイルを作成する。<br>
vi /<AppImageのルートディレクトリ>/AppRun
<br>
<syntaxhighlight lang="sh">
# /<AppImageのルートディレクトリ>/AppRunファイル
#!/usr/bin/env sh
appname="<アプリケーションファイル名>"
# use -f to make the readlink path absolute
dirname="$(dirname -- "$(readlink -f -- "${0}")" )"
if [ "$dirname" = "." ]; then
    dirname="$PWD/$dirname"
fi
export DOTNET_ROOT="$dirname/usr/bin"
# Run Application binary
exec "$dirname/usr/bin/$appname" "$@"
</syntaxhighlight>
<br>
AppRunファイルに実行権限を付加する。<br>
chmod u+x /<AppImageのルートディレクトリ>/AppRun
<br>
==== AppImageファイルの生成 ====
AppImageファイルを生成する。<br>
./appimagetool-x86_64.AppImage <任意のディレクトリ名> <任意のAppImageファイル名>.AppImage
<br><br>
{{#seo:
|title={{PAGENAME}} : Exploring Electronics and SUSE Linux | MochiuWiki
|keywords=MochiuWiki,Mochiu,Wiki,Mochiu Wiki,Electric Circuit,Electric,pcb,Mathematics,AVR,TI,STMicro,AVR,ATmega,MSP430,STM,Arduino,Xilinx,FPGA,Verilog,HDL,PinePhone,Pine Phone,Raspberry,Raspberry Pi,C,C++,C#,Qt,Qml,MFC,Shell,Bash,Zsh,Fish,SUSE,SLE,Suse Enterprise,Suse Linux,openSUSE,open SUSE,Leap,Linux,uCLnux,Podman,電気回路,電子回路,基板,プリント基板
|description={{PAGENAME}} - 電子回路とSUSE Linuxに関する情報 | This page is {{PAGENAME}} in our wiki about electronic circuits and SUSE Linux
|image=/resources/assets/MochiuLogo_Single_Blue.png
}}


__FORCETOC__
__FORCETOC__
[[カテゴリ:RHEL]][[カテゴリ:SUSE]][[カテゴリ:Raspberry_Pi]][[カテゴリ:PinePhone]]
[[カテゴリ:RHEL]][[カテゴリ:SUSE]][[カテゴリ:Raspberry_Pi]][[カテゴリ:PinePhone]]

2025年1月7日 (火) 00:18時点における最新版

概要

AppImageは、比較的新しいパッケージングフォーマットであり、Linuxでソフトウェアを実行するためのClick to Runの方法を提供している。

従来のDEB / RPMパッケージとは異なり、AppImageはどのディストリビューションでも使用できるため、Linuxユーザにとって非常に魅力的なものとなっている。
従来のパッケージは、それぞれのディストリビューションにソフトウェアをインストールする便利な方法を提供するが、ソフトウェア開発者にとってはあまり便利な方法ではない。
ソフトウェア開発者は、複数のディストリビューション用に複数のパッケージを作成しなければならない。

AppImageはユニバーサルソフトウェアパッケージフォーマットであり、AppImageでソフトウェアをパッケージ化することにより、開発者は「すべてを支配する」1つのファイルだけを提供することができる。
エンドユーザー、つまり、最新のLinuxディストリビューションのほとんど(全てではないにしても)で使用することができる。


AppImageの特徴

  • ディストリビューションに依存しない:さまざまなLinuxディストリビューションで実行可能である。
  • ソフトウェアのインストールやコンパイルが不要クリックして再生するだけである。
  • root権限不要:システムファイルに触れることはない。
  • 移植性が良いため、ライブディスクを含め、どこでも実行可能である。
  • ソフトウェア本体は読み取り専用モード
  • AppImageファイルを削除するだけでソフトウェアが削除される。
  • AppImageでパッケージされたソフトウェアは、デフォルトではサンドボックス化されていない。



AppImageの注意点

AppImageについては、さらに知っておくべきことがいくつかある。

  • パッケージングが不十分なAppImageは、実行権限があっても実行されない。
    AppImageのコンセプトは、全ての依存関係をパッケージ自体の中に持つことである。
    しかし、開発者が依存関係を全てパッケージ化したつもりでも、実際にはそうなっていない場合がある。
    そのような場合、AppImageを実行してもソフトウェアは起動しない。
    AppImageにパッケージング上の問題がある場合、開発者に連絡して、その旨を伝える必要がある。

  • AppImage Launcherを使用しないデスクトップ統合
    AppImageを実行すると、ソフトウェアによっては「デスクトップファイルをインストールする」よう求めるメッセージが表示されることがある。
    「はい」を選択すると、AppImageは通常インストールされるアプリケーションのようにLinuxシステムに統合される。

  • AppImage Launcherを使用しないデスクトップ統合では、削除後に手動でのクリーンアップが必要になる場合がある。
    デスクトップ統合を選択した場合、システムにいくつかのファイルが作成される。
    AppImage Launcherとは異なり、AppImageファイルを削除しても、これらのデスクトップファイルはシステムに残る。
    そのため、そのままにする、または、手動で削除する必要がある。

  • アップデートは必ずしもオプションではない。
    ソフトウェアによっては、自動的にアップデートをチェックして、新しいバージョンが入手可能になったことを通知してくれるものもあるかもしれない。
    しかし、ほとんどの場合、そうはならない。
    これは、開発者がこのオプションを提供しているかどうかによる。



AppImageファイルの展開

まず、AppImageファイルが最新バージョンの内部フォーマットを使用しているかどうかを確認する。

./<AppImageファイル> --appimage-help


出力に次のような行がある場合、埋め込まれたファイルシステムのイメージからコンテンツを取り出すことができる。

./<AppImageファイル> --appimage-extract


上記のコマンドが失敗する場合は、ヘルパーツールを使用することができる。
AppImageToolをダウンロードする。
AppImageToolを実行する。

./<AppImageToolファイル> --list <展開するディレクトリ>



AppImageファイルの作成 : .NETアプリケーション

.NETアプリケーションのパブリッシュ

.NETアプリケーションをビルドする。

dotnet publish -c:Release                 \
               -r:linux-x64               \
               -p:PublishReadyToRun=false \
               -p:PublishSingleFile=true  \ 
               --self-contained true


AppImageKitのダウンロード

まず、AppImageKitのGithubにアクセスして、AppImageKitをダウンロードする。
または、wgetコマンド等を使用して、AppImageKitをダウンロードする。

wget https://github.com/AppImage/AppImageKit/releases/download/continuous/appimagetool-x86_64.AppImage


AppImageKitに実行権限を付加する。

chmod u+x appimagetool-x86_64.AppImage


AppDirの構成

次に、AppDirを構成する。

mkdir <AppImageのルートディレクトリ>
mkdir -p /<AppImageのルートディレクトリ>/{usr/bin,usr/share/applications,usr/share/icon,usr/share/metainfo}


.NETアプリケーションをusr/binディレクトリにコピーする。

cp <.NETアプリケーションのパス> /<AppImageのルートディレクトリ>/usr/bin


.NETアプリケーションのアイコンをAppImageのルートディレクトリに配置する。

cp <アイコンファイルのパス> <AppImageのルートディレクトリ>


デスクトップエントリファイルを作成する。

vi /<AppImageのルートディレクトリ>/<デスクトップエントリファイル名>.desktop


 # /<AppImageのルートディレクトリ>/<デスクトップエントリファイル名>.desktopファイル
 
 [Desktop Entry]
 Type=Application
 Name=<任意のアプリケーション名>
 GenericName=<汎用的な任意のアプリケーション名>
 Comment=<アプリケーションの説明>
 Comment[ja_JP]=<アプリケーションの説明>
 Exec=<実行ファイル名>
 Icon=<アイコンファイル名>
 Categories=<任意のカテゴリ  例: Utility>;
 Terminal=false  # (オプション) GUIアプリケーションの場合はfalseを指定する


.NETアプリケーションのAppImageを作成する場合は、エントリーポイントの設定が必要なため、AppRunファイルを作成する。

vi /<AppImageのルートディレクトリ>/AppRun


 # /<AppImageのルートディレクトリ>/AppRunファイル
 
 #!/usr/bin/env sh
 
 appname="<アプリケーションファイル名>"
 
 # use -f to make the readlink path absolute
 dirname="$(dirname -- "$(readlink -f -- "${0}")" )"
 
 if [ "$dirname" = "." ]; then
    dirname="$PWD/$dirname"
 fi
 
 export DOTNET_ROOT="$dirname/usr/bin"
 
 # Run Application binary
 exec "$dirname/usr/bin/$appname" "$@"


AppRunファイルに実行権限を付加する。

chmod u+x /<AppImageのルートディレクトリ>/AppRun


AppImageファイルの生成

AppImageファイルを生成する。

./appimagetool-x86_64.AppImage <任意のディレクトリ名> <任意のAppImageファイル名>.AppImage