无忧启动论坛

 找回密码
 注册
搜索
系统gho:最纯净好用系统下载站投放广告、加入VIP会员,请联系 微信:wuyouceo
查看: 4569|回复: 11
打印 上一主题 下一主题

老生常谈(linux下源码安装软件)

  [复制链接]
跳转到指定楼层
1#
发表于 2011-1-7 10:24:53 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
http://www.linuxdiyf.com/bbs/vie ... 1890&highlight=


      在linux下的很多软件都是通过源码包方式发布的,这样做对于最终用户而言,虽然相对于二进制软件包,配置和编译起来繁琐点,但是它的可移植性却好得多,针对不同的体系结构,软件开发者往往仅需发布同一份源码包,不同的最终用户经过编译就可以正确运行,这也是非常符合c语言的设计哲学的,一次编写,到处编译么,而常见的二进制包,比如rpm和deb,软件开发者必须为每种特定的平台定制好专门的软件包,这个通过rpm文件的后缀名就可以初见端倪,比如ppc,sparc,i386之类,在这里不做过多的陈述,其实源码安装软件远没有很多朋友想象的那么复杂,下面我在这里尽可能详细的做一些陈述,如有谬误,欢迎朋友们拍砖!

安装的具体步骤:
$ tar zxvf XXXX.tar.gz (or tar jxvf XXXX.tar.bz2)
$ cd XXXX
$ ./configure
$ make
# make install

$ make clean       //安装完成后用来清理临时文件


# make uninstall        //用来卸载软件

解压:
        最常见源码包的就两种(XXXX.tar.gz or XXXX.tar.bz2),其实这些源码包都是由2个工具压缩而成的,tar.gz结尾的文件用到的工具是tar和gunzip,而tar.bz2结尾的文件所使用的工具是tar和bzip2,之所以这样做是因为,tar仅仅能够打包多个文件但是没有压缩的功能,而gz和bz2却刚好相反,仅能够压缩单个文件,这样我们常见的源码包实际上是通过tar先将不同的源文件打包,然后再通过gunzip或者bzip2压缩后发布的,当然这两个步骤可以通过一条命令实现:
$ tar zcvf XXXX.tar.gz XXXX(or tar jcvf XXXX.tar.bz2 XXXX)
复制代码
解压的相关命令如下:
$ tar zxvf XXXX.tar.gz
$ tar jxvf XXXX.tar.bz2


./configure:
        解压完成就正式开始安装了(补充一点,开始configure之前,如有必要,请使用patch工具为源码打上相应的补丁),首先跳转到源码的解压目录,众所周知,开始configure前还是应该仔细阅读源码目录下的README或者INSTALL文件,好多安装中的注意事项在这里都有所罗列,configure实际上是一个脚本文件,在当前目录中键入"./configure",shell就会运行当前目录下的configure脚本,有一点必须说明,在整个configure过程,其实编译尚未进行,configure仅仅是做编译相关的准备工作,它主要对您当前的工作平台做一些依赖性检查,比如编译器是否安装,连接器是否存在,如果在检测的过程没有任何错误,你很幸运,configure脚本会在当前目录下生成下一步编译链接所要用到的另一个文件Makefile,当然configure支持及其丰富的命令行参数,可以键入"./configre --help"获取具体的信息,最常用的恐怕就是:
$ ./configure --prefix=/opt/XXX        //它用来设置软件的安装目录.

make:
        如果configure过程正确完成,那么在源码目录,会生成相应的Makefile文件,Makefile文件简单来说包括的是一组文件依赖关系以及编译链接的相关步骤,事实上真正的编译链接工作也不是make所做的,make只是一个通用的工具,一般情况下,make会根据Makefile中的规则调用合适的编译器编译所有与当前软件相依赖的源码,生成所有相关的目标文件,最后再使用链接器生成最终的可执行程序:
$ make


make install:
        当上面两个步骤正确完成,代表着编译链接过程已经完全结束,最后要做的就是将可执行程序安装到正确的位置,在这个步骤,普通用户可能没有相关目录的操作权限,临时切换到root是一个不错的选择,"install"只是Makefile文件中的一个标号,"make install"代表着make工具执行Makefile文件中"install"标号下的所有相关操作,如果在configure阶段没有使用"--prefix=/opt/XXX"指定应用程序的安装目录,那么应用程序一般会被默认安装到/usr/local/bin,如果/usr/local/bin已经存在于您的PATH中,那么安装已经基本结束:
