在广泛的研究和测试中,为了编写一个值得 stackexchange 的正确问题,我找到了一个解决方案:libapr1
在来宾内部重建包。
我想我还是会发布这些信息,因为它可能对其他人有用。
问题
当我libapache2-mod-php5
在 Wheezy 来宾中安装并尝试启动时,我得到以下信息:
root@test01:~# /usr/sbin/apache2ctl start
[crit] (22)Invalid argument: alloc_listener: failed to get a socket for (null)
Syntax error on line 9 of /etc/apache2/ports.conf:
Listen setup failed
Action 'start' failed.
The Apache error log may have more information.
root@test01:~# tail /var/log/apache2/error.log
root@test01:~#
root@test01:~# head -n 9 /etc/apache2/ports.conf|tail -n 1
Listen 80
这是未更改的原始包安装,默认情况下无法启动。
我的测试
根据官方文档,Listen 80其实是可以的。把它变成Listen 127.0.0.1:80
给我:
[crit] (22)Invalid argument: alloc_listener: failed to get a socket for 127.0.0.1
Syntax error on line 9 of /etc/apache2/ports.conf:
Listen setup failed
Action 'start' failed.
那么为什么 Apache 无法获得套接字呢?我有其他守护进程在运行(即 nginx 在其他 Wheezy 安装上;exim4 在同一安装上侦听端口 25)没有问题。
环境
主持人
2.6.26-2-vserver-amd64 上的 Debian Lenny
# vserver-info
Versions:
Kernel: 2.6.26-2-vserver-amd64
VS-API: 0x00020303
util-vserver: 0.30.216-pre2772; Dec 13 2008, 04:56:19
Features:
CC: gcc, gcc (Debian 4.3.2-1) 4.3.2
CXX: g++, g++ (Debian 4.3.2-1) 4.3.2
CPPFLAGS: ''
CFLAGS: '-Wall -g -O2 -std=c99 -Wall -pedantic -W -funit-at-a-time'
CXXFLAGS: '-g -O2 -ansi -Wall -pedantic -W -fmessage-length=0 -funit-at-a-time'
build/host: x86_64-pc-linux-gnu/x86_64-pc-linux-gnu
Use dietlibc: yes
Build C++ programs: yes
Build C99 programs: yes
Available APIs: v13,net,v21,v22,v23,netv2
ext2fs Source: e2fsprogs
syscall(2) invocation: alternative
vserver(2) syscall#: 236/glibc
crypto api: beecrypt
use library versioning: yes
Paths:
prefix: /usr
sysconf-Directory: /etc
cfg-Directory: /etc/vservers
initrd-Directory: $(sysconfdir)/init.d
pkgstate-Directory: /var/run/vservers
vserver-Rootdir: /var/lib/vservers
Assumed 'SYSINFO' as no other option given; try '--help' for more information.
来宾
Debian Wheezy,构建于vserver $VSERVER build -m debootstrap --hostname $VSERVER --netdev eth0 --context $CONTEXT --interface v$CONTEXT=x.y.z.$CONTEXT/zz -- -d wheezy -m http://apt-proxy:9999/debian/
研究至今
到目前为止,互联网为我提供了以下内容:
我最大的恐惧,也是我目前的结论,是虚拟服务器中的 apache 依赖于我的主机不提供的一些较新的内核功能。毕竟,Wheezy 默认内核肯定没有我的 2.6.26 旧。
我想不惜一切代价避免升级主机内核。
为什么?
- 缺乏时间和知识(硬件是 HP 服务器,不知道要注意什么)
- Wheezy 不再支持虚拟服务器(开箱即用;自行安装请参见 1)...)
- 已经在运行需要 24/7 全天候可用的虚拟服务器(整个系统是公司内部的,不暴露在互联网上)
- 没有第二个相同的硬件来执行测试
我愿意为 Apache 打补丁
如果可以找出问题所在,我愿意为我的 Wheezy 任务构建一个自定义 deb 包。
解决方案
正如我在第一句话中所说,我已经找到了解决方案:我在 guest中重建了
libapr1
包。我通过谷歌搜索“Invalid argument: alloc_listener: failed to get a socket for (null)”找到了解决方案,第 5 次命中是Invalid argument crap,它提到了内核升级并引用了另一位谈论 Fedora 11 httpd问题的博主:
他提到 Fedora 团队已修复,所以我查看了错误报告:https ://bugzilla.redhat.com/show_bug.cgi?id=516331 ,特别是第二条评论:
这敲响了警钟。我所要做的就是重建
libapr1
包,因为配置脚本会自动找出accept4
不可用的包,并将恢复为accept
. 我就是这样做的:apt-get source libapr1
tar -xf apr_1.4.6.orig.tar.gz
cd apr-1.4.6
tar -xf ../apr_1.4.6-3.debian.tar.gz
dpkg-buildpackage
由于缺少依赖项,这首先失败了:
apt-get install debhelper autoconf autotools-dev uuid-dev doxygen libtool
dpkg -i libapr1_1.4.6-3_amd64.deb
/etc/init.d/apache2 start
在磁盘匮乏的系统上,您可能希望在编译后删除 doxygen:在我的系统上,它需要超过 600MB 以及它的依赖项。