4
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

FreeBSDAdvent Calendar 2023

Day 25

FreeBSD pkg コマンド概要

Last updated at Posted at 2023-12-24

はじめに

FreeBSDにおけるサードパーティ製ツール導入のための仕組み(ports および packages)の充実によって、バイナリパッケージの利用が進化してきました。
特にフレイバー機能導入の恩恵は大きく、インストールされる内容は同一のものであるにも関わらず、依存するパッケージのバージョン依存のために、組み合わせが複雑になってしまうようなケースでも、シンプルにパッケージが用意できるようになっています。あとはその依存されるパッケージのバージョン全てに対してパッケージが用意されてれば…と思わなくも無いです。
ここでは、バイナリパッケージの恩恵を受けるべく、よく使うコマンドをとりまとめました。とは言え細かいオプションまで言及すると大変なので、よく使うオプションだけ明示していきます。
またほとんどのコマンドで実行の可否を聞いてきます。そのためほぼ共通と言っていい -y オプションがあったりするのですが、この辺りの説明は省きます。慣れたら使うようにしましょう。
その他にも、あまり実行事例を書いていません。使い方がよく分からない等ありましたらお知らせください。肉付けしたいと思います。

よく使う pkg コマンド

ここではコマンド名(サブコマンド名)に対して [R][L] のマークを付けておきます。これは以下の通りとなります。

  • [R]: 外部パッケージ/リポジトリに存在する情報を参照します。
  • [L]: インストール済みまたはローカルファイルシステムに存在するパッケージに対する情報を参照します。
  • [RL]: 環境に応じて [R] にも [L] にも振る舞います。

pkg update [R]

パッケージメタデータを収集するためのコマンドです。何よりも先にメタデータの収集が必要となります。
この辺りは yum check-update に通じるものがあります。
なお、常に必要なコマンドというのではなく、自動的にメタデータの更新を実施してから動くコマンドはあるので、それが気にならないなら実行する必要はないです。
具体的には以下のサブコマンドでは最新のメタデータに基づいて実行します。

  • pkg install
  • pkg upgrade
  • pkg version
  • pkg search
  • pkg fetch
  • pkg rquery

pkg install [R]

パッケージのインストールを行います。後述する pkg add との違いは、キーワードで特定&ネットワーク取得からのパッケージのインストールとなります。

pkg add [L]

指定されたパッケージファイルのインストールを行います。前述の pkg install と違い、パッケージファイル名を明示してのインストールとなります。

pkg delete [L]

指定されたパッケージを削除します。

pkg delete -ayf

全ての(-a)パッケージを無慈悲(-f)かつ問答無用(-y)で削除します。直観的には -ay オプションの指定で十分なのですが、依存関係の都合で消せないケースでは -f オプションの指定が必要となります。
どのみち全部消すつもりなら遠慮会釈無く全部指定しましょう。

pkg version [RL]

パッケージのバージョン比較を行います。一言で言うには癖が強いので、ユースケースを分解して解説します。

デフォルトで /usr/ports/INDEX-OSメジャーバージョン と言うメタファイルとの比較を行います。このファイルが存在しない場合、各 ports のオリジン(ディレクトリ)を参照します(-P オプション指定相当)。またこのディレクトリが存在しない場合、リモートリポジトリを参照します(-R オプション指定相当)。

前者2ケースの場合は [L] 相当で、後者のケースでは [R] 相当となります。

pkg version -L =

通常は -L オプションを指定して、インストール済みパッケージとの比較を行い、イコールで「無い」ものを表示します。イディオム的に = しか指定しないものと思って問題無いです。参考として = の他に ><?! の指定が可能ですが、どれもこれもクォートが必要な文字となっています。

各文字の意味は下記の通りですが、-L オプションの場合、その文字以外という意味になります。逆にその文字の意味が欲しい場合は -l オプションを使用します。

  • >: 現在インストールされているものより新しいバージョンがリリースされている場合
  • =: 現在インストールされているものと同等のバージョンがリリースされている場合
  • <: 現在インストールされているものより古いバージョンがリリースされている場合、通常メタデータが更新されていない、新しい ports のテストインストールといったケースで発生する
  • ?: 現在インストールされているパッケージのオリジンが存在しない(削除またはリネームにより)ため、バージョン比較ができない場合
  • !: 現在インストールされているバージョンとのバージョン比較ができない場合

pkg version -t