#make install


make clean:
make uninstall:
        这两个步骤只是安装的后续操作,有一点必须注意,"clean"和"uninstall"也是Makefile文件中相应的两个标号,执行这两个步骤的时候Makefile文件必要保留,"make clean"用来清除编译连接过程中的一些临时文件,"make uninstall"是卸载相关应用程序,与make install类似,make uninstall也需要切换到root执行,不过"uninstall"标号在好多Makefile中都被省略掉了,朋友们完全可以自己在相应的Makefile文件一探究竟.

Why?
        在这里我尝试着解释一下上面这些步骤存在的理由,从C语言的角度来说,一个程序从源码到正确生成相关的可执行文件,下面这些部分必不可少:源文件,编译器,汇编器,连接器,依赖库,通过上面几个步骤,朋友们应该已经知道,真正执行编译链接操作的步骤只有一个(make),那其他步骤存在的理由何在?
        有一点是肯定的,我在自己的电脑上使用C语言写一些自娱自乐的小程序,也没有用到"configure or make install"之类的命令,顶多自己写个Makefile管理源文件的依赖关系,可是软件开发者不同,他必须考虑到软件的可移植性,他开发的软件不能仅仅就在他自己的pc上跑吧?不同的平台可能连硬件体系结构都不同,这样就导致了Makefile的不可移植性,为了解决这个问题,开发者通常使用autoconf之类的工具生成相应的configure脚本,而configure脚本就是用来屏蔽相应的平台差异,从而正确生成Makefile文件,然后make再根据configure的劳动成果(Makefile)完成编译链接工作.        
        至于"install or clean or uninstall",也只是对应着Makefile文件中不同的规则,关于Makefile的详细信息,朋友们可以自行查阅相关的文档.

一个例子
        下面是我在自己的pc机上源码安装tar工具的过程,权当做是上面这些步骤的一个具体事例吧:

                [root@localhost ~]#是命令提示符,相当于win中的d:\>,这个可以自行设置;
                //后边是注释


[root@localhost ~]# head -n 1 /etc/issue   // etc/issue是文本文件,发行版的名称
CentOS release 5.4 (Final)

[root@localhost ~]# uname -sr                //显示内核版本
Linux 2.6.18-164.el5

[root@localhost ~]# gcc --version               //查看gcc版本
gcc (GCC) 4.1.2 20080704 (Red Hat 4.1.2-46)
Copyright (C) 2006 Free Software Foundation, Inc.

这个是我的系统信息。
[root@localhost tools]# pwd                        //显示当前所在目录
/root/tools
[root@localhost tools]# ls                             //显示当前目录中的文件,相当于dos中的dir
tar-1.23.tar.bz2
[root@localhost tools]# tar jxvf tar-1.23.tar.bz2       //解压文件
......

[root@localhost tools]# ls                                //显示当前目录中的文件
tar-1.23  tar-1.23.tar.bz2              

[root@localhost tools]# cd tar-1.23                 //进入tar-1.23目录

[root@localhost tar-1.23]# ls           
ABOUT-NLS     build-aux   configure     gnu      Makefile.am  po       src
acinclude.m4  ChangeLog    configure.ac  INSTALL  Makefile.in  README   tests
aclocal.m4    ChangeLog.1  COPYING       lib      Make.rules   rmt      THANKS
AUTHORS       config.h.in  doc           m4       NEWS         scripts  TODO

                                                                 //解压原文件包,可以发现其中包括了configure脚本和README文件。
[root@localhost tar-1.23]# mkdir -v ~/tar          //在自己的主目录建立tar文件夹
mkdir: 已创建目录 “/root/tar”

[root@localhost tar-1.23]# ./configure --prefix=/root/tar       //运行当前目录的.configure脚本
......(省略)

