设为首页 收藏本站
查看: 572|回复: 0

[经验分享] 您不得不看 apache添加模块(不重新编译)

[复制链接]

尚未签到

发表于 2017-1-8 10:20:43 | 显示全部楼层 |阅读模式
  下面是使用apxs工具给apache添加模块
  添加的模块:
LoadModule proxy_module        libexec/mod_proxy.so
LoadModule rewrite_module      libexec/mod_rewrite.so
LoadModule headers_module      libexec/mod_headers.so
  添加方法:
1. 进入apache1.3.33 源文件modules目录
cd apache_1.3.33/src/modules/
  2. 安装 proxy_module
> cd proxy
> /user/local/apache/bin/apxs -i -a -c *.c
  3. 安装 rewrite_module
> cd standard
> /user/local/apache/bin/apxs -i -a -c mod_rewrite.c
  4. 安装 headers_module
> cd standard
> /user/local/apache/bin/apxs -i -a -c mod_headers.c
  但是,用这种方法添加的proxy不可用,提示错误:
/apache/httpd/bin/apachectl configtest
httpd: Syntax error on line 58 of /apache/httpd-2.2.3/conf/httpd.conf:Cannot load /apache/httpd-2.2.3/modules/mod_proxy.so into server:/apache/httpd-2.2.3/modules/mod_proxy.so: undefinedsymbol:proxy_lb_workers
  所以,应该这样:
  在Linux系统下,需要给已经运行的Apache增加mod_proxy模块,编译的时候应该这样:
  apxs -c -i mod_proxy.c proxy_util.c
  否则你可能会收到这样的错误信息
  [iyunv@server1 proxy]# /apache/httpd/bin/apachectl configtest
httpd: Syntax error on line 58 of /apache/httpd-2.2.3/conf/httpd.conf:Cannot load /apache/httpd-2.2.3/modules/mod_proxy.so into server:/apache/httpd-2.2.3/modules/mod_proxy.so: undefinedsymbol:proxy_lb_workers
  如果你还加载了mod_proxy_ajp.so那应该
  apxs -c -i mod_proxy_ajp.c ajp*.c
[iyunv@server1 proxy]# /apache/httpd/bin/apachectl configtest
httpd: Syntax error on line 58 of /apache/httpd-2.2.3/conf/httpd.conf:Cannot load /apache/httpd-2.2.3/modules/mod_proxy_ajp.so into server:/apache/httpd-2.2.3/modules/mod_proxy_ajp.so: undefinedsymbol:ajp_msg_reset
  这是为什么呢?请看
apxs - Apache 扩展工具
  apxs是一个为Apache HTTP服务器编译和安装扩展模块的工具,用于编译一个或多个源程序或目标代码文件为动态共享对象,使之可以用由mod_so提供的LoadModule指令在运行时加载到Apache服务器中。
  因此,要使用这个扩展机制,你的平台必须支持DSO特性,而且Apache httpd必须内建了mod_so模块。apxs工具能自动探测是否具备这样的条件,你也可以自己用这个命令手动探测:
  $ httpd -l

  该命令的输出列表中应该有mod_so模块。如果所有这些条件均已具备,则可以很容易地借助apxs安装你自己的DSO模块以扩展Apache服务器的功能:
  $ apxs -i -a -c mod_foo.c
gcc -fpic -DSHARED_MODULE -I/path/to/apache/include -c mod_foo.c
ld -Bshareable -o mod_foo.so mod_foo.o
cp mod_foo.so /path/to/apache/modules/mod_foo.so
chmod 755 /path/to/apache/modules/mod_foo.so
[activating module 'foo' in /path/to/apache/etc/httpd.conf]
$ apachectl restart
/path/to/apache/sbin/apachectl restart: httpd not running, trying to start
[Tue Mar 31 11:27:55 1998] [debug] mod_so.c(303): loaded module foo_module
/path/to/apache/sbin/apachectl restart: httpd started
$ _

  其中的参数files可以是任何C源程序文件(.c)、目标代码文件(.o)、甚至是一个库(.a)。apxs工具会根据其后缀自动编译C源程序或者连接目标代码和库。但是,使用预编译的目标代码时,必须保证它们是地址独立代码(PIC),使之能被动态地加载。如果使用GCC编译,则应该使用 -fpic参数;如果使用其他C编译器,则应该查阅其手册,为apxs使用相应的编译参数。
  有关Apache对DSO的支持的详细信息,可以阅读mod_so文档,或者直接阅读src/modules/standard/mod_so.c源程序。

DSC0000.gif
语法
  apxs-g[ -Sname=value] -nmodname
  apxs-q[ -Sname=value] query...
  apxs-c[ -Sname=value] [ -odsofile] [ -Iincdir] [ -Dname=value] [ -Llibdir] [ -llibname] [ -Wc,compiler-flags] [ -Wl,linker-flags] files...
  apxs-i[ -Sname=value] [ -nmodname] [ -a] [ -A] dso-file...
  apxs-e[ -Sname=value] [ -nmodname] [ -a] [ -A] dso-file...


