問題:如果你要在Debian系統(tǒng)中發(fā)布一款軟件或者一個包,該如何做呢?如果你的項目中有各種二進制包,該如何維護呢?如果你自己做了一款小小的實用軟件,該如何與朋友分享呢?…….
案例:假如我從網(wǎng)上下載了eclipse-SDK-3.1-linux-gtk.tar.gz壓縮文件,我想把他安裝到/opt/eclipse目錄下,且菜單Apps-->Programming中有Eclipse菜單項。并且在命令終端中輸入eclipse中可以運行Eclipse程序,而且還要象其他的軟件包一樣,可以方便的進行安裝(install )和卸載(remove)。
如果你還不知道如何做,請跟我來,我將告訴你解決方案。
熟悉Debian(Linux的發(fā)行版之一)的用戶,應(yīng)該對他的包管理機制記憶猶新。便捷的包管理機制是Debian易用的一個主要特性。Debian包管理機制可分為兩個層面:對軟件包文件操作以及對包中文件的操作。apt和dselect完成前者,dpkg完成后者。
接下來,我們將借助Debian的包管理機制,打造屬于自己的deb包。
首先,介紹其目錄結(jié)構(gòu)(為了便于理解,借用Windows下的截圖)
eclipse
|----DEBIAN
|-------control
|-------md5sums
|-------postinst
|-------postrm
|----usr
|-----bin
|------eclipse
|-----lib
|-------menus
|-----eclipse
圖一 目錄結(jié)構(gòu)
其中,eclipse文件夾表示待發(fā)布的軟件,也是我們的工作目錄。 DEBIAN文件夾下包含control和md5sums等文本文件。opt目錄表示待發(fā)布的包將要安裝(放置)的地方。usr/bin/目錄提供了運行該程序命令的腳本。usr/lib/menu目錄提供了將Eclipse加入菜單的腳本。
DEBIAN必須大寫,且必須為該名。根據(jù)不同的情況,該目錄將包含不同的文件,其中control和md5sums文件是最小(基本)要求。如果待發(fā)布包在安裝和卸載,需要運行某些命令或腳本進行初始化和配置時,則會包含下列文件:
preinst
在Debian包文件解包之前,將會運行該腳本。許多“preinst”腳本的任務(wù)是停止作用于待升級軟件包的服務(wù),直到軟件包安裝或升級完成。
postinst
該腳本的主要任務(wù)是完成安裝包時的配置工作。通常,“postinst”腳本等待用戶輸入,或提醒用戶,如果他接受當(dāng)前默認(rèn)值,要記得軟件包安裝完后返回重新配置。許多“postinst”腳本負(fù)責(zé)執(zhí)行有關(guān)命令為新安裝或升級的軟件重啟服務(wù)。
prerm
該腳本負(fù)責(zé)停止與軟件包相關(guān)聯(lián)的daemon服務(wù)。它在刪除軟件包關(guān)聯(lián)文件之前執(zhí)行。
postrm
該腳本負(fù)責(zé)修改軟件包鏈接或文件關(guān)聯(lián),或刪除由它創(chuàng)建的文件
因為本案例需要將Eclipse加入到菜單中,所以應(yīng)該包含postinst and postrm這兩個文件。
control文件內(nèi)容如下:
Package: eclipse
Version: 3.1
Section: utils
Priority: optional
Architecture: i386
Depends: libc6 (>= 2.3.2.ds1-4),jdk
Installed-Size: 14062
Maintainer: xxxxxx<xxx@xxxxxx.xxx>
Description:Develop tools
md5sums是基于md5sum命令生成的文件。
因為在安裝本包時,只需要更新菜單項,所以postinst腳本只需要包含update-menus命令,卸載時也是同樣的操作。其postinst腳本內(nèi)容為:
程序清單一
#!/bin/sh
# filename :postinst/postrm
if test -x /usr/bin/update-menus; then
update-menus
fi
postrm腳本內(nèi)容跟postinst內(nèi)容相同。如果你還要做其他的操作,則可以在這兩個文件中加入其他內(nèi)容。
/opt/eclipse/目錄就是待發(fā)布(安裝)的軟件目錄。對于本例只需要在/opt目錄下執(zhí)行該操作:$ tar xzvf eclipse-SDK-3.1-linux-gtk.tar.gz.
要在命令終端中輸入eclipse,也能運行Eclipse。通常有三種解決方案:
1) 把/opt/eclipse/加入到PATH變量中。
2) 在/usr/bin目錄建立一個指向/opt/eclipse/eclipse的鏈接
3) 在/usr/bin目錄下新建一個腳本,在腳本中運行該程序
綜合考慮,第一種方案不可行。第二種方案比較好,但失敗了。因為eclipse在運行時,需要starup.jar文件,并且是相對路徑下的starup.jar文件,當(dāng)你在其他任何路徑下運行eclipse時,都將會失敗。只有采用第三種方案,建立一個腳本。只需要在該腳本中寫入:exec /opt/eclipse/eclipse。
程序清單二:
#!/bin/sh
# filename :eclipse
exec /opt/eclipse/eclipse
接下來,解決最后一個問題,如何把eclipse加入到Apps-->Programming的菜單中去?基本上每一個Debian系統(tǒng)的應(yīng)用程序都會有一個菜單配置文件,用以定義該程序的菜單項名稱、位置和命令行選項等參數(shù)。該配置文件一般位于/usr/lib/menus、/etc/menu或~/.menu目錄下。
我們新建一個文件eclipse ,程序安裝后,將置于/usr/lib/menu/路徑下
該eclipse配置文件格式示例如下:
?package(eclipse): #定義軟件包名
needs="X11" #定義該菜單項需在X11環(huán)境中使用
section="Apps/Programming" #定義菜單項的路徑位置
title="Eclipse" #定義菜單項的標(biāo)題
command="/usr/bin/eclipse" #定義命令和選項
hints="Eclipse" #定義一些提示信息
icon="/opt/eclipse/icon.xpm" #定義菜單項的圖標(biāo)
目錄結(jié)構(gòu)框架介紹完畢后,就開始打地基,準(zhǔn)備文件吧,需要準(zhǔn)備的文件有:
1) control(必須要)
2) eclipse.sh(用于終端,因為與菜單的eclispe重名,所有加了.sh后綴)
3) eclipse.menu (用于菜單)
4) eclipse-SDK-3.1-linux-gtk.tar.gz (下載的eclipse包)
5) postinst (用于安裝和卸載時調(diào)用的腳本)
將上述所有文件放置一目錄中,并在該目錄下新建mkeclipse腳本,主要用于完成上面的工作,其內(nèi)容如下:
#!/bin/sh
ROOT=$PWD
ECLIPSE=$ROOT/eclipse-SDK-3.1-linux-gtk.tar.gz
CONTROL=$ROOT/control
POST=$ROOT/postinst
BINECP=$ROOT/eclipse.sh
MENUS=$ROOT/eclipse.menu
if [ -w "$ROOT" ];then
mkdir eclipse
cd eclipse
mkdir DEBIAN opt usr usr/bin usr/lib usr/lib/menu
cd opt
if [ -e "$ECLIPSE" ];then
tar xzvf $ECLIPSE
fi
cd ..
if [ -e "$CONTROL" ];then
cp $CONTROL DEBIAN/
fi
if [ -e "$POST" ];then
cp $POST DEBIAN/postrm
fi
if [ -e "$BINECP" ];then
cp $BINECP usr/bin/eclipse
fi
if [ -e "$MENUS" ];then
cp $MENUS usr/lib/menu/eclipse
fi
rm -f DEBIAN/md5sums
find opt usr -type f -exec md5sum {} ;>>DEBIAN/md5sums
fi
現(xiàn)在已經(jīng)萬事俱備,只欠東風(fēng)。那現(xiàn)在就草船借東風(fēng)──借Debian的dpkg包這股東風(fēng),來成就我們的事業(yè)吧。
制作deb包,在當(dāng)前ROOT目錄運行如下命令:$dpkg -b eclipse eclipse_3.1_i386.deb
也可以在mkeclipse腳本的最后一個fi前加入
cd $ROOT
dpkg -b eclipse eclipse_3.1_i386.deb
來完成該功能。
好,現(xiàn)在就開始我們的心動之旅吧。
首先安裝deb包:dpkg -i eclipse_3.1_i386.deb 下面打印的消息是不是非常熟悉。
進入圖形界面,發(fā)現(xiàn)Apps-->Programming中已經(jīng)有了Eclipse菜單項,請鼓足勇氣單擊一下吧,Eclipse IDE已經(jīng)躍然出現(xiàn)在你的桌面上(當(dāng)然你的jdk環(huán)境已經(jīng)配置好了)。
接下來,試著卸載一下:apt-get remove eclipse。Eclipse已經(jīng)從菜單中消失了,/opt/eclipse目錄也已經(jīng)不復(fù)存在。
現(xiàn)在覺得是不是很方便?當(dāng)你看完本文的時候,你是否對文章開始提出的問題已經(jīng)豁然開朗。其實這樣做的目的就是簡化勞動,同一個項目組的人在做重復(fù)的工作,比如安裝eclipse,要在/usr/bin下建立文件,又要在/usr/lib/menu中建立文件,還要拷貝一些eclipse文件,不知道在拷貝的過程中是否會遺漏一些文件等等。或者你的系統(tǒng)出于某種原因要重裝,以前的工作又的重新來一遍,很費時。如果你做成了一個deb包,以上的問題和疑慮就迎刃而解。
參考文獻:
1. Debian manual refrence
2. http://www.nl.debian.org/doc/packaging-manuals/menu.html/index.html
作者:normalnotebook