任意のバージョン番号(=ただの文字列)を指定して比較、その結果を返します。これはパッケージのための機能というよりも、多種多様なバージョン番号をテストするための機能となります。これだけ他のサブコマンドと比較して、毛色が違う機能になります。
特にα版、β版といったバージョン指定の置き換えの際に、どっちが大きくて(最新)、どっちが小さい(最古)かわからないケースをトライ&エラーするために存在しています。
バージョン比較についてのルールについては FreeBSD Porter's Handbook - 5.2.2. Versions, DISTVERSION or PORTVERSION をご覧ください。

pkg upgrade [R]

指定されたパッケージを更新します。特に指定がない場合は全てのパッケージに対して更新可否を確認して更新しようとします。

pkg info [L]

指定されたパッケージ情報を表示します。指定されない場合、全てのパッケージの概要を一覧表示します。

pkg info -a

他のオプションと合わせて指定した場合、全てのパッケージが対象になります。

pkg info -l

指定されたパッケージのインストールされたパス名一覧を表示します。

pkg info -D

指定されたパッケージに関する注意書きを表示します。セットアップのヒント情報などが含まれていることがあります。

pkg lock [L]

指定されたパッケージを更新されないよう、ロックします。このロックすることの影響は、パッケージ自体の変更を防止する以上に機能するようになっています。

  • ロックされたパッケージの再インストール・アップグレード・ダウングレード・削除のブロック
  • ロックされたパッケージに依存するパッケージが、ロックされたパッケージの別のバージョンに依存する場合の、当該パッケージのアップグレードまたはダウングレードのブロック
  • ロックされたパッケージが依存しているパッケージの、削除またはアップグレードまたはダウングレードのブロック
  • 上記に関して間接的に依存が共有している場合にもブロックの対象となる

pkg unlock [L]

指定したパッケージのロックを解除します。

pkg search [R]

パッケージ名を大文字小文字と問わず、正規表現で検索します。
-e オプションで厳密に指定できますが、バージョン番号の指定含めての検索になるので、あまり人間向けのオプションではありません。
-g オプションはシェルグロブ的(?* で曖昧検索する)に検索できますが、バージョン番号込みの検索となるため、事実上、最後に * が必要となります。

pkg which [L]

指定したファイル、ディレクトリ等が所属しているパッケージ名を表示します。-o オプションでオリジンを表示することができます。

滅多に使わないけど知っておいた方がいい pkg コマンド

pkg audit [RL]

インストールされたパッケージの、脆弱性情報との突合結果をレポートします。
外部から脆弱性情報を取得する必要があるためため、若干 [R] よりの機能ですが、今すぐ情報を更新したいという事情が無ければわざわざ -F オプションを指定して、脆弱性情報の取得は行わなくてもよいです。
これは通常、一日に一回脆弱性情報を取得するスクリプトが脆弱性情報を自動取得しているからです。

pkg check -s [L]

指定されたパッケージが改変されてないか一貫性を検査します。通常 -a オプションと合わせて使用することになります。

pkg check -d [L]

指定されたパッケージの依存が壊れていないか一貫性を検査します。通常 -a オプションと合わせて使用することになります。

pkg autoremove [L]

孤立したパッケージを削除します。「孤立した」というのは、何か別のパッケージの依存関係のためにインストールされ、当該パッケージが削除された、ないしは(更新等により)依存されなくなって、使われなくなった…ものとなります。

実際に「孤立した」パッケージを「使ってる」ケースがあるかもしれませんが、パッケージ依存情報からは読み取れないため、その実行には注意する必要があります。
たとえば bash を普段使用しているが、何かの依存で bash がインストールされたので、そのまま使ってるぞ…というケースは要注意となります。
明示的に bash をインストールするか、後述のテクニックで逃げる方法があります。

ports system の場合わかりやすく、「主に」ビルド時に必要なパッケージ(コンパイラ等)が削除対象となります。

pkg updating [L]

パッケージの要注意アップデート手順(手動更新の指示)を表示します。具体的には /usr/ports/UPDATING を読んで必要そうな箇所を、インストールされている(または指定された)パッケージ情報からマッチングして、表示します。
同ファイルは、人間が読む前提で、かなりヒューリスティックな作りになっているのですが、厳密性については微妙なものがあります。
また同ファイルが存在することが必要で、わざわざダウンロードしてこない点も微妙です。

pkg set [L]

指定されたパッケージのメタデータ(データベース)を変更します。通常は pkg updating 情報に基づき実行されるくらいの存在なので、主体的に操作することは無いはずです。

pkg set -A

