问题

操作系统:Red Hat Enterprise Linux Server版本6.4(圣地亚哥)

此操作系统上当前yum安装的Apache是​​2.2.15.我需要最新的2.4.x分支,所以已经去手动安装它.我注意到了我承诺的完整的过程,包括事先将 apr apr-util 源解包到apache源中,但我想以下是过程的最重要的部分:

GATHER LATEST APACHE AND APR
$ cd ~
$ mkdir apache-src
$ cd apache-src
$ wget http://apache.insync.za.net//httpd/httpd-2.4.6.tar.gz
$ tar xvf httpd-2.4.6.tar.gz
$ cd httpd-2.4.6
$ cd srclib
$ wget http://apache.insync.za.net//apr/apr-1.5.0.tar.gz
$ tar -xvzf apr-1.5.0.tar.gz
$ mv apr-1.5.0 apr
$ rm -f apr-1.5.0.tar.gz
$ wget http://apache.insync.za.net//apr/apr-util-1.5.3.tar.gz
$ tar -xvzf apr-util-1.5.3.tar.gz 
$ mv apr-util-1.5.3 apr-util

INSTALL DEVEL PACKAGES
yum update --skip-broken (There is a dependency issue with the latest Chrome needing the latest libstdc++, which is not available for RHEL and CentOS)
yum install apr-devel
yum install apr-util-devel
yum install pcre-devel

INSTALL
$ cd ~/apache-src/httpd-2.4.6
$ ./configure --prefix=/etc/httpd --enable-mods-shared="all" --enable-rewrite --with-included-apr
$ make
$ make install

NOTE: At the time of running the above, /etc/http is empty.

这似乎已经很好,直到我尝试启动httpd服务.看起来每个模块都包含在 httpd.conf 失败,并且类似于 mod_rewrite 的消息:

httpd: Syntax error on line 148 of /etc/httpd/conf/httpd.conf: Cannot load /etc/httpd/modules/mod_rewrite.so into server: /etc/httpd/modules/mod_rewrite.so: undefined symbol: ap_global_mutex_create

我已经浏览了 httpd.conf 中的已启用模块列表,并一次一个地注释它们.所有触发一个错误,如上所述,但是"未定义的符号:值"通常是不同的(因此不总是 ap_global_mutex_create ).

我缺少一个步骤吗?虽然我在Google上发现了该错误的一部分,但大多数解决方案围绕着 .so 文件无法访问.这似乎并不是一个问题,这些模块存在于 / etc / http / modules .

NOTE: At the time of running the above, /etc/http is empty.



解决方法

您有正确的程序,但不完整.

安装后,您必须在 httpd.conf 中启用SSL.并生成 server.crt server.key 文件. 下面的完整过程:

1.下载Apache

cd /usr/src
wget http://www.apache.org/dist/httpd/httpd-2.4.23.tar.gz
tar xvf httpd-2.4.23.tar.gz

2.下载APR和APR-Util

cd /usr/src
wget -c http://mirror.cogentco.com/pub/apache/apr/apr-1.5.2.tar.gz
wget -c http://mirror.cogentco.com/pub/apache/apr/apr-util-1.5.4.tar.gz
tar xvf apr-1.5.2.tar.gz
tar xvf apr-util-1.5.4.tar.gz

现在将您下载的APR和APR-Util放到apache源文件中.

mv apr-1.5.2 /usr/src/httpd-2.4.23/srclib/apr
mv apr-util-1.5.4 /usr/src/httpd-2.4.23/srclib/apr-util

3.编译

cd /usr/src/httpd-2.4.23
./configure --enable-so --enable-ssl --with-mpm=prefork --with-included-apr
make
make install

4.在httpd.conf中启用SSL

Apache配置文件 httpd.conf 位于 / usr / local / apache2 / conf 下.

nano /usr/local/apache2/conf/httpd.conf

取消注释 httpd-ssl.conf 包含行和 LoadModule ssl_module 行 /usr/local/apache2/conf/httpd.conf < em> file:

# LoadModule ssl_module modules/mod_ssl.so
# Include conf/extra/httpd-ssl.conf

查看 httpd-ssl.conf 以查看所有默认SSL配置.对于大多数情况,您不需要修改此文件中的任何内容.

nano /usr/local/apache2/conf/extra/httpd-ssl.conf

在我们启动Apache之前,需要SSL证书和密钥. httpd-ssl.conf 中提及的 server.crt server.key .

cd /usr/local/apache2/conf/extra
egrep 'server.crt|server.key' httpd-ssl.conf

SSLCertificateFile "/usr/local/apache2/conf/server.crt"
SSLCertificateKeyFile "/usr/local/apache2/conf/server.key"

5.生成server.crt和server.key文件

首先,使用openssl生成 server.key .

cd /usr/src
openssl genrsa -des3 -out server.key 1024

上述命令将要求输入密码.请务必记住此密码.稍后启动Apache时,您需要这样做.

接下来,使用上述 server.key 文件生成证书请求文件( server.csr ).

openssl req -new -key server.key -out server.csr

最后,使用上述 server.key server.csr 文件生成自签名SSL证书( server.crt ).< / p>

openssl x509 -req -days 365 -in server.csr -signkey server.key -out server.crt

server.key server.crt 文件复制到相应的Apache配置目录位置.

cp server.key /usr/local/apache2/conf/
cp server.crt /usr/local/apache2/conf/

6.启动Apache

/usr/local/apache2/bin/apachectl start

如果您收到以下错误讯息:

AH00526: Syntax error on line 51 of /usr/local/apache2/conf/extra/httpd-ssl.conf:
Invalid command 'SSLCipherSuite', perhaps misspelled or defined by a module not included in the server configuration

请务必取消以下在 httpd.conf 中显示的行注释:

vi /usr/local/apache2/conf/httpd.conf

# LoadModule socache_shmcb_module modules/mod_socache_shmcb.so

最后,这将提示您在启动apache之前输入您的私钥的密码. 验证Apache httpd进程是否在后台运行.

ps -ef | grep http

您应该看到类似的东西:

root    29529 1     0 13:08 ? 00:00:00 /usr/local/apache2/bin/httpd -k start
antoine 29530 29529 0 13:08 ? 00:00:00 /usr/local/apache2/bin/httpd -k start
antoine 29531 29529 0 13:08 ? 00:00:00 /usr/local/apache2/bin/httpd -k start
antoine 29532 29529 0 13:08 ? 00:00:00 /usr/local/apache2/bin/httpd -k start
root    29616 18260 0 13:09 pts/0 00:00:00 grep http

默认情况下,Apache SSL在443端口上运行.打开网络浏览器并验证您是否可以使用https:// {your-ip-address}

访问您的Apache

我希望这个帮助,否则我建议你去看: http://jasonpowell42.wordpress.com/2013/04/05/install-apache-2-4-4-on-centos-6-4/




相关问题推荐