[root@localhost tar-1.23]# echo $?
0                                                                   //建立软件安装目录,并configure,检查configure返回结果,为0代表运行成功.
[root@localhost tar-1.23]# ls -F                         //显示当前目录中的文件(夹)后边有/的是文件夹,*的是可运行文件。
ABOUT-NLS     ChangeLog.1     configure.ac  m4/          po/       tests/
acinclude.m4  config.h        COPYING       Makefile    README    THANKS
aclocal.m4    config.h.in     doc/          Makefile.am  rmt/      TODO
AUTHORS       config.log      gnu/          Makefile.in  scripts/
build-aux/    config.status*  INSTALL       Make.rules   src/
ChangeLog     configure*      lib/          NEWS         stamp-h1
                                                                      //可以看到Makefile文件已经被成功建立.
[root@localhost tar-1.23]# less Makefile | grep install:
           || { echo "ERROR: files left after uninstall:" ; \
install: install-recursive
uninstall: uninstall-recursive                                 //在建立的Makefile中存在install和uninstall标号

[root@localhost tar-1.23]#make
......

[root@localhost tar-1.23]#echo &?
0                                                                   //make成功

[root@localhost tar-1.23]#make install
......

[root@localhost tar-1.23]# ls /root/tar
bin  libexec  sbin  share

[root@localhost tar]# cd /root/tar/bin

[root@localhost bin]# ls
tar

[root@localhost bin]# ./tar --help
......

[root@localhost tar-1.23]#echo &?
0                                                                //安装并简单测试成功

再啰嗦2句:
1.确切的明白自己想要做什么以及正在做什么.
2.开源界名言"RTFM"!!

评分

参与人数 1无忧币 +5 收起 理由
2013sorajio + 5

查看全部评分

2#
发表于 2011-1-9 18:53:35 | 只看该作者
嘿嘿,沙发~~~写的很详细
回复

使用道具 举报

3#
发表于 2011-1-9 22:51:01 | 只看该作者
不错,谢谢。
学习下。
回复

使用道具 举报

4#
发表于 2011-1-11 16:57:57 | 只看该作者
提示: 作者被禁止或删除 内容自动屏蔽
回复

使用道具 举报

5#
发表于 2011-1-18 23:21:34 | 只看该作者
好东西,这样我就不怕使用不了一些我想用的软件了

点评

呵呵 你 把LINUX下装软件看的太简单了! 你能自己解决所有依赖关系?  详情 回复 发表于 2014-11-3 19:30
回复

使用道具 举报

6#
发表于 2013-4-25 15:57:13 | 只看该作者
好东西 学习一下
回复

使用道具 举报

7#
发表于 2014-11-3 19:28:22 | 只看该作者
你用的是CentOS ?
回复

使用道具 举报

8#
发表于 2014-11-3 19:30:15 | 只看该作者
nil13 发表于 2011-1-18 23:21
好东西,这样我就不怕使用不了一些我想用的软件了

呵呵 你 把LINUX下装软件看的太简单了!
你能自己解决所有依赖关系?
回复

使用道具 举报

9#
发表于 2014-11-30 19:08:50 来自手机 | 只看该作者
我想在
回复

使用道具 举报

10#
发表于 2014-11-30 19:11:03 来自手机 | 只看该作者
我想在 slitaz 中 安装 Teamiewer 需要如何解决依赖关系
回复

使用道具 举报

11#
发表于 2015-1-6 16:40:50 | 只看该作者
如果有一天能linux能统一里面的库那么这种源码安装方式将变得非常有效。打个比方,一个mplayer的编译需要很多库的支持,但是这些库系统默认是不会自带的,所以你选择的方式就两种:1. 等编译器报错看看是少了什么,再一个个安装上去,有些库很老,你从官方的安装源里面根本找不到,而且最麻烦的就是你下载回来的源代码所依赖的库和你正在安装的库之间版本的兼容问题,比如mplayer 依赖libv3版本,网上只有libv4,郁闷的是v3和v4之间的关于某个函数的申明和实现稍微做了修改,这将是噩梦。。2. 先看官方文档,把需要的文件先全部安装好,再编译。 总之linux的毛病就在这: 库之间的依赖关系没有统一,所以也就造就了很多人编译报错,折腾了半天又是看源代码又是修改的,最后都放弃,选择了deb或者rpm。
回复

使用道具 举报

12#
发表于 2015-10-15 15:20:36 | 只看该作者
又学习了!
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|Archiver|捐助支持|无忧启动 ( 闽ICP备05002490号-1 )

闽公网安备 35020302032614号

GMT+8, 2025-12-11 00:34

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表