首页 > 学院 > 开发设计 > 正文

在 Linux 下建立软体套件

2019-11-17 05:29:07
字体:
来源:转载
供稿:网友

  作者:Mendel Leo Cooper
http://personal.riverusers.com/~thegrendel/

译者:J.S.Lin

这是份广泛指引文件,可用来建立"一般性" UNIX 软体发行套件在 linux 下.

1. 简介

很多软体套件提供给各式 UNIX, 包括 Linux, 是将原始码档案压缩成档

案(archives)而发行的. 相同的套件可以建立以便在不同对象的机器上执行, 并

且这可节省些软体成品而免於必须制造各种发行版本. 软体套件的单一发行版本

结果能执行在各式实体(incarnations), 像是在 Intel 机器, DEC Alpha, RISC

工作站, 甚至是电算主机. 但不幸的是, 这将"建立"软体的工作推给了最终使用

者(end user), 实际上是"系统治理者", 即坐在键盘前的同志...你. 虽然这样,

认真来说这过程并不是像它看起来那麽可怕或不可思议, 就像这指引所解说一

样.

 

2. 从取得开始

你有下载或其它方式取得一个软体套件. 最常见情况是它被打包起来 (tarred)

而且被压缩 (gzipped), 成为 .tar.gz 或 .tgz 形式. 首先将它复制到一工作目

录. 然後用 untar 和 gunzip 处理它. 处理它最适合的命令是 tar xzvf

filename, 这□的 filename 当然是软体档名. 这种解开程序经常会安装适当档

案在它所开启的子目录中. 注重的是假如套件名称有 .Z 结尾, 那将要使用

uncomPRess PACKAGENAME, 然後再用 tar xvf PACKAGENAME 而不要用之前的步

骤.

 

有时打包起来的档案必须 untarred 且安装自使用者的家目录(home

Directory), 或者也许是在某个其它目录, 像是套件设定资料所指定的. 假若你

设法要 untar 它而得到的是错误讯息, 也许就是那原因. 读一下套件文件, 非凡

是 README 和/或 Install 档案, 假如存在, 编辑设定档案和/或 Makefiles 如

所需要的, 即与安装指示符合. 注重的是通常 不 去更改 Imake 档案, 因为这可

能有未预期的结果. 某些软体套件答应自动安装程序,它是藉由执行 make

install 来放置二元码在适当系统位置.

 

偶而, 你可能需要使用 patch档案,该档案有列出原本的与新的原始档案的差异,

来升级或加入臭□(bug)的修正至未打包(unarchived)的原始档案. doc档案与/或

README 档案会告知你这算不算该情况. 对於使用 Larry Wall 的强力 修

补(patch) 工具之正常的语法(syntax)是 patch < patchfile.

 

你现在可以开始进行 建立 过程阶段了.

 

3. 使用 Make

Makefile 是建立过程的重点. 在它的最简单的形式, Makefile 就是个 script

,它是用来编译或建立"二元码",套件的可执行部分. Makefile也可以提供软体套

件升级的工具,而不需要重新编译每一个在套件中的原始档案, 但其有不同的情

况(或是不同的约定).

 

某些特点是, Makefile 开启 cc 或 gcc. 这实际上是个前处理器, C (or C++)

编译器, 和 连结器, 按照那个顺序. 这过程转换原始码(source)为可真正去执行

的二元码(binaries).

 

下指令 make 通常只要键入 make. 这通常建立讨论中的套件所有需要的可执行

档. 然而, make 也做其他工作,像是安装档案至合适的目录 (make install) 而

且删除旧的 object 档案 (make clean). 执行 make -n 答应预览建立过程, 就


是列出所有 make 所唤起的(triggered)所有命令, 但没有真的去执行它们.

 

只有在最简单的软体使用一般性的 Makefile. 较复杂的安装需要根据函式

库(libraries), include 档案以及你个别机器资源所在目录来量身定制. 这非凡

是当需要 X11 libraries 来安装建立时. Imake 和 xmkmf 可完成这样的工作.

 

引用自 man page,Imakefile 是个"模板(template)"的 Makefile. imake 工具参

考 Imakefile 根据你的系统造出合适的 Makefile. 然而,几乎在所有的情况下,

