论坛: UNIX系统 标题: 从源代码安装Linux软件 复制本贴地址    
作者: blackeyes [ilovewhere]    论坛用户   登录
    


从源代码安装Linux软件

提供者:jzj   发表日期:2002-04-25 

--------------------------------------------------------------------------------

作者: Thomas Nooning CCNA,CCDA(TechRepublic) 
Thursday, January 24 2002 5:10 PM 


安装Linux软件越来越容易了, 现在,大多数版本的Linux都支持很多类型的管理工具包,可以在很大程度上简化软件安装过程,例如RPM(RedHat软件管理工具包)。但是我们也不能低估了懂得在Linux下直接用源代码安装软件的重要性。 

使用源代码进行软件安装,可能会更复杂一些,但是用源代码安装软件至今仍然是在Linux进行软件安装的重要手段,也是运行Linux的最主要的优势之一。使用源代码安装软件,能按照用户的需要选择用户制定的安装方式进行安装,而不是仅仅依靠那些在安装包中的预配置的参数选择进行安装。另外,仍然有一些软件程序只能从源代码处进行安装。从这些原因来说,有必要懂得如何从源代码中进行软件安装。本指南将指导用户如何从源代码进行软件安装。 

获得源代码 有很多地方都提供源代码包,到底在什么地方获得,这取决于软件的特殊需要。对于那些使用比较普遍的软件,如Sendmail,可以从商业网站处下载源代码软件包(如sendmail.org),也可以从世界各地的FTP或者HTTP镜象站点进行下载。比较小的包,则可能需要从开发者的Web站点下载。 

许多源代码软件包可以有很多种下载方式,包括对RPM和DEB专门创建的包,也可以是预编译成为二进制格式的包,当然还有源代码方式。许多源代码会被压缩成为.tar格式,这是源代码包进行打包的最简单方式。这些文件通常以.tar.gz做为扩展名。 

因为程序tar本身并不做任何压缩,只进行打包,所以.tar文件还需要用gzip软件进行压缩,形成以.gz为扩展名的文件。这些文件通常使用tar xpfz命令来解压缩。大多数软件开发者会在软件安装包中包含目录结构,所以安装时没必要再进行人工创建目录。不过,可以把文件解压缩到一个空目录中进行安装,这是比较好的习惯。 

例如,假如要下载一个sendmail的源代码软件包,首先会创建一个/use/local/sendmail的目录;然后把下载来的sendmail.8.12.0.tar.gz源代码压缩文件放到该目录下,再从该目录下通过运行命令tar xpfz sendmail 8.12.0.tar.gz进行解压缩。 

有些Web浏览器,如Netscape,当遇到以.gz为文件扩展名的文件时,会自动进行文件解压缩。如果在下载来的文件只是以.tar为扩展名的文件包,那么直接就用tar xpf命令来解该文件包就可以了,因为该文件并没有压缩。 

从源代码中进行软件安装 

成功解压缩源代码文件后,接下来应该在安装前阅读readme文件和查看其它安装文件。尽管许多源代码文件包都使用基本相同的命令,但是有时在阅读这些文件时就能发现一些重要的区别。例如,有些软件包含一个可以做完安装的安装脚本程序。在正式安装之前阅读这些说明文件,通常会为安装节约大量的时间。 

通常的安装方法是从安装包的目录执行以下命令: 
/configure 
make 
make install 

配置脚本程序将对系统进行检测,确定要安装的组件,并且完成诸如编译器的兼容性和所需要的库的完整性检测。如果发现有任何遗漏,安装程序就会输出一个错误信息,并且创建一个config.cache文件来保存这个失败的安装信息。如果想继续进行安装,重新运行配置脚本,就需要使用命令rm删除config.cache文件,这样,就可能保证配置脚本能再次进行所有的安装检测。 


这儿列出了一个脚本执行的快照: 
# ./configure 
creating cache ./config.cache 
checking for gcc... gcc 
checking whether the C compiler (gcc ) works... yes 
checking whether the C compiler (gcc ) is a cross-compiler... no 
checking whether we are using GNU C... yes 
checking whether gcc accepts -g... yes 
checking for a BSD compatible install... /usr/bin/install -c 
checking for socket in -lsocket... no 
checking for strlcpy... no 
checking for strlcat... no 
checking for arc4random... no 
checking for MD5Update... no 
checking for warnx... yes 
checking for libpcap... yes 
checking for ANSI C header files... yes 
checking for sys/ioctl.h... yes 
checking for sys/time.h... yes 
updating cache ./config.cache 
creating ./config.status 
creating Makefile 
creating config.h 

注意:并不是所有的选项都选择“是”;脚本将会提示是否有丢失的要求项。 

第二个命令是make,完成把源代码编译成为可执行的二进制代码,用来进行系统安装。这一步可能要花费大量的时间,这主要是看要编译的代码大小和系统的速度了。 这个命令阶段,是最有可能出现问题的阶段。尽管开发者在努力开发尽可能广泛使用的源代码,但仍然会有很多Linux变种版本不能得到支持。如果有问题出现在库文件上,那么看看你是否有完整的Linux开发版。这就是为什么使用源代码安装软件的灵活处,也是我们提供这篇指南的原因。使用源代码可以查出错误发生的地方,可以查找较旧的库文件。 

如果在安装时出现了问题,可以去访问开发者站点以及提供你的Linux版本站点,通常这些站点都会帮助查找安装时所需要的文件。还有,要多使用搜索站点,比如Google和Yahoo这些搜索引擎进行搜索,因为你碰到的问题可能别人早已经碰到过,解决问题的方法可能就在互联网上的什么地方放着呢。 

接下来的make install命令将把源代码的编译结果,安装到你的系统,这些结果通常是二进制代码或库文件。主要方法是拷贝这些文件到合适的目录下,成为系统文件。这些步骤通常可以在配置阶段完成。如果不能确定该命令运行完成之后文件都存到什么地方了,可以查看readme和安装文件,看安装程序默认安装在什么目录下了。 

也可以查看配置脚本创建的makefile文件,看有什么变量存贮在该文件中。标准目录通常是/usr/local/bin,/usr/local/sbin和/usr/local/lib,不过也有可能有变化,需要的话做可以进一步的研究。 

要完成最后一个命令,必须拥有根权限,否则就不能把文件拷贝到指定的目录。一种方法是以根权限运行所有的命令,这时为了安全,应该检查脚本的安全性,因为以根权限运行脚本的任何命令,都相当于在根权限下运行每个命令行。虽然这不是太大的问题,尤其是从比较有名的站点下载时,安全问题都会得到保证,但最好还是在脑中绷紧这根弦,防人之心不可无。 

小结 

下载源代码,并从源代码中进行程序的安装,这是Linux最大的优势。即使不是编程人员,也可以控制那些要安装的源代码选项,编译到新生成的软件中。一些程序包可能除了使用源代码安装外,别无其它选择;而且预编译程序并没有把全部参数都开放。这些要求的结果就是:从源代码进行软件安装,是系统管理员必备的技巧之一。 

(翻译:智德;责任编辑:王岳) 
 
  


地主 发表时间: 08/02 01:16

论坛: UNIX系统

20CN网络安全小组版权所有
Copyright © 2000-2010 20CN Security Group. All Rights Reserved.
论坛程序编写:NetDemon

粤ICP备05087286号