Dpkg

在沒有 root 權限的情況下使用“dpkg”將軟體包安裝到備用位置失敗並出現權限錯誤

  • March 1, 2016

我正在使用的命令行是

dpkg --force-not-root --root  /some/other/location -i the_package.deb

但我得到一個錯誤

dpkg: could not open log '/var/log/dpkg.log': Permission denied

我本來希望日誌被寫入

/some/other/location/var/log/dpkg.log

使用 rpm 你可以生成一個備用數據庫,但我不知道如何使用 dpkg 來做到這一點。為了達到上述狀態,我手動添加(也許不是最明智的方法)以下內容。

mkdir -p /some/other/location/var/lib/dpkg/updates
mkdir -p /some/other/location/var/lib/dpkg/triggers
mkdir -p /some/other/location/var/lib/dpkg/info
touch /some/other/location/var/lib/dpkg/status
touch /some/other/location/var/lib/dpkg/available

如果我嘗試以 root 身份執行,在這種情況下我不希望這樣做

sudo dpkg --force-not-root --root  /some/other/location -i the_package.deb

它走得更遠並將deb安裝在我的備用位置,但隨後失敗

dpkg (subprocess): unable to execute installed post-installation script (/var/lib/dpkg/info/the_package.postinst): No such file or directory

但是這個文件已經由上面的 dpkg 命令寫入

/some/other/location/var/lib/dpkg/info/the_package.postinst

我不使用機器 dpkg 數據庫的原因是,這是一個安裝到網路驅動器上的應用程序軟體,可供許多使用者使用。也許只是提取包的內容並手動安裝是最好的方法。特定軟體包沒有列出任何外部依賴項。

Debian ‘dpkg’ 包管理程序版本 1.18.2 (amd64)

用於--log=filename更改您的登錄位置。

如果您正在使用,則--root=/foo需要設置/foo為有效的根。例如,sudo chroot /foo /bin/sh工作。

“沒有這樣的文件或目錄”表示the_package.postinst腳本需要不在 chroot 中的東西(很可能/bin/sh還有一大堆其他東西)。這是從 chroot 內部執行的,因此您/foo在路徑中看不到。

您可以使用它--no-triggers來阻止觸發器執行。但是,您現在應該看到這正在成為一種黑客行為。dpkg嚴重傾向於認為您想在安裝它的機器上執行該軟體包,並且根文件系統位於/.

"

$$ J $$只需提取軟體包的內容並手動安裝它會是一種更好的方法。” 是的 - 看起來您正在將它安裝在不打算執行它的文件伺服器上。 編輯:雖然這嚴格解決了您的問題,但分發軟體的“現代”方法是使用編排軟體(例如,廚師)直接在客戶端上安裝軟體包,而不是通過文件伺服器共享軟體。磁碟很便宜。

引用自:https://serverfault.com/questions/760605