<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>OurApache &#187; apxs</title>
	<atom:link href="http://ourapache.com/archives/tag/apxs/feed" rel="self" type="application/rss+xml" />
	<link>http://ourapache.com</link>
	<description>我们致力于一个Apache知识的分享网站</description>
	<lastBuildDate>Tue, 13 Apr 2010 05:18:24 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.2.1</generator>
		<item>
		<title>apxs是Apache编译和安装扩展模块的工具</title>
		<link>http://ourapache.com/archives/251</link>
		<comments>http://ourapache.com/archives/251#comments</comments>
		<pubDate>Sun, 07 Jun 2009 11:28:35 +0000</pubDate>
		<dc:creator>OurApache</dc:creator>
				<category><![CDATA[Apache基础知识]]></category>
		<category><![CDATA[apxs]]></category>
		<category><![CDATA[扩展]]></category>
		<category><![CDATA[编译]]></category>

		<guid isPermaLink="false">http://www.ourapache.com/?p=251</guid>
		<description><![CDATA[apxs是一个为Apache HTTP服务器编译和安装扩展模块的工具，用于编译一个或多个源程序或目标代码文件为动态共享对象，使之可以用由mod_so提供的LoadModule指令在运行时加载到Apache服务器中。

因此，要使用这个扩展机制，你的平台必须支持DSO特性，而且Apache httpd必须内建了mod_so模块。]]></description>
			<content:encoded><![CDATA[<p>apxs是一个为Apache HTTP服务器编译和安装扩展模块的工具，用于编译一个或多个源程序或目标代码文件为动态共享对象，使之可以用由mod_so提供的LoadModule指令在运行时加载到Apache服务器中。</p>
<p>因此，要使用这个扩展机制，你的平台必须支持DSO特性，而且Apache httpd必须内建了mod_so模块。apxs工具能自动探测是否具备这样的条件，你也可以自己用这个命令手动探测：</p>
<p>$ httpd -l</p>
<p>该命令的输出列表中应该有mod_so模块。如果所有这些条件均已具备，则可以很容易地借助apxs安装你自己的DSO模块以扩展Apache服务器的功能：</p>
<blockquote><p>$ <a href="http://ourapache.com/archives/tag/apxs" class="st_tag internal_tag" rel="tag" title="标签 apxs 下的日志">apxs</a> -i -a -c mod_foo.c<br />
gcc -fpic -DSHARED_MODULE -I/path/to/apache/include -c mod_foo.c<br />
ld -Bshareable -o mod_foo.so mod_foo.o<br />
cp mod_foo.so /path/to/apache/modules/mod_foo.so<br />
chmod 755 /path/to/apache/modules/mod_foo.so<br />
[activating module 'foo' in /path/to/apache/etc/httpd.conf]<br />
$ apachectl restart<br />
/path/to/apache/sbin/apachectl restart: httpd not running, trying to start<br />
[Tue Mar 31 11:27:55 1998] [debug] mod_so.c(303): loaded module foo_module<br />
/path/to/apache/sbin/apachectl restart: httpd started<br />
$ _</p></blockquote>
<p>其中的参数files可以是任何C源程序文件(.c)、目标代码文件(.o)、甚至是一个库(.a)。apxs工具会根据其后缀自动编译C源程序或者连接目标代码和库。但是，使用预编译的目标代码时，必须保证它们是地址独立代码(PIC)，使之能被动态地加载。如果使用GCC编译，则应该使用 -fpic 参数；如果使用其他C编译器，则应该查阅其手册，为apxs使用相应的编译参数。</p>
<p>有关Apache对DSO的支持的详细信息，可以阅读mod_so文档，或者直接阅读src/modules/standard/mod_so.c源程序。</p>
<p>语法</p>
<blockquote><p>apxs -g [ -S name=value ] -n modname</p>
<p>apxs -q [ -S name=value ] query &#8230;</p>
<p>apxs -c [ -S name=value ] [ -o dsofile ] [ -I incdir ] [ -D name=value ] [ -L libdir ] [ -l libname ] [ -Wc,compiler-flags ] [ -Wl,linker-flags ] files &#8230;</p>
<p>apxs -i [ -S name=value ] [ -n modname ] [ -a ] [ -A ] dso-file &#8230;</p>
<p>apxs -e [ -S name=value ] [ -n modname ] [ -a ] [ -A ] dso-file &#8230;</p></blockquote>
<p>选项<br />
一般选项<br />
-n modname<br />
它明确设置了 -i(安装)和 -g(模板生成)选项的模块名称。对 -g 选项，它是必须的；对 -i 选项，apxs工具会根据源代码判断，或(在失败的情况下)按文件名推测出这个模块的名称。<br />
查询选项<br />
-q<br />
查询某种apxs设置的信息。该选项的query参数可以是下列一个或多个字符串：CC, CFLAGS, CFLAGS_SHLIB, INCLUDEDIR, LD_SHLIB, LDFLAGS_SHLIB, LIBEXECDIR, LIBS_SHLIB, SBINDIR, SYSCONFDIR, TARGET 。<br />
这个参数用于手动查询某些设置。比如，要手动处理Apache的C头文件，可以在Makefile中使用：</p>
<p>INC=-I`apxs -q INCLUDEDIR`</p>
<p>配置选项<br />
-S name=value<br />
此选项可以改变apxs的上述设置。<br />
模板生成选项<br />
-g<br />
此选项生成一个名为name的子目录(见选项 -n)和其中的两个文件：一个是名为mod_name.c的样板模块源程序，可以用来建立你自己的模块，或是学习使用apxs机制的良好开端；另一个则是对应的Makefile ，用于编译和安装此模块。<br />
DSO编译选项<br />
-c<br />
此选项表示需要执行编译操作。它首先会编译C源程序(.c)files为对应的目标代码文件(.o)，然后连接这些目标代码和files中其余的目标代码文件(.o和.a)，以生成动态共享对象dsofile 。如果没有指定 -o 选项，则此输出文件名由files中的第一个文件名推测得到，也就是默认为mod_name.so 。<br />
-o dsofile<br />
明确指定所建立的动态共享对象的文件名，它不能从files文件列表中推测得到。如果没有明确指定，则其文件名将为mod_unknown.so 。<br />
-D name=value<br />
此选项直接传递到给编译命令，用于增加自定义的编译变量。<br />
-I incdir<br />
此选项直接传递到给编译命令，用于增加自定义的包含目录。<br />
-L libdir<br />
此选项直接传递到给连接命令，用于增加自定义的库文件目录。<br />
-l libname<br />
此选项直接传递到给连接命令，用于增加自定义的库文件。<br />
-Wc,compiler-flags<br />
此选项用于向编译命令 libtool &#8211;mode=compile 中附加compiler-flags ，以增加编译器特有的选项。<br />
-Wl,linker-flags<br />
此选项用于向连接命令 libtool &#8211;mode=link 中附加linker-flags ，以增加连接器特有的选项。<br />
DSO的安装和配置选项<br />
-i<br />
此选项表示需要执行安装操作，以安装一个或多个动态共享对象到服务器的modules目录中。<br />
-a<br />
此选项自动增加一个LoadModule行到httpd.conf文件中，以激活此模块，或者，如果此行已经存在，则启用之。<br />
-A<br />
与 -a 选项类似，但是它增加的LoadModule命令有一个井号前缀(#)，即此模块已经准备就绪但尚未启用。<br />
-e<br />
表示需要执行编辑操作，它可以与 -a 和 -A 选项配合使用，与 -i 操作类似，修改Apache的httpd.conf文件，但是并不安装此模块。<br />
举例<br />
假设有一个扩展Apache功能的模块mod_foo.c ，使用下列命令，可以将C源程序编译为共享模块，以在运行时加载到Apache服务器中：</p>
<blockquote><p>$ apxs -c mod_foo.c<br />
/path/to/libtool &#8211;mode=compile gcc &#8230; -c mod_foo.c<br />
/path/to/libtool &#8211;mode=link gcc &#8230; -o mod_foo.la mod_foo.slo<br />
$ _</p></blockquote>
<p>然后，必须修改Apache的配置，以确保有一个LoadModule指令来加载此共享对象。为了简化这一步骤，apxs可以自动进行该操作，以安装此共享对象到”modules”目录，并更新httpd.conf文件，命令如下：</p>
<blockquote><p>$ apxs -i -a mod_foo.la<br />
/path/to/instdso.sh mod_foo.la /path/to/apache/modules<br />
/path/to/libtool &#8211;mode=install cp mod_foo.la /path/to/apache/modules &#8230; chmod 755 /path/to/apache/modules/mod_foo.so<br />
[activating module 'foo' in /path/to/apache/conf/httpd.conf]<br />
$ _</p></blockquote>
<p>如果配置文件中尚不存在，会增加下列的行：</p>
<p>LoadModule foo_module modules/mod_foo.so</p>
<p>如果你希望默认禁用此模块，可以使用 -A 选项，即：</p>
<p>$ apxs -i -A mod_foo.c</p>
<p>要快速测试apxs机制，可以建立一个Apache模块样板及其对应的Makefile ：</p>
<blockquote><p>$ apxs -g -n foo<br />
Creating [DIR] foo<br />
Creating [FILE] foo/Makefile<br />
Creating [FILE] foo/modules.mk<br />
Creating [FILE] foo/mod_foo.c<br />
Creating [FILE] foo/.deps<br />
$ _</p></blockquote>
<p>然后，立即可以编译此样板模块为共享对象并加载到Apache服务器中：</p>
<blockquote><p>$ cd foo<br />
$ make all reload<br />
apxs -c mod_foo.c<br />
/path/to/libtool &#8211;mode=compile gcc &#8230; -c mod_foo.c<br />
/path/to/libtool &#8211;mode=link gcc &#8230; -o mod_foo.la mod_foo.slo<br />
apxs -i -a -n “foo” mod_foo.la<br />
/path/to/instdso.sh mod_foo.la /path/to/apache/modules<br />
/path/to/libtool &#8211;mode=install cp mod_foo.la /path/to/apache/modules &#8230; chmod 755 /path/to/apache/modules/mod_foo.so<br />
[activating module 'foo' in /path/to/apache/conf/httpd.conf]<br />
apachectl restart<br />
/path/to/apache/sbin/apachectl restart: httpd not running, trying to start<br />
[Tue Mar 31 11:27:55 1998] [debug] mod_so.c(303): loaded module foo_module<br />
/path/to/apache/sbin/apachectl restart: httpd started<br />
$ _</p></blockquote>
<h3  class="related_post_title">相关文章</h3><ul class="related_post"><li>2008年12月27号 -- <a href="http://ourapache.com/archives/11" title="apxs &#8211; Apache 扩展工具">apxs &#8211; Apache 扩展工具</a></li><li>2009年08月13号 -- <a href="http://ourapache.com/archives/286" title="linux下查看nginx，apache，mysql，php的编译参数">linux下查看nginx，apache，mysql，php的编译参数</a></li><li>2009年02月17号 -- <a href="http://ourapache.com/archives/142" title="在64位机器上关于Apache 2.2.3版的编译问题">在64位机器上关于Apache 2.2.3版的编译问题</a></li><li>2008年12月27号 -- <a href="http://ourapache.com/archives/13" title="单独编译apache的rewrite模块">单独编译apache的rewrite模块</a></li></ul>
	标签：<a href="http://ourapache.com/archives/category/basic" title="Apache基础知识" rel="tag">Apache基础知识</a>, <a href="http://ourapache.com/archives/tag/apxs" title="apxs" rel="tag">apxs</a>, <a href="http://ourapache.com/archives/tag/%e6%89%a9%e5%b1%95" title="扩展" rel="tag">扩展</a>, <a href="http://ourapache.com/archives/tag/%e7%bc%96%e8%af%91" title="编译" rel="tag">编译</a><br />
]]></content:encoded>
			<wfw:commentRss>http://ourapache.com/archives/251/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>apxs &#8211; Apache 扩展工具</title>
		<link>http://ourapache.com/archives/11</link>
		<comments>http://ourapache.com/archives/11#comments</comments>
		<pubDate>Sat, 27 Dec 2008 15:30:44 +0000</pubDate>
		<dc:creator>OurApache</dc:creator>
				<category><![CDATA[Apache高级应用]]></category>
		<category><![CDATA[apxs]]></category>
		<category><![CDATA[扩展]]></category>

		<guid isPermaLink="false">http://www.ourapache.com/?p=11</guid>
		<description><![CDATA[apxs是一个为Apache HTTP服务器编译和安装扩展模块的工具，用于编译一个或多个源程序或目标代码文件为动态共享对象，使之可以用由mod_so提供的LoadModule指令在运行时加载到Apache服务器中。
因此，要使用这个扩展机制，你的平台必须支持DSO特性，而且Apache httpd必须内建了mod_so模块。apxs工具能自动探测是否具备这样的条件。]]></description>
			<content:encoded><![CDATA[<p>apxs是一个为Apache HTTP服务器编译和安装扩展模块的工具，用于编译一个或多个源程序或目标代码文件为动态共享对象，使之可以用由mod_so提供的LoadModule指令在运行时加载到Apache服务器中。</p>
<p>因此，要使用这个扩展机制，你的平台必须支持DSO特性，而且Apache httpd必须内建了mod_so模块。apxs工具能自动探测是否具备这样的条件，你也可以自己用这个命令手动探测：</p>
<p>$ httpd -l</p>
<p>该命令的输出列表中应该有mod_so模块。如果所有这些条件均已具备，则可以很容易地借助apxs安装你自己的DSO模块以扩展Apache服务器的功能：</p>
<p>$ <a href="http://ourapache.com/archives/tag/apxs" class="st_tag internal_tag" rel="tag" title="标签 apxs 下的日志">apxs</a> -i -a -c mod_foo.c<br />
gcc -fpic -DSHARED_MODULE -I/path/to/apache/include -c mod_foo.c<br />
ld -Bshareable -o mod_foo.so mod_foo.o<br />
cp mod_foo.so /path/to/apache/modules/mod_foo.so<br />
chmod 755 /path/to/apache/modules/mod_foo.so<br />
[activating module 'foo' in /path/to/apache/etc/httpd.conf]<br />
$ apachectl restart<br />
/path/to/apache/sbin/apachectl restart: httpd not running, trying to start<br />
[Tue Mar 31 11:27:55 1998] [debug] mod_so.c(303): loaded module foo_module<br />
/path/to/apache/sbin/apachectl restart: httpd started<br />
$ _</p>
<p>其中的参数files可以是任何C源程序文件(.c)、目标代码文件(.o)、甚至是一个库(.a)。apxs工具会根据其后缀自动编译C源程序或者连接目标代码和库。但是，使用预编译的目标代码时，必须保证它们是地址独立代码(PIC)，使之能被动态地加载。如果使用GCC编译，则应该使用 -fpic 参数；如果使用其他C编译器，则应该查阅其手册，为apxs使用相应的编译参数。</p>
<p>有关Apache对DSO的支持的详细信息，可以阅读mod_so文档，或者直接阅读src/modules/standard/mod_so.c源程序。<br />
<span style="font-size: large;">语法</span><br />
apxs -g [ -S name=value ] -n modname</p>
<p>apxs -q [ -S name=value ] query &#8230;</p>
<p>apxs -c [ -S name=value ] [ -o dsofile ] [ -I incdir ] [ -D name=value ] [ -L libdir ] [ -l libname ] [ -Wc,compiler-flags ] [ -Wl,linker-flags ] files &#8230;</p>
<p>apxs -i [ -S name=value ] [ -n modname ] [ -a ] [ -A ] dso-file &#8230;</p>
<p>apxs -e [ -S name=value ] [ -n modname ] [ -a ] [ -A ] dso-file &#8230;</p>
<p><span style="font-size: large;">一般选项</span><br />
-n modname<br />
它明确设置了 -i(安装)和 -g(模板生成)选项的模块名称。对 -g 选项，它是必须的；对 -i 选项，apxs工具会根据源代码判断，或(在失败的情况下)按文件名推测出这个模块的名称。<br />
查询选项<br />
-q<br />
查询某种apxs设置的信息。该选项的query参数可以是下列一个或多个字符串：CC, CFLAGS, CFLAGS_SHLIB, INCLUDEDIR, LD_SHLIB, LDFLAGS_SHLIB, LIBEXECDIR, LIBS_SHLIB, SBINDIR, SYSCONFDIR, TARGET 。<br />
这个参数用于手动查询某些设置。比如，要手动处理Apache的C头文件，可以在Makefile中使用：</p>
<p>INC=-I`apxs -q INCLUDEDIR`</p>
<p><span style="font-size: large;">配置选项</span><br />
-S name=value<br />
此选项可以改变apxs的上述设置。<br />
模板生成选项<br />
-g<br />
此选项生成一个名为name的子目录(见选项 -n)和其中的两个文件：一个是名为mod_name.c的样板模块源程序，可以用来建立你自己的模块，或是学习使用apxs机制的良好开端；另一个则是对应的Makefile ，用于编译和安装此模块。<br />
DSO编译选项<br />
-c<br />
此选项表示需要执行编译操作。它首先会编译C源程序(.c)files为对应的目标代码文件(.o)，然后连接这些目标代码和files中其余的目标代码文件(.o和.a)，以生成动态共享对象dsofile 。如果没有指定 -o 选项，则此输出文件名由files中的第一个文件名推测得到，也就是默认为mod_name.so 。<br />
-o dsofile<br />
明确指定所建立的动态共享对象的文件名，它不能从files文件列表中推测得到。如果没有明确指定，则其文件名将为mod_unknown.so 。<br />
-D name=value<br />
此选项直接传递到给编译命令，用于增加自定义的编译变量。<br />
-I incdir<br />
此选项直接传递到给编译命令，用于增加自定义的包含目录。<br />
-L libdir<br />
此选项直接传递到给连接命令，用于增加自定义的库文件目录。<br />
-l libname<br />
此选项直接传递到给连接命令，用于增加自定义的库文件。<br />
-Wc,compiler-flags<br />
此选项用于向编译命令 libtool &#8211;mode=compile 中附加compiler-flags ，以增加编译器特有的选项。<br />
-Wl,linker-flags<br />
此选项用于向连接命令 libtool &#8211;mode=link 中附加linker-flags ，以增加连接器特有的选项。<br />
DSO的安装和配置选项<br />
-i<br />
此选项表示需要执行安装操作，以安装一个或多个动态共享对象到服务器的modules目录中。<br />
-a<br />
此选项自动增加一个LoadModule行到httpd.conf文件中，以激活此模块，或者，如果此行已经存在，则启用之。<br />
-A<br />
与 -a 选项类似，但是它增加的LoadModule命令有一个井号前缀(#)，即此模块已经准备就绪但尚未启用。<br />
-e<br />
表示需要执行编辑操作，它可以与 -a 和 -A 选项配合使用，与 -i 操作类似，修改Apache的httpd.conf文件，但是并不安装此模块。</p>
<p><span style="font-size: large;">举例</span><br />
假设有一个扩展Apache功能的模块mod_foo.c ，使用下列命令，可以将C源程序编译为共享模块，以在运行时加载到Apache服务器中：</p>
<p>$ apxs -c mod_foo.c<br />
/path/to/libtool &#8211;mode=compile gcc &#8230; -c mod_foo.c<br />
/path/to/libtool &#8211;mode=link gcc &#8230; -o mod_foo.la mod_foo.slo<br />
$ _</p>
<p>然后，必须修改Apache的配置，以确保有一个LoadModule指令来加载此共享对象。为了简化这一步骤，apxs可以自动进行该操作，以安装此共享对象到”modules”目录，并更新httpd.conf文件，命令如下：</p>
<p>$ apxs -i -a mod_foo.la<br />
/path/to/instdso.sh mod_foo.la /path/to/apache/modules<br />
/path/to/libtool &#8211;mode=install cp mod_foo.la /path/to/apache/modules &#8230; chmod 755 /path/to/apache/modules/mod_foo.so<br />
[activating module 'foo' in /path/to/apache/conf/httpd.conf]<br />
$ _</p>
<p>如果配置文件中尚不存在，会增加下列的行：</p>
<p>LoadModule foo_module modules/mod_foo.so</p>
<p>如果你希望默认禁用此模块，可以使用 -A 选项，即：</p>
<p>$ apxs -i -A mod_foo.c</p>
<p>要快速测试apxs机制，可以建立一个Apache模块样板及其对应的Makefile ：</p>
<p>$ apxs -g -n foo<br />
Creating [DIR] foo<br />
Creating [FILE] foo/Makefile<br />
Creating [FILE] foo/modules.mk<br />
Creating [FILE] foo/mod_foo.c<br />
Creating [FILE] foo/.deps<br />
$ _</p>
<p>然后，立即可以编译此样板模块为共享对象并加载到Apache服务器中：</p>
<p>$ cd foo<br />
$ make all reload<br />
apxs -c mod_foo.c<br />
/path/to/libtool &#8211;mode=compile gcc &#8230; -c mod_foo.c<br />
/path/to/libtool &#8211;mode=link gcc &#8230; -o mod_foo.la mod_foo.slo<br />
apxs -i -a -n “foo” mod_foo.la<br />
/path/to/instdso.sh mod_foo.la /path/to/apache/modules<br />
/path/to/libtool &#8211;mode=install cp mod_foo.la /path/to/apache/modules &#8230; chmod 755 /path/to/apache/modules/mod_foo.so<br />
[activating module 'foo' in /path/to/apache/conf/httpd.conf]<br />
apachectl restart<br />
/path/to/apache/sbin/apachectl restart: httpd not running, trying to start<br />
[Tue Mar 31 11:27:55 1998] [debug] mod_so.c(303): loaded module foo_module<br />
/path/to/apache/sbin/apachectl restart: httpd started<br />
$ _</p>
<h3  class="related_post_title">相关文章</h3><ul class="related_post"><li>2009年06月7号 -- <a href="http://ourapache.com/archives/251" title="apxs是Apache编译和安装扩展模块的工具">apxs是Apache编译和安装扩展模块的工具</a></li></ul>
	标签：<a href="http://ourapache.com/archives/category/advanced" title="Apache高级应用" rel="tag">Apache高级应用</a>, <a href="http://ourapache.com/archives/tag/apxs" title="apxs" rel="tag">apxs</a>, <a href="http://ourapache.com/archives/tag/%e6%89%a9%e5%b1%95" title="扩展" rel="tag">扩展</a><br />
]]></content:encoded>
			<wfw:commentRss>http://ourapache.com/archives/11/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>

