Dpkg
在沒有 root 權限的情況下使用“dpkg”將軟體包安裝到備用位置失敗並出現權限錯誤
我正在使用的命令行是
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 $$只需提取軟體包的內容並手動安裝它會是一種更好的方法。” 是的 - 看起來您正在將它安裝在不打算執行它的文件伺服器上。 編輯:雖然這嚴格解決了您的問題,但分發軟體的“現代”方法是使用編排軟體(例如,廚師)直接在客戶端上安裝軟體包,而不是通過文件伺服器共享軟體。磁碟很便宜。