选项
一般选项
-n modname它明确设置了 -i(安装)和 -g(模板生成)选项的模块名称。对 -g选项,它是必须的;对 -i选项,apxs工具会根据源代码判断,或(在失败的情况下)按文件名推测出这个模块的名称。 查询选项
-q查询某种apxs设置的信息。该选项的query参数可以是下列一个或多个字符串:CC, CFLAGS, CFLAGS_SHLIB, INCLUDEDIR, LD_SHLIB, LDFLAGS_SHLIB, LIBEXECDIR, LIBS_SHLIB, SBINDIR, SYSCONFDIR, TARGET。  这个参数用于手动查询某些设置。比如,要手动处理Apache的C头文件,可以在Makefile中使用:
  INC=-I`apxs -q INCLUDEDIR`

配置选项
-S name=value此选项可以改变apxs的上述设置。 模板生成选项
-g此选项生成一个名为name的子目录(见选项 -n)和其中的两个文件:一个是名为mod_name.c的样板模块源程序,可以用来建立你自己的模块,或是学习使用apxs机制的良好开端;另一个则是对应的Makefile,用于编译和安装此模块。 DSO编译选项
-c此选项表示需要执行编译操作。它首先会编译C源程序(.c)files为对应的目标代码文件(.o),然后连接这些目标代码和files中其余的目标代码文件(.o和.a),以生成动态共享对象dsofile。如果没有指定 -o选项,则此输出文件名由files中的第一个文件名推测得到,也就是默认为mod_name.so。 -o dsofile明确指定所建立的动态共享对象的文件名,它不能从files文件列表中推测得到。如果没有明确指定,则其文件名将为mod_unknown.so。 -D name=value此选项直接传递到给编译命令,用于增加自定义的编译变量。 -I incdir此选项直接传递到给编译命令,用于增加自定义的包含目录。 -L libdir此选项直接传递到给连接命令,用于增加自定义的库文件目录。 -l libname此选项直接传递到给连接命令,用于增加自定义的库文件。 -Wc,compiler-flags此选项用于向编译命令 libtool --mode=compile中附加compiler-flags,以增加编译器特有的选项。 -Wl,linker-flags此选项用于向连接命令 libtool --mode=link中附加linker-flags,以增加连接器特有的选项。 DSO的安装和配置选项
-i此选项表示需要执行安装操作,以安装一个或多个动态共享对象到服务器的modules目录中。 -a此选项自动增加一个LoadModule行到httpd.conf文件中,以激活此模块,或者,如果此行已经存在,则启用之。 -A与 -a选项类似,但是它增加的LoadModule命令有一个井号前缀(#),即此模块已经准备就绪但尚未启用。 -e表示需要执行编辑操作,它可以与 -a和 -A选项配合使用,与 -i操作类似,修改Apache的httpd.conf文件,但是并不安装此模块。

举例
  假设有一个扩展Apache功能的模块mod_foo.c,使用下列命令,可以将C源程序编译为共享模块,以在运行时加载到Apache服务器中:
  $ apxs -c mod_foo.c
/path/to/libtool --mode=compile gcc ... -c mod_foo.c
/path/to/libtool --mode=link gcc ... -o mod_foo.la mod_foo.slo
$ _

  然后,必须修改Apache的配置,以确保有一个LoadModule指令来加载此共享对象。为了简化这一步骤,apxs可以自动进行该操作,以安装此共享对象到"modules"目录,并更新httpd.conf文件,命令如下:
  $ apxs -i -a mod_foo.la
/path/to/instdso.sh mod_foo.la /path/to/apache/modules
/path/to/libtool --mode=install cp mod_foo.la /path/to/apache/modules ... chmod 755 /path/to/apache/modules/mod_foo.so
[activating module 'foo' in /path/to/apache/conf/httpd.conf]
$ _

  如果配置文件中尚不存在,会增加下列的行:
  LoadModule foo_module modules/mod_foo.so

  如果你希望默认禁用此模块,可以使用 -A选项,即:
  $ apxs -i -A mod_foo.c

  要快速测试apxs机制,可以建立一个Apache模块样板及其对应的Makefile :
  $ apxs -g -n foo
Creating [DIR] foo
Creating [FILE] foo/Makefile
Creating [FILE] foo/modules.mk
Creating [FILE] foo/mod_foo.c
Creating [FILE] foo/.deps
$ _

  然后,立即可以编译此样板模块为共享对象并加载到Apache服务器中:
  $ cd foo
$ make all reload
apxs -c mod_foo.c
/path/to/libtool --mode=compile gcc ... -c mod_foo.c
/path/to/libtool --mode=link gcc ... -o mod_foo.la mod_foo.slo
apxs -i -a -n "foo" mod_foo.la
/path/to/instdso.sh mod_foo.la /path/to/apache/modules
/path/to/libtool --mode=install cp mod_foo.la /path/to/apache/modules ... chmod 755 /path/to/apache/modules/mod_foo.so
[activating module 'foo' in /path/to/apache/conf/httpd.conf]
apachectl restart
/path/to/apache/sbin/apachectl restart: httpd not running, trying to start
[Tue Mar 31 11:27:55 1998] [debug] mod_so.c(303): loaded module foo_module
/path/to/apache/sbin/apachectl restart: httpd started
$ _

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-325428-1-1.html 上篇帖子: Apache模块开发/用C语言扩展apache(2:APR编程介绍) 下篇帖子: apache cxf在线阅读(http://cxf.apache.org/docs/jax-rs.html)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表