Linux手动编译源代码文件

一、简介

    Linux系统上程序包安装的方式多种多样,一般来说可通过rpm包安装、yum在线安装等方式实现。但有时候为了实现某种功能,而这种功能在通常情况下又不是太常用或是因为其他原因,不能通过yum下载安装或在网上没有找到rpm包,只是找到了程序安装包的源代码的话,这种情况下我们就可以对源代码直接进行编译安装,以便解决这种临时需求。当然这只是其中一种情况,而因为其他原因而采用源代码编译安装的情况也经常存在,所以有必要梳理下采用源代码安装程序包的安装方式。

   手动编译源代码文件通常需要依赖相关的库环境、编译开发工具等,不同语言编写的源代码它们所依赖的头文件、本地库、编译工具和被依赖的程序包的开发组件等各不相同。

二、用法详解

 一般来说带“devel”关键字的rpm包都是这个程序包的开发组件。

   包组(此处列出包组仅适用于centos6,其他版本名称各有不同):

   Development tools(含编译器、汇编器、链接器等工具,必须)

   Server Platform Development(服务器平台开发组件,必须)

   Desktop Platform Development(桌面平台开发组件,非必须,视情况安装)

   Debug Tools(非必须,视情况安装)

 被依赖的程序包的开发组件:两种方式:

   (1) 编译安装被依赖的程序;

   (2) 安装相关程序的名称中包含devel的子包;

例:安装开发工具组件,命令为:yum groupinstall "开发工具" ,详情见下图:

blob.png

例:安装服务器平台开发组件,命令为:yum groupinstall "服务器平台开发" ,详情见下图:

blob.png

安装好开发套件之后就可以进行相关配置操作。

GNU make:配置文件:makefile

注意:

(1)每个项目的程序员开发完成某版本之后,会使用autoconf为程序代码生成一个脚本文件:configure;

功用:此脚本会收集当前系统上的开发环境中所依赖各组件的版本、特性等,并检查所依赖的环境是否能满足,最后会根据Makefile.in 文件生成一个makefile文件;

(2)每个项目的程序员开发完成某版本之后,会使用automake为程序代码生成一个makefile模板文件,即Makefile.in。

编译人员的编译安装过程:

   (1) 运行configure脚本;常使用选项指明:

      安装路径: –prefix=/usr/local/nginx (该路径如不存在会自动创建)

      启用或禁用的特性;

      依赖的程序包;

   (2) 运行make命令,完成项目构建;

   (3) 运行make install命令,完成安装(大多数情况只有管理员有权限执行此命令);

注意:前两步只需要普通用户权限,建议使用普通用户身份进行;最后一步根据安装路径的指定,可能会用到管理权限。

configure脚本的应用:

   –help: 查看帮助信息;

   –prefix: 指定默认安装路径;

   –sysconfdir: 指定配置文件安装路径

   –with-CAPABILITY(依赖某特性)

   –without-CAPABILITY(不依赖某特性)

   –enable-FEATURE(启用某特性)

   –disable-FEATURE(禁用某特性)

例:安装nginx-1.6.2.tar.gz源代码安装包,详情见下图:blob.png

blob.png

blob.png

blob.png

例:安装源代码格式的httpd程序包 ,详情见下图:

blob.png

blob.png

blob.png

程序运行环境:

二进制文件:$PATH环境变量指明的路径下,/bin, /sbin, /usr/bin, /usr/sbin,/usr/local/bin,/usr/local/sbin

自己编译的程序文件安装路径如果不在PATH环境变量指定的程序搜索路径中:

(1) 使用绝对路径;

(2) 编译PATH环境变量,加入此些程序文件所在目录;

export PATH=extra_path:$PATH