你要执行 xmkmf, 它是要下 imake 指令用的 shell script, 也就是个前端介

面(front end). 察阅一下内附在软体档案间的 README 或 INSTALL 档案以取得

非凡的指示. 至於更具体的步骤分析,请阅读 imake 和 xmkmf 的 man pages.

 

要知道的是 xmkmf 和 make 可能需要以 root 身分来下指令, 非凡是当 make

install 来搬移二元码到 /usr/bin 或 /usr/local/bin 目录. 以一般使用者的

身分而不具 root 权力 来使用 make 将可能会导致 write access denied 的错

误讯息, 因为你缺少写入(write)至系统目录的权限. 也检查一下, 所造出来的二

元码对你与任何其他适用的使用者有适合的执行(execute)权限.

 

下指令 xmkmf 来使用 Imake 档案, 建立一个新的而且适合你系统的 Makefile.

正常地下指令 xmkmf 都会附加 -a 引数, 因而自动地做 make Makefiles, make

includes, 和 make depend 的动作. 这会设定变数(variables)和给定函式

库(library) 位置给编译器和连结器. 有时会没有 Imake 档案, 引而代之的是有

INSTALL 和 configure 的 script, 也会到这样的目的. 注重的是假如你要执行

configure, 那要下指令 ./configure 以确保在目前目录下正确的 script

configure 是被呼叫. 在大部分的情况, 在发行套件中的 README 档案会说明安

装步骤.

 

通常一个好的方法是从外观检视一下 Makefile 是 xmkmf 或 其中一个安装的

scripts 所造出来的. Makefile 正常下会为你的系统而修正, 但你偶而可能需

要"旋扭(tweak)"或手动地修正错误.

 

你的一般安装步骤将会是:

* 读一下 README 档案和其它合用的文件.

* 执行 xmkmf -a, 还是 INSTALL 或 configure script.

* 检查一下 Makefile.

* 假如需要, 执行一下 make clean, make Makefiles, make includes, and

make depend.

* 执行 make.

* 检查一下权限.

* 假如需要, 执行一下 make install.

 

4. 克服困难

假如用 xmkmf 和/或 make 很成功没有错误, 你可以著手於 [4]next section.

然而, 在真实生活, 很少事情在第一次就正确的工作. 这就是当你的机智丰富

时,要勇於尝试.

 

4.1 连结错误

* 假如 make 失败而出现有 Link error: -lX11: No sUCh file or

directory, 甚至是在使用 xmkmf 後. 这可能意味著 Imake 档案没有适当地

装好. 检查 Makefile 的第一部分有没有像这样的几行:

 

LIB= -L/usr/X11/lib


INCLUDE= -I/usr/X11/include/X11

LIBS= -lX11 -lc -lm

-L 和 -I 切换器(switches)会通告编译器和连结器分别去哪□寻找

library 和 include 档案. 在这例子, X11 libraries 应该是在

/usr/X11/lib 目录, 而 X11 include 档案 应该是在

/usr/X11/include/X11目录. 假如这在你的机器上是不对的, 必须改变

Makefile 而且再试试 make.

 

* 在非常少的情况, 以 root 身分跑一下 ldconfig 也许是个答案: #

/etc/ldconfig -n /lib 将会更新共享式函式库符号连结 (shared library

symbolic links). 这在正常的情形下不是需要的.

 

* 目前另一件事是假如 xmkmf 失败, 则试试下列 script:

 

make -DUseInstalled -I/usr/X386/lib/X11/config

* 有时原始码需要使用旧版的 X11R5 libraries 来建立. 假如你有 R5 libs

在 /usr/X11R6/lib (当你首先在安装 Linux 时, 你是有选择是否安装它们

的), 然後你只需要确定,你有连结到软体所需要建立的地方. R5 libs 是有

libX11.so.3.1.0, libXaw.so.3.1.0, 和 libXt.so.3.1.0. 一般你需要连结

至, 像是 libX11.so.3 -> libX11.so.3.1.0. 大概软体也需要这个形式连结

libX11.so -> libX11.so.3.1.0. 当然, 要将这"断掉(missing)"的连结建

好, 要以 root 身分使用这

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表