使用 apxs 构建和安装 Apache 扩展共享对象模块

AP ache e X ten S ion 工具或者是一个简洁的apxs小程序(perl 脚本),它允许我们为 Apache HTTP 服务器构建和安装扩展模块。这些类似于我们多次看到的模块mod_rewrite,例如、mod_proxymod_authz_core、等,它们作为(共享对象)文件mod_remoteip驻留在某个文件夹中。.so是的,我们正在讨论如何使用此工具从 C 源代码构建共享/动态模块。

要使用此扩展机制,您的平台必须支持 DSO 功能(这对于大多数基于 unix 或类 unix 的操作系统都是如此)并且httpd必须使用 mod_so(这也是相当常见的)构建。如果不是这样,apxs无论如何都会抱怨跑步。

安装

让我们看看如何apxs跨不同的操作系统安装该工具,因为它并不总是随标准包管理器存储库中的默认包apache或包一起提供。httpd

FreeBSD

对于 FreeBSD,该apxs工具apache自带软件包,所以这很酷。

# pkg install apache24
# rehash
# which apxs
/usr/local/sbin/apxs

CentOS / Fedora

对于 CentOS 或 Fedora,我们必须安装一个名为httpd-devel.

# dnf install httpd-devel # or yum install httpd-devel
# which apxs
/usr/bin/apxs

Ubuntu/Debian

对于 Ubuntu 或 Debian,要安装的软件包是apache2-dev.

# apt install apache2-dev
# which apxs
/usr/bin/apxs

Alpine (Docker)

如果您正在运行基于 Alpine 的容器,则apache2-dev需要 package。

# apk add apache2-dev

用法

安装apxs后,使用它非常简单。例如,最近我必须构建和安装mod_evasive模块(用于 DDoS 保护),我所做的只是复制单个 C 文件并运行以下命令:

# apxs -cia mod_evasive.c
...
Libraries have been installed in:
   /usr/lib/apache2/modules
...
chmod 644 /usr/lib/apache2/modules/mod_evasive.so
[preparing module `evasive20' in /etc/apache2/mods-available/evasive20.load]
Enabling module evasive20.
To activate the new configuration, you need to run:
  service apache2 restart

它负责:

  • -c– 构建.so文件。
  • -i– 将它放在正确的位置(所有其他模块所在的位置),在我的情况下(Ubuntu)是/usr/lib/apache2/modules/.
  • -a– 创建一个.load带有指令的文件LoadModule并将其放在mods-available(特定于 Ubuntu/Debian)下。它甚至可以启用该模块。在 FreeBSD、Fedora 等其他发行版中,apxs会自动将LoadModule指令添加到httpd.conf.

为了使更改生效,最后一步是重新启动 apache 服务器。

所以现在我们知道给定一个源文件(in C),如何apxs使用它来生成一个可以轻松链接到 httpd 的共享对象。将来如果您必须从头开始构建第三方模块,因为操作系统包管理器不提供对象,那么您知道该怎么做!

猜你喜欢

转载自blog.csdn.net/allway2/article/details/126257311