AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 496989
Accepted
mark
mark
Asked: 2013-04-08 03:16:47 +0800 CST2013-04-08 03:16:47 +0800 CST 2013-04-08 03:16:47 +0800 CST

linux-vserver 中的 Apache 无法启动,无法创建套接字

  • 772

在广泛的研究和测试中,为了编写一个值得 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/

研究至今

到目前为止,互联网为我提供了以下内容:

  • 通过升级 APR 解决了 fedorra 上的问题
  • 升级包解决的问题
  • 内核不兼容
  • 另一个解决方案需要内核升级

我最大的恐惧,也是我目前的结论,是虚拟服务器中的 apache 依赖于我的主机不提供的一些较新的内核功能。毕竟,Wheezy 默认内核肯定没有我的 2.6.26 旧。

我想不惜一切代价避免升级主机内核。

为什么?

  • 缺乏时间和知识(硬件是 HP 服务器,不知道要注意什么)
  • Wheezy 不再支持虚拟服务器(开箱即用;自行安装请参见 1)...)
  • 已经在运行需要 24/7 全天候可用的虚拟服务器(整个系统是公司内部的,不暴露在互联网上)
  • 没有第二个相同的硬件来执行测试

我愿意为 Apache 打补丁

如果可以找出问题所在,我愿意为我的 Wheezy 任务构建一个自定义 deb 包。

apache-2.2
  • 1 1 个回答
  • 6703 Views

1 个回答

  • Voted
  1. Best Answer
    mark
    2013-04-08T03:16:47+08:002013-04-08T03:16:47+08:00

    解决方案

    正如我在第一句话中所说,我已经找到了解决方案:我在 guest中重建了libapr1包。

    我通过谷歌搜索“Invalid argument: alloc_listener: failed to get a socket for (null)”找到了解决方案,第 5 次命中是Invalid argument crap,它提到了内核升级并引用了另一位谈论 Fedora 11 httpd问题的博主:

    该问题与 apr-1.3.8-1 中使用的三个内核调用有关:accept4()、dup3() 和 epoll_create1()。没有这些调用,apache 将无法启动。

    他提到 Fedora 团队已修复,所以我查看了错误报告:https ://bugzilla.redhat.com/show_bug.cgi?id=516331 ,特别是第二条评论:

    .. 如果您在该 Xen 实例上构建自己的 APR,它将正确地获取旧功能并工作 ..

    这敲响了警钟。我所要做的就是重建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
    • 一段时间后,这在我安装的目录之外产生了一个 debian 包:
      dpkg -i libapr1_1.4.6-3_amd64.deb
    • 然后我刚刚启动了 apache,它成功了!
      /etc/init.d/apache2 start

    在磁盘匮乏的系统上,您可能希望在编译后删除 doxygen:在我的系统上,它需要超过 600MB 以及它的依赖项。

    • 16

相关问题

  • Apache Django Mod_Wsgi - 自动重新加载应用程序

  • Apache:对多个虚拟主机使用相同的目录指令

  • Apache 上的子域不工作 - 找不到服务器

  • PHP 作为 CGI 还是 Apache 模块?

  • 避免将某些丢失的文件记录到 Apache2 错误日志中

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve