前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >CentOS-6.4-minimal版中源码安装Apache-2.2.29

CentOS-6.4-minimal版中源码安装Apache-2.2.29

作者头像
星哥玩云
发布2022-07-03 13:11:47
2580
发布2022-07-03 13:11:47
举报
文章被收录于专栏:开源部署开源部署

CentOS-6.4-minimal版中源码安装Apache-2.2.29 ---------------------------------------------------------------------------------------------------------------------- 源码安装软件时常见的三个步骤 1)配置环境:通常命令为./configure --prefix=DIR(即指定软件安装目录),如果还想启用其它功能,可在后面接着添加指令           比如下面的--enable-ssl用于启用Apache的SSL模块           若不想使用操作系统缺省的SSL库,还可通过--with-ssl=DIR指定自己编译的SSL库 2)编译源码:通常命令为make 3)安装应用:通常命令为make install ---------------------------------------------------------------------------------------------------------------------- 注意事项 1)httpd-2.2.29目录下的configure工具是GNU软件基金会推出的专门用于源码发布的工具 2)配置环境时若出现这个错误[configure: error: no acceptable C compiler found in $PATH],是说明缺少GCC编译环境   这时执行[yum -y install gcc]命令安装编译源码所需的工具和库就可以了 3)执行yum命令时若出现这个错误[Error: database disk image is malformed],是说明yum的缓存出错,需要清理缓存   这时执行[yum clean dbcache]命令即可 4)配置环境时configure的主要工作就是生成Makefile,编译源码时的make命令就是根据Makefile来进行编译的 5)最好以root安装和启动Apache,以root运行之后,apache就会把它的派生进程切换到非root用户 ---------------------------------------------------------------------------------------------------------------------- 安装Perl5 [root@CentOS64 software]# yum -y install wget [root@CentOS64 software]# wget http://www.cpan.org/src/5.0/perl-5.20.1.tar.gz [root@CentOS64 software]# tar zxvf perl-5.20.1.tar.gz [root@CentOS64 software]# cd perl-5.20.1 [root@CentOS64 perl-5.20.1]# ./Configure -des -Dprefix=/app/perl [root@CentOS64 perl-5.20.1]# make [root@CentOS64 perl-5.20.1]# make install [root@CentOS64 perl-5.20.1]# perl -v ---------------------------------------------------------------------------------------------------------------------- 安装OpenSSL [root@CentOS64 software]# tar zxvf openssl-1.0.1i.tar.gz [root@CentOS64 software]# cd openssl-1.0.1i [root@CentOS64 openssl-1.0.1i]# ./config --prefix=/app/openssl [root@CentOS64 openssl-1.0.1i]# make [root@CentOS64 openssl-1.0.1i]# make install [root@CentOS64 openssl-1.0.1i]# /app/openssl/bin/openssl version ---------------------------------------------------------------------------------------------------------------------- 安装Apache [root@CentOS64 software]# tar zxvf httpd-2.2.29.tar.gz [root@CentOS64 software]# cd httpd-2.2.29 [root@CentOS64 httpd-2.2.29]# rpm -qa | grep http [root@CentOS64 httpd-2.2.29]# ./configure --prefix=/app/apache --enable-ssl --with-ssl=/app/openssl [root@CentOS64 httpd-2.2.29]# make [root@CentOS64 httpd-2.2.29]# make install ---------------------------------------------------------------------------------------------------------------------- Apache的目录结构 bin------可执行文件(其实apache的可执行文件就一个:httpd,它就是apache的主程序)         使用[/app/apache/bin/httpd -l]命令可以查看apache编译了多少模块,即列出它支持的所有模块         如果其中包含[mod_so.c],则说明apache具备了动态加载模块的功能         比如说想新增加一个模块,那么就不用再编译一次apache了,只要编译一下这个模块,再在配置文件里面load进去就行了 conf-----配置文件(apache只有一个配置文件) htdocs---缺省的网站根目录(即启动apache后,别人访问apache时,实际访问的就是该目录里面的东西) include--头文件 logs-----日志 man------手册 manual---联机文档 modules--存放一些编译好的模块,供apache启动时动态加载 ---------------------------------------------------------------------------------------------------------------------- 访问Apache 由于/app/apache/bin/目录下的apache主程序httpd支持很多参数,容易搞混 为了方便用户,apache提供了一个名为apachectl的启动脚本,它也是位于/app/apache/bin/目录下的,通过[vi apachectl]就可以看到脚本内容 启动apache时,在apache2.0版本中,若想启动支持SSL的apache,则需执行[apachectl startssl]命令 而在2.2中,直接执行[apachectl start]即可启动并支持SSL.当然前提是在httpd.conf中配置[Include conf/extra/httpd-ssl.conf] [root@CentOS64 bin]# /app/apache/bin/apachectl start [root@CentOS64 bin]# /app/apache/bin/apachectl restart [root@CentOS64 bin]# /app/apache/bin/apachectl stop ---------------------------------------------------------------------------------------------------------------------- Apache安装并初次启动后,常见的修改参数 1)启动或重启apache时,控制台会打印下面的信息   httpd: Could not reliably determine the server's fully qualified domain name, using 192.168.0.103 for ServerName   解决办法是修改/app/apache/conf/httpd.conf文件,取消注释[#ServerName www.example.com:80],再重启apache就看到效果了 2)apache启动后通过电脑访问http://192.168.0.102/,发现无法访问(成功访问时页面会显示"It works!")   解决办法是修改/etc/sysconfig/iptables文件,增加一行[-A INPUT -m state --state NEW -m tcp -p tcp --dport 80 -j ACCEPT]   注意这一样要添加到默认的22端口规则的下面,若添加到iptables文件的尾部,会有可能导致防火墙启动失败   接着再执行[service iptables restart]命令重启防火墙即可,不需要重启Linux   详细说明见 http://www.linuxidc.com/Linux/2014-09/107343.htm )当/app/apache/htdocs/中默认的index.html不存在时,访问apache会显示htdocs目录下的文件列表,我们可以设置其不显示文件列表   解决办法是修改/app/apache/conf/httpd.conf文件,注释掉[Options Indexes FollowSymLinks]这一行即可   然后再访问http://192.168.0.102/,就会看到熟悉的"Forbidden:You don't have permission to access / on this server." 4)如果想把apache加入系统自启动,常见的方法有两种:修改配置文件和将apache注册为系统服务(还有一种是在ntsysv命令调出的图形界面中操作的)   修改配置文件的方式最简单,在/etc/rc.d/rc.local文件尾部加入[/app/apache/bin/apachectl start]即可 ---------------------------------------------------------------------------------------------------------------------- @create Sep 26, 2014 9:14:43 AM @author 玄玉<http://www.linuxidc.com>

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档