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

相关推荐

  • shell脚本一键分区

    #!/bin/bash #实现硬盘自动分区助手 echo "当前所有分区:" echo `fdisk -l|grep "Disk /dev/[sh]d"|cut -d: -f1|awk '{print $2 &q…

    Linux干货 2016-07-26
  • day6总结

    主要内容: useradd与usermod对比 groupadd与groupmod对比 passwd与chage对比 gpasswd与groupmems对比 切换用户 chown与chgrp用法 一般权限与特殊权限 chmod用法   useradd创建用户的初始信息存放在/etc/login.defs和/etc//default/useradd文…

    系统运维 2016-08-08
  • 分布式文件系统之MogileFS

    MogileFS是一个开源的分布式文件存储系统,由LiveJournal旗下的Danga Interactive公司开发。Danga团队开发了包括 Memcached、MogileFS、Perlbal 等多个知名的开源项目。目前使用MogileFS 的公司非常多,如日本排名先前的几个互联公司及国内的yupoo(又拍)、digg、豆瓣、1号店、大众点评、搜狗和…

    Linux干货 2017-06-16
  • samba应用

    samba详解 前言 前面学过了NFS,是一个网络文件系统,可以让远程连接像访问本地文件一样,在同一个网络上的多个用户间共享目录和文件系统。只不过NFS只是针对于两个linux主机,我们现在需要linux主机和windows主机都能共享,这个时候就用到了samba。 1、步骤,允许个别用户访问 1、安装下面三个包: samba samba-common sa…

    Linux干货 2016-12-21
  • 公钥和私钥的原理

          今天上课老师讲到公钥和秘钥,模模糊糊听了个大概,始终还是不能够详细的理解公钥怎么会事?私钥怎么会事?工作原理是怎么的?今天在网上找了半天,通过查看大家对这个密钥对的理解,总算弄清楚了,咱就把我的心得写出来给大家对密钥对有疑问的同志们看看。      公钥和私钥就是俗称…

    Linux干货 2016-11-30
  • 马哥教育网络班22期+第4周课程练习

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 [root@localhost home]# cp -r /etc/skel /home/tuser1 [root@localhost skel]# ch…

    Linux干货 2016-09-05

评论列表(2条)

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

    写的这么用心

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

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