-A オプションに対して以下の値を指定して、指定したパッケージのメタデータを変更します。この変更は pkg autoremove の結果に影響を与えます。

  • 0: 指定したパッケージを pkg autoremove の対象にしません。
  • 1: 指定したパッケージを pkg autoremove の対象にします。

この項目に興味ある人は pkg autoremove の動作原理について気になるかと思いますが、このフラグが有効でかつ、他のパッケージから依存が無いこと、といった判定になるため、単純にこのフラグだけで pkg autoremove の対象にはなりません。

また pkg install または pkg add で直接指定したものは、インストール時にこのフラグが無効になるよう設定されます。あくまで依存の都合でインストールされたパッケージに対してのみ、このフラグが有効になります。

pkg set -o

-o 旧オリジン:新オリジン という形で、旧オリジンに依存している全てのパッケージのメタデータのオリジン情報を変更します。

pkg set -n

-n 旧パッケージ名:新パッケージ名 という形で、パッケージ名の変更を行います。ただまぁパッケージ名にバージョン番号含まれるか…と言われると含まれないので、色々微妙な存在ではあります。

マニアック過ぎて知らなくても良い pkg コマンド

pkg alias [L]

/usr/local/etc/pkg.conf にて定義されるエイリアス情報を表示します。

pkg query [L]

指定されたフォーマットでパッケージのメタ情報を表示します。パッケージ名が指定されない場合、全てのパッケージが対象となります。
フォーマットで指定できる文字列は下記のものがあります。

  • %n: パッケージの名前
  • %v: パッケージのバージョン
  • %o: パッケージのオリジン
  • %p: パッケージのプレフィックス
  • %m: パッケージのメンテナー(メールアドレス)
  • %c: パッケージのコメント
  • %e: パッケージの記述
  • %w: パッケージのWebサイト
  • %l: パッケージのライセンスロジック(無し・単一・and・or)
  • %sb または %sh: パッケージのサイズ(バイト単位または人間が読みやすい単位)
  • %a: パッケージの自動インストールフラグ
  • %Q: パッケージのアーキテクチャ対応候補
  • %q: パッケージのアーキテクチャ(OS、バージョン、CPUアーキテクチャ)
  • %k: パッケージのロックフラグ
  • %M: パッケージのメッセージ
  • %t: パッケージがインストールされた時のタイムスタンプ
  • %R: パッケージのインストール元リポジトリ
  • %X: パッケージのチェックサム
  • %?C(具体的には d/r/C/F/O/D/L/U/G/B/b/A・説明は省略)として指定された状況のフラグ
  • %#C(具体的には d/r/C/F/O/D/L/U/G/B/b/A・説明は省略)として指定された内容の数
  • %dC: パッケージの依存しているパッケージのリスト、(具体的には n/o/v)により Name、Origin、Version` を取得
  • %rC: パッケージの逆に依存しているパッケージのリスト、(具体的には n/o/v)により Name、Origin、Version` を取得
  • %C: パッケージのカテゴリ一覧
  • %FC: パッケージのファイル一覧、(具体的には p/s)により Path または Sum を取得
  • %D: パッケージのディレクトリ一覧
  • %OC: パッケージのオプション一覧、(具体的には k/v/d/D)によりkey、value、default value、Descrition を取得
  • %L: パッケージのライセンス一覧
  • %U: パッケージのユーザー一覧
  • %G: パッケージのグループ一覧
  • %B: パッケージのプログラム内で使用している共有ライブラリの一覧
  • %b: パッケージの提供している共有ライブラリの一覧
  • %AC: パッケージの注釈タグの一覧、(具体的には t/v)により tag、value を取得

pkg query -e

指定されたクエリーに合致するパッケージを絞り込む。気が向いたら詳しく書く。

pkg rquery [R]

リモートメタデータに対する pkg query。こちらは特に説明しません。

pkg anotate [L]

パッケージに対して「注釈情報タグ」を追加・変更・削除するコマンドです。表示に関しては pkg info -A で確認できます。注釈タグについての意味や活用方法等は特に説明しません。

pkg shell [L]

パッケージメタデータを管理しているデータベース(=SQLite3)に直接アクセスするためのコマンドです。せいぜい pkg shell VACUUM くらいしか使い道がありません。
クエリーを活用したいなら pkg query で十分お釣りが来るレベルのツールとなります。

便利なエイリアスコマンド

自動インストールフラグ関連

