实例;编译安装apache 2.2,并启动此服务

基于c语言的源代码编译安装,通常有三个步骤

    ./configure

        (1)通过选项传递参数,指定启用特性,安装路径等:执行时会参考用户的指定以及makefile.in文件生成makefile.

        (2)检查依赖到的外部环境;



make:根据makefile文件,构建应用程序:(make是真正构建项目成为二进制程序的一个关键步骤,但make自己不是编译器,他是调用gcc来完成编译的,所以说make只是一个项目管理工具,而这个项目管理工具依赖与makfile,l来完成项目构建,而makefile又不能写死,所以这个时候依赖与configure脚本结合程序员事先写好的模版Makefile.in,让用户自己指定选项以后执行生成



makeinstall(makeinstall其实就是把编译好的文件复制到configure指定的安装路径下去)

   configure,和makefile.in是由项目构建工具生成的,但是有些应用程序的编译安装不会自带,所以得手动生成,而这依赖于以下两个开发工具;       开发工具:

          autoconf:生成configure脚本

          automake:生成makefile.in

      对与不同的应用程序,他的configure脚本肯定是不一样的,因为对不同的应用程序他的参数和特性不一样。所有autoconf需要结合一个配置文件去生成一个configure脚本,这个配置文件是用来告诉autoconf当前的这个开发的代码他需要有那些功能,是用来做特性使用的。automake也是如此,这就意味着不同程序的安装步骤是不一样的,有些程序需要configure脚本,有些程序不需要。所有建议安装源代码程序时注意查他的install文档,建议:安装前查看install文档,readme文档



准备工作    

    开源程序源代码的获取:

     官方自建站点:

          apache.org(ASF)

          mariadb.org

     代码托管:

          sourceforge

          github.com

          code.google.com

 提供开发工具及开发环境(chentos 5 6 7 通过“包组”提供开发组件,本次安装是在centos6操作系统下完成的)

         centos 6 的标准开发组件有两个"Development toos","server platfrom development"   

        开发工具:make ,gcc等等

          开发环境:开发库,头文件

        安装"Development toos","server platfrom development"

]#yum groupinstall "Development toos" "server platfrom development"

第一步:./configure脚本

    选项:指定安装位置,指定启用特性

        –help:获取其支持使用的选项

    选项分类:

    安装路径设定:

        –prefix=path/to/somewhere:指定默认安装位置;默认为/usr/local

        –sysconfidir=/path/to/somewhere:配置文件安装位置

        optional features:可选特性

        –disable-feature

        –enable-feature[=arg]

        optional packages:可选包

        –with-package[=arg]

        –whithout-package

    下载并解压httpd-2.2.29.tar

]#tar xvf httpd-2.2.29.tar.bz2

cd至httpd2.2.29目录

安装前查看INSTALL,README文档

    INSTALL,README文件是该程序的安装文档信息等内容

]#less INSTALL 
]#less README

执行./configure –prefix=/usr/local/apache –sysconfdir=/etc/httpd命令,指定安装位置和配置文件位置

]#./configure --prefix=/usr/local/apache --sysconfdir=/etc/httpd

第二步:make

    执行make根据makefile文件,构建应用程序

]#make