把上面的命令保存于/etc/profile.d/*.sh文件中

blob.png

库文件:

默认情况下,大多数应用程序都依赖于标准库某些共享库文件,甚至于某些应用提供的特定的库文件;

Linux系统会在特定路径下为应用查找所依赖的库文件:/lib64, /lib, /usr/lib64, /usr/lib

自己编译安装的程序提供的库文件有可能不在系统搜索路径中,解决办法:两步骤:

(1) 编辑/etc/ld.so.conf.d/*.conf文件,添加新库文件搜索路径至此文件中,每行一个;

(2) 执行ldconfig命令,重新生成库映射缓存ld.so.conf

ldconfig命令:configure dynamic linker run-time bindings

用于生成/etc/ld.so.cache

常用选项:

-p: 打印当前系统ld.so.cache中已经缓存的所有库文件目录及库文件映射列表;

-v: 显示命令执行过程的详细信息;

blob.pngblob.pngblob.png

blob.pngblob.png

blob.png

blob.png

头文件导出方案:

方法:

(1) 复制所有新生成的头文件至/usr/include目录中(不推荐);

(2) 创建链接

  ln -sv /usr/local/apache/include /usr/include/httpd

  ln -sv /usr/local/apache/include/* /usr/include/

blob.pngblob.png

man手册文件:

Linux会到特定目录下查找用户需要使用命令手册

路径:/etc/man.config配置文件中,使用MANPATH指令指向的路径;

方法:

(1) 在此文件新增MANPATH指令,并指向新的命令手册路径;

(2) 在man命令执行时使用-M选项显式指定手册而查找路径即可;

blob.png

blob.pngblob.png

blob.pngblob.pngblob.png

注意:如果安装的程序是一个服务类程序,rpm安装的方式通常为自动生成服务脚本文件(此文件为rpm制作者所提供),但编译安装不会有;需要卸载时只需删除安装目录即可。

注意:编译安装的程序包,尽可能把所有文件安装至一个专用路径下,卸载时删除此目录即可;

其它程序语言(如:perl, python, ruby, java)开发的源码包,编译安装方式可能会有所不同;

这种情况一般查看INSTALL, README文件里的使用说明即可。

原创文章,作者:镜花水月,如若转载,请注明出处:http://www.178linux.com/8433

(2)
镜花水月镜花水月
上一篇 2015-09-26
下一篇 2015-09-27

相关推荐

  • 马哥教育网络班N22期+第7周作业

    1、创建一个10G分区,并格式为ext4文件系统;(1) 要求其block大小为2048, 预留空间百分比为2, 卷标为MYDATA, 默认挂载属性包含acl;mke2fs -t ext4 -b 2048 -L MYDATA -m 2 /dev/sdb1tune2fs -o acl /dev/sdb1(2) 挂载至/data/mydata目录,要求挂载时禁止…

    Linux干货 2016-11-14
  • 早安,Linux

    希望能通过不断的努力,变成一个不一样的我。

    Linux干货 2017-07-11
  • LINUX下的RPM应用

    一 前言 在进入RPM的应用前,关于可执行程序的一些基本知识有必要说明一下: 1 ABI:application binary interface,这是应用程序与系统间的协议,大家都知道同一个程序在不同的操作系统平台可能会无法执行,很大程度上就是因为ABI的不同,因此,对于可执行程序,选择对应操作系统平台是第一步 2 API:application prog…

    Linux干货 2017-04-17
  • 探究PHP底层

    1、PHP是什么? PHP 指的是我们从外面看到的一套完整的系统。这听起来有点糊涂,但其实并不复杂(PHP4 内部结构图)。从功能上来分:我们可以分为三部分: 1、 解释器部分(Zend 以引擎),负责对输入代码的分析、翻译和执行;2、 功能性部分(PHP功能函数以及扩展),负责具体实现语言的各种功能(比如它的函数等等);3、 接口部分(SAPI),负责同 …

    Linux干货 2015-04-10
  • Nginx 编译安装

    简介 Nginx ("engine x") 是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP服务器。Nginx是由Igor Sysoev为俄罗斯访问量第二的Rambler.ru站点开发的,第一个公开版本0.1.0发布于2004年10月4日。其将源代码以类BSD许可证的形式发布,因它的稳定性、丰富的功能集、示例配…

    Linux干货 2016-12-01
  • 2班jackcui20160802作业

    1、每日课堂笔记总结 2、预习 3、每日课堂pdf练习 4、在/data/testdir里创建的新文件自动属于g1组,组g2的成员如:alice能对这些新文件有读写权限,组g3的成员如:tom只能对新文件有读权限,其它用户(不属于g1,g2,g3)不能访问这个文件夹。 [root@centos7 /]# groupadd g1 [root@centos7 /…

    Linux干货 2016-08-05

评论列表(2条)

  • 云中鹤
    云中鹤 2015-09-26 22:50

    写的这么用心

    • 镜花水月
      镜花水月 2015-09-26 23:20

      @艾贺谢谢,希望在自己记录博客的同时,能帮助到大家 。