以下のエイリアスは自動インストールフラグを参照し、自動インストールフラグが0であるもの=明示的に指定インストールされたものを返すコマンドです。

  • pkg prime-list [L]
  • pkg prime-origins [L]
  • pkg noauto [L]

pkg leaf [L]

リーフ(依存木の葉)に存在するパッケージを表示します。これにあって pkg noauto に無いものが pkg autoremove の対象となります。

pkg list [L]

指定したパッケージがインストールしたパス名一覧。

シンタックスシュガー

単純にどちらで実行しても良い用のエイリアス。なんなら pkg vanish みたいな中二病溢るる パワーワード 力強い単語を使用してサブコマンドを定義しても問題ありません。デフォルトで無難なものが定義されてます。

  • pkg removepkg delete

知らんわこんな pkg コマンド

ほとんど内部で使用するコマンドであったり、別のツール(別のパッケージ管理システムから FreeBSD pkg システムへの登録など)からの呼び出しで使われるようなものなので知らなくても問題無いです。

  • pkg stats: 統計情報の表示。
  • pkg clean: パッケージキャッシュの削除。
  • pkg config/usr/local/etc/pkg.conf で設定されてる内容の参照(大文字小文字区別無し)。
  • pkg create: パッケージの作成…なんだけど、ports ビルド時にはよく使うけど、単体で使うケースはあまり無い。
  • pkg fetch: パッケージの取得。pkg installpkg fetchpkg add な関係。
  • pkg register: パッケージのローカルデータベースへの登録。これ完全に内部で使ってる用としか。
  • pkg repo: パッケージリポジトリカタログの作成。この辺りは pkg-repository(5) を参考にリポジトリ作ってみるしか。
  • pkg shlib: パッケージが提供している共有ライブラリおよびそのライブラリに依存する別のパッケージの表示。これは主にセキュリティ診断用ですね。
  • pkg ssh: 完全に内部で使用する用で人間が使うためのコマンドでないので省略。
  • pkg triggers: 延期されたトリガーの実行。誰が延期したの?から含めて内部で使用しているので省略。

オリジン

オリジンとはTODO。気が向いたら書く。

よくある質問とその答え

Q.pkg コマンドはパッケージなのですか?

A.そうです。pkg コマンドはパッケージです。

Q.あれ? /usr/sbin/pkg は?

A.pkg パッケージをインストールするだけのブートストラップです。その後、pkg パッケージ(/usr/local/bin/pkg-static)を呼び出します。

Q.あれ?ベースシステムには入らないの?

A.旧パッケージシステムで散々な目にあってこういう形態になっています。pkg コマンドが進化しないと何もできませんでした(新しいバージョンがリリースされても古い機能を強要される)。

Q.pkg コマンドと pkg-static コマンドの違いは?

全く同じです。pkg-static は自分自身の削除といった微妙な操作で必要になります。通常は pkg コマンドを使ってればいいです。ある種の内部処理で実行する場合に安全のため使用されています。

Q.pkg update で取得したリポジトリ情報を削除する方法は?

A.自分も興味あるので調査中。

Q.pkg query だと上手く絞り込みできないんですよね。最後にインストールしたパッケージを…な出力をしたいケースの時どうすればいいですか?

A.pkg shell で頑張ろう。レッツSQL!というのは置いておいて、お悩みの通り pkg query には出力順序や集計機能がありません。あるいはパイプで繋いで他のツール(sortawkheadtail など)を駆使するのも手かと思います。

Q.これマジ全部覚えてるの?

A.よく使うのは憶えてる。自分も数個くらいだと思ったけど、十数個がそれなり出てきて記憶に頼って書いてるから、十分憶えるに値するかと。細かいニュアンスが微妙なものもあったけど、そこはマニュアルを精査するということで。
まぁ普段遣いしないものは記憶の彼方に置き去って問題無いです。

Q.pkg update/upgrade/updating 何かむずい。

A.残念ながら憶えておいてください。別のパッケージシステムだと updateupgrade が同じだったりしますが、残念なこt(メッセージはここで途切れています

Q.WITH_PKGNG とか pkg2ng って?

極めて古い話(10.0-RELEASE よりも前)なので、その部分の話は無視してください。歴史的価値しか無く、設定や運用での価値はゼロです。

愚痴

これくらい知ってるよねぇ…とリストアップした直後の絶望感。普段遣いとは?でもこれくらい載せておかないと…の地獄感。
更にマニュアル読んでたらバグ(pkg-query(8): duplicate %#b)を発見。 orz

参考文献

4
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
4
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?