第三步:make install

]#make install

    cd到/usr/local/apache目录,查看安装结果查找到bin目录下的apachectl(这是一个脚本,可以控制启动apachectl服务的)。并且执行bin/apachectl start命令开启服务,使用netstat -tan 查看80端口属于监听状态及表示服务已经开始运行。

    自定义编译安装之后,将其整体安装在了/usr/local/*文件下,卸载时只需删除该文件夹即可。

    但是,此时系统路径是无法读取该配置文件的,所以服务可能无法启动,需要配置其部分文件。

/usr/local/apache]#ls bin
ab         apr-1-config  apxs      dbmmanage  envvars-std   htdbm     htpasswd  httxt2dbm   rotatelogs
apachectl  apu-1-config  checkgid  envvars    htcacheclean  htdigest  httpd     logresolve


安装后的配置

(1)导出二进制程序目录至path环境变量中

    编辑文件/etc/profile.d/name(以程序名命名).sh输入export path=/payh/to/bin:$path

]#vim apaceh.sh
]#cat apaceh.sh
export PATH=$PATH:/usr/local/apache/bin

(2)导出库文件路径

    编辑/etc/ld.so.conf.d/name.conf

    添加新的库文件所在目录至此文件中;

]#vim /etc/ld.so.conf.d/apache.conf
]#cat /etc/ld.so.conf.d/apache.conf
/usr/local/apache/lib

让系统重新生成缓存

    执行ldconfig[-v]命令

]#ldconfig -v
/usr/local/apache/lib:
	libexpat.so.0 -> libexpat.so.0.5.0
	libapr-1.so.0 -> libapr-1.so.0.5.1
	libaprutil-1.so.0 -> libaprutil-1.so.0.5.3

(3)导出头文件

    基于链接的方式实现

    ln -sv

]#ln -sv /usr/local/include/ /usr/include/apache
"/usr/include/apache" -> "/usr/local/include/"

(4)导出帮助手册

    编辑/etc/man.config文件

    添加一个manpath

MANPATH /usr/local/apache(添加此段语句)
/usr/local/apache]#ls man
man1  man8

至此整个编译安装完成!



安装后问题报错

启动服务失败

]#service httpd start
正在启动 httpd:httpd: Syntax error on line 163 of /etc/httpd/conf/httpd.conf: Cannot load /etc/httpd/modules/mod_ldap.so into
 server: /etc/httpd/modules/mod_ldap.so: undefined symbol: apr_ldap_ssl_init
                                                           [失败]

问题分析;/etc/httpd/conf/httpd.的第163行不能加载配置 这个apr_ldap_ssl_init到底是什么鬼,目前未知。

解决办法,注释掉/etc/httpd/cof/httpd.conf第163,164行,并且启动成功

]#service httpd start
正在启动 httpd:httpd: apr_sockaddr_info_get() failed for \xd8\xa7\xd9\x84\xd8\xb3\xd9\x84\xd8\xa7\xd9\x85 \xd8\xb9\xd9\x
84\xd9\x8a\xd9\x83\xd9\x85
httpd: Could not reliably determine the server's fully qualified domain name, using 127.0.0.1 for ServerName
                                                           [确定]

yum安装links之后测试成功

blob.png

本地ip测试可访问(需关闭防火墙)iptables -F

blob.png

原创文章,作者:M20-1马星,如若转载,请注明出处:http://www.178linux.com/39288

(0)
M20-1马星M20-1马星
上一篇 2016-08-24
下一篇 2016-08-24

相关推荐

  • 开篇

    新人报道

    Linux干货 2016-10-24
  • 初涉Linux基本要点概括(1)

    计算机,这里通常指可以储存程序的计算机,根据冯诺依曼体系,计算机组成部件包括控制单元(Control Unit)、算术逻辑单元(Arithmetic Logic Unit)、内存(Memory)、输入设备(Input)、输出设备(Output)。计算机通过输入的数据和指令,可以完成各种复杂的运算任务,小到文字处理、游戏、影音、大到卫星定位,火箭发射,人工智能…

    Linux干货 2016-09-26
  • Linux文本三剑客之grep

    一、定义:                 GREP  :Global search REgular expression and Print out the line的缩写。是一种强大的文本搜索工具,根据用户指定的“模式”对目标文本逐行进行匹配检查;并把匹配的行打印出…

    Linux干货 2016-04-05
  • 简述硬盘参数和ext2文件系统

    硬盘类型: HDD机械硬盘和SSD固态硬盘: HDD是现在最普通的硬盘,容量大,稳定,是存储数据的首选。SSD是现在新兴的硬盘,相比HDD,它的并发i/o高,传输速度可达HDD的几倍以上,无噪音低功耗,而且轻便防震,随着各大厂商发力,性价比也越来越高,要求性能高或者数据轻度使用者可以优先考虑SSD。   容量:存储数据的空间大小,一般来说HDD每G…

    Linux干货 2016-04-19
  • Linux下常用安全策略设置的六个方法

    安全第一”对于linux管理界乃至计算机也都是一个首要考虑的问题。加密的安全性依赖于密码本身而非算法!而且,此处说到的安全是指数据的完整性,由此,数据的认证安全和完整性高于数据的私密安全,也就是说数据发送者的不确定性以及数据的完整性得不到保证的话,数据的私密性当无从谈起! 1. 禁止系统响应任何从外部/内部来的ping请求攻击者一般首先通过ping命令检测此…

    Linux干货 2017-07-31
  • 国际标准OSI七层模型和事实标准TCP/IP四层模型

    我们知道,标准分为三种:国际标准、国家标准和事实标准。那我们学习的两个重要模型:OSI和TCP/IP模型分别属于国际标准和事实标准,接下来我们来总结一下两种模型的分层及功能还有异同: 一:国际标准OSI模型 OSI:(Open System Interconnect) 开放系统互连,总共分为七层,从下到上顺序为:物理层(physical)、数据链路层(dat…

    2017-09-02