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