Posts Tagged ‘apache’

11 10 2011

Apache 2.0 中文文档[Directory, Location and Files段]

bigCat Posted in Linux - 0 Comment

原文 http://www.php100.com/html/webkaifa/apache/2009/0418/1193.html\r\n\r\n \r\n\r\n配置段容器的类型 相关模块 core mod_proxy 相关指令 Directory DirectoryMatch Files FilesMatch IfDefine IfModule Location LocationMatch Proxy ProxyMatch VirtualHost 容器有两种基本类型。大多数容器是针对各个请求的,包含于其中的指令仅对与容器配置段容器的类型\r\n\r\n相关模块 core mod_proxy\r\n相关指令 <Directory> <DirectoryMatch> <Files> <FilesMatch> <IfDefine> <IfModule> <Location> <LocationMatch> <Proxy> <ProxyMatch> <VirtualHost>\r\n\r\n容器有两种基本类型。大多数容器是针对各个请求的,包含于其中的指令仅对与容器匹配的请求起作用,而容器<IfDefine>和<IfModule>仅在启动和重新启动中起作用,如果条件成立,则其中的指令有效,否则会被忽略。\r\n\r\n<IfDefine>容器中的指令只有在httpd命令行中设定了适当的参数后才有效。下例中,只有在服务器用httpd -DClosedForNow方式启动时,所有的请求才会被重定向到另一个站点。\r\n\r\n<IfDefine ClosedForNow>\r\nRedirect / http://otherserver.example.com/\r\n</IfDefine>\r\n\r\n<IfModule>容器很相似,但是其中的指令只有当服务器中存在特定的模块时有效,或者是被静态地编译进了服务器,或者是被动态装载进了 服务器,而且,配置文件中其装载指令行LoadModule必须在出现在此容器之前。这个容器应该仅用于你希望无论特定模块装了还是没装,配置文件都能正 常运转的场合;而不应该用于容器中的指令在任何情况下都必须生效的场合,因为它会抑制类似模块没找到的有用的出错信息。\r\n\r\n下例中,MimeMagicFiles指令仅当mod_mime_magic模块存在时才有效。\r\n\r\n<IfModule mod_mime_magic.c>\r\nMimeMagicFile conf/magic\r\n</IfModule>\r\n\r\n<IfDefine>和<IfModule>都可以在条件前加"!"以实现条件的否定,而且都可以嵌套以实现更复杂的限制。\r\n\r\n文件系统和网络空间\r\n\r\n改变一个在文件系统和网络空间的位置的配置段是最常用的。首先必须理解这两个概念的区别,文件系统是在操作系统中所看见的磁盘上的分布,比如,在Unix 文件系统中,Apache会被默认地安装到/usr/local/apache2,在Windows文件系统中,会装到"c:/Program Files/Apache Group/Apache2"(注意:Apache始终用斜杠而不是反斜杠作为路径的分隔符,即使是在Windows中)。相反,网络空间是客户在浏览器 中所看见的站点上的分布,所以网络空间中的路径 /dir/ 对应于Apache在Unix文件系统中的默认安装路径 /usr/local/apache2/htdocs/dir/。由于网页可以从数据库或其他地方动态生成,因此,网络空间无须直接映射到文件系统。\r\n\r\n文件系统容器\r\n<Directory>和<Files>是针对文件系统的指令。<Directory>段中的指令作用于指定的文件 系统目录及其所有子目录,.htaccess 文件可以达到同样的效果。下例中,/var/web/dir1及其所有子目录被允许目录列表。\r\n\r\n<Directory /var/web/dir1>\r\nOptions +Indexes\r\n</Directory>\r\n\r\n<Files>段中的指令作用于特定的文件名,而无论这个文件实际存在于哪个目录。下例中的配置指令如果出现在配置文件的主服务器段,则会拒绝对位于任何目录下的private.html的访问。\r\n\r\n<Files private.html>\r\nOrder allow,deny\r\nDeny from all\r\n</Files>\r\n\r\n<Files>和<Directory>段的组合可以作用于文件系统中的特定文件。下例中的配置会拒绝对\r\n/var/web/dir1/private.html,\r\n/var/web/dir1/subdir2/private.html,\r\n/var/web/dir1/subdir3/private.html\r\n等任何/var/web/dir1/目录下的private.html的访问。\r\n\r\n<Directory /var/web/dir1>\r\n<Files private.html>\r\nOrder allow,deny\r\nDeny from all\r\n</Files>\r\n</Directory>\r\n\r\n网络空间容器\r\n<Location>是针对网络空间的指令。下例中的配置会拒绝任何对以/private开头的URL的访问,如\r\nhttp://yoursite.example.com/private,\r\nhttp://yoursite.example.com/private123,\r\nhttp://yoursite.example.com/private/dir/file.html\r\n等所有以/private开头的URL。\r\n\r\n<Location /private>\r\nOrder Allow,Deny\r\nDeny from all\r\n</Location>\r\n\r\n<Location>指令无须文件系统的支持,下例演示了如何映射特定的URL到由mod_status提供的Apache内部处理器,而并不要求文件系统中确实存在server-status。\r\n\r\n<Location /server-status>\r\nSetHandler server-status\r\n</Location>\r\n\r\n通配符和正则表达式\r\n<Directory>,<Files>, 和<Location>指令可以使用类似C标准库中的fnmatch的外壳通配符。符号"*"匹配任何字符串,"?"匹配任何单个的字符," [seq]" 匹配seq序列中的任何字符,符号"/"不匹配为任何通配符所匹配,所以不能显式使用。\r\n\r\n这些指令都有一个正则的配对指令,<DirectoryMatch>, <FilesMatch>和<LocationMatch>,可以使用与perl一致的正则表达式,以提供更复杂的匹配。但是还 须注意下文配置的合并中有关使用正则表达式会如何作用于配置指令的内容。\r\n\r\n下例使用非正则表达式的通配符来改变所有用户目录的配置:\r\n\r\n<Directory /home/*/public_html>\r\nOptions Indexes\r\n</Directory>\r\n\r\n下例使用正则表达式一次性拒绝对多种图形文件的访问:\r\n\r\n<FilesMatch .(?i:gif|jpe?g|png)$>\r\nOrder allow,deny\r\nDeny from all\r\n</FilesMatch>\r\n\r\n什么情况下用什么\r\n选择使用文件系统容器还是使用网络空间容器其实很简单。当指令应该作用于文件系统时,总是用<Directory>或 者<Files>;而当指令作用于不存在于文件系统的对象时,就用<Location>,比如一个由数据库生成的网页。\r\n\r\n不要试图用<Location>去限制对文件系统中对象的访问,因为许多不同的网络空间路径可能会映射到同一个文件系统目录,导致你的访问限制被突破。比如:\r\n\r\n<Location /dir/>\r\nOrder allow,deny\r\nDeny from all\r\n</Location>\r\n\r\n上述配置对http://yoursite.example.com/dir/请求的确起作用。但是设想在一个不区分大小写的文件系统中,这个访问限制会 被http://yoursite.example.com/DIR/请求轻易突破。而<Directory>指令才会真正作用于对这个位置 的任何形式的请求。(但是有一个例外,就是Unix文件系统中的连接,符号连接可以使同一个目录出现在文件系统中的多个位 置。<Directory>指令能不经过重置路径名而跟随符号连接,因此,对于安全要求最高的,应该用Options指令禁止对符号连接的跟 随。)\r\n\r\n不要认为使用大小写敏感的文件系统就无所谓了,因为有很多方法会将不同的网络空间路径映射为同一个文件系统路径,所以,能使用文件系统容器时就应该使用。 但是,也有一个例外,就是,把访问限制放在<Location/>段中可以很安全地作用于除了某些特定的以外所有的URL。\r\n\r\n虚拟主机\r\n\r\n<VirtualHost>容器作用于特定的主机,对同一个机器上的具有不同配置的多个主机提供支持。详见:虚拟主机文档(Virtual Host Documentation)。\r\n\r\n代理\r\n\r\n<Proxy>和<ProxyMatch>容器中的指令仅作用于指定URL所匹配的通过mod_proxy的代理服务器访问的站点。下例中的配置会拒绝通过代理服务器访问cnn.com站点。\r\n\r\n<Proxy http://cnn.com/*>\r\nOrder allow,deny\r\nDeny from all\r\n</Proxy>\r\n\r\n允许使用的指令\r\n\r\n查阅指令的作用域,就可以知道哪些指令可以出现在哪些段中。从语义上看,允许在<Directory>段中使用的指令当然也可以 在<DirectoryMatch>, <Files>, <FilesMatch>, <Location>, <LocationMatch>, <Proxy>和<ProxyMatch>段中使用,但是有几个例外:\r\n\r\nAllowOverride指令只能出现在<Directory>段中;\r\nOptions中的FollowSymLinks和 SymLinksIfOwnerMatch只能出现在<Directory>段或者.htaccess文件中;\r\nOptions指令不能用于<Files>和<FilesMatch>段。\r\n\r\n配置段的合并\r\n配置段会按非常特别的顺序依次生效,由于这会对配置指令的处理结果产生重大影响,理解它的流程尤为重要。\r\n\r\n合并的顺序是:\r\n\r\n<Directory> (除了正则表达式)和.htaccess同时处理;(如果允许的话,.htaccess的设置会覆盖<Directory>的设置)\r\n<DirectoryMatch> (和<Directory ~>)\r\n<Files>和<FilesMatch>同时处理;\r\n<Location>和<LocationMatch>同时处理;\r\n除了<Directory>,每个组都按它们在配置文件中出现的顺序被依次处理,而<Directory>组,会按字典顺序由短 到长被依次处理。例如,<Directory /var/web/dir>会先于<Directory /var/web/dir/subdir>被处理。如果有多个指向同一个目录的<Directory>段,则按它们在配置文件中的顺序 被依次处理。用Include指令包含进来的设置被视为按原样插入到Include指令的位置。\r\n\r\n位于<VirtualHost>段中的配置段在外部相对应的段处理完毕以后再处理,这样就允许虚拟主机覆盖主服务器的设置。\r\n\r\n后面的段覆盖前面的相应的段。\r\n\r\n技术说明\r\n其实,在名称翻译阶段(即,用Aliases和DocumentRoots来映射URL到文件)之前,会有一个<Location>/<LocationMatch>的序列被处理,而在名称翻译结束后,这个序列的处理结果则被完全抛弃。\r\n一些例子\r\n这是一个假设的演示合并顺序的例子。如果这些指令都起作用,则会按A > B > C > D > E的顺序依次生效。\r\n\r\n<Location />\r\nE\r\n</Location>\r\n\r\n<Files f.html>\r\nD\r\n</Files>\r\n\r\n<VirtualHost *>\r\n<Directory /a/b>\r\nB\r\n</Directory>\r\n</VirtualHost>\r\n\r\n<DirectoryMatch "^.*b$">\r\nC\r\n</DirectoryMatch>\r\n\r\n<Directory /a/b>\r\nA\r\n</Directory>\r\n\r\n在这个更具体的例子中,无论在<Directory>段中加了多少访问限制,由于<Location>段将会被最后处理,从而会允许不加限制的对服务器的访问,可见合并的顺序是很重要的,千万小心!\r\n\r\n<Location />\r\nOrder deny,allow\r\nAllow from all\r\n</Location>\r\n\r\n# Woops! This <Directory> section will have no effect\r\n# 哇呀!这个<Directory>段居然不起作用\r\n<Directory />\r\nOrder allow,deny\r\nAllow from all\r\nDeny from badguy.example.com\r\n</Directory>

29 10 2010

Apache遇到的问题:APR not found

bigCat Posted in Linux - 3 Comments

原文 http://52lamp.net/documents/apache/128956574863.html\r\n\r\n#./configure --prefix……检查编辑环境时出现:\r\n\r\nchecking for APR... no\r\nconfigure: error: APR not found .  Please read the documentation.\r\n\r\n可以用./configure –help | grep apr 查看帮助。\r\n--with-included-apr     Use bundled copies of APR/APR-Util\r\n--with-apr=PATH         prefix for installed APR or the full path to apr-config\r\n--with-apr-util=PATH    prefix for installed APU or the full path to\r\n安装APR(Apache Portable Runtime )\r\n下载:http://apr.apache.org/download.cgi\r\n\r\n#cd /tmp/52lamp/ //源码存放位置\r\n#tar -zxvf apr-1.4.2.tar.gz //unzip -o apr-1.4.2.zip\r\n#cd apr-1.4.2\r\n#./configure\r\n#make\r\n#make install\r\n\r\n再次检查编译环境出现\r\n\r\nchecking for APR-util... no\r\nconfigure: error: APR-util not found .  Please read the documentation.\r\n\r\n#./configure –help | grep apr-util\r\n--with-apr-util=PATH    prefix for installed APU or the full path to\r\n\r\n下载:http://download.chinaunix.net/download/0001000/472.shtml\r\n#tar -zxvf apr-util-1.3.9.tar.gz\r\n#cd apr-util-1.3.9\r\n#./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr\r\n#make\r\n#make install\r\n\r\n./configure仍提示APR-util not found,增加--with-apr=/usr/local/apr --with-apr-util=/usr/local/apr-util后出现\r\nconfigure: error: pcre-config for libpcre not found. PCRE is required and available from http://pcre.org/\r\n\r\n#./configure –help | grep pcre\r\n--with-pcre=PATH        Use external PCRE library\r\n\r\n下载:http://sourceforge.net/projects/pcre\r\n#unzip -o pcre-8.10.zip\r\n#cd pcre-8.10\r\n#./configure --prefix=/usr/local/pcre\r\n#make\r\n#make install\r\n\r\n继续安装Apache/httpd,./configure 时加上参数 --with-apr=/usr/local/apr/ --with-apr-util=/usr/local/apr-util/ --with-pcre=/usr/local/pcre,这个问题就解决了\r\n\r\n注意:Apache在安装时不会检查参数是否正确,错误的参数会直接被丢弃,不会报告给用户。但可以使用echo $?命令检查是否有错误,当输出结果为0时表示没有错误。\r\n\r\n#echo $?\r\n0\r\n\r\n#make\r\n#make install\r\n\r\n复制Apache启动文件\r\n#cp /usr/local/httpd/bin/apachectl /sbin/\r\n\r\n启动Apache\r\n#apachectl start\r\n\r\n设置Apache开机自启动\r\n#vi /etc/rc.d/rc.local\r\n增加一行 /sbin/apachectl start\r\n\r\n或者将httpd服务添加到ntsysv服务管理工具\r\n#apachectl stop //关闭Apache以免不必要的麻烦\r\n#cp /usr/local/httpd/bin/apachectl /etc/rc.d/init.d/httpd\r\n#vi /etc/rc.d/init.d/httpd\r\n修改为\r\n#!/bin/sh\r\n#\r\n#chkconfig: 345 85 15 //#不能省略,注意空格\r\n#description: httpd for 52lamp 20101016 21:54 //任意字符串\r\n#\r\n......\r\n\r\n第二行中345的含义:\r\n#       0 - operation completed successfully\r\n#       1 -\r\n#       2 - usage error\r\n#       3 - httpd could not be started\r\n#       4 - httpd could not be stopped\r\n#       5 - httpd could not be started during a restart\r\n\r\n修改有关权限\r\n#cd /etc/rc.d/init.d/\r\n#chmod a+x httpd\r\n#chkconfig --add httpd\r\n\r\n#ntsysv\r\nhttpd已经在列表中,按F1可以看到刚才编写的服务描述httpd for 52lamp 20101016 21:54。\r\n\r\n#apachectl start\r\n#ps -e |grep httpd\r\n23247 ?        00:00:00 httpd\r\n23248 ?        00:00:00 httpd\r\n23249 ?        00:00:00 httpd\r\n23251 ?        00:00:00 httpd\r\n23252 ?        00:00:00 httpd\r\n\r\n在浏览器中输入127.0.0.1,看起来一切正常;但是局域网内其他电脑不能访问!\r\n\r\n#service iptables stop\r\n\r\n如果不想关闭防火墙,放开80端口即可。\r\n\r\n#vi /etc/sysconfig/iptables\r\n增加一行-A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 22 -j ACCEPT\r\n#service iptables restart //重启防火墙\r\n\r\n现在一切OK

14 10 2010

Linux下安装apache指定安装模块or安装后编译加载其他模块

bigCat Posted in Linux - 0 Comment

http://zydky.javaeye.com/blog/553959\r\n\r\n一、安装apache时同时安装mod_proxy模块\r\n\r\n1.下载apache。\r\n本人下载的是httpd-2.2.12.tar.bz2,保存到了/home/sxs/software下。\r\n\r\n2.解压apache文件\r\n进入/home/sxs/software文件夹,执行:\r\n# tar -xjf httpd-2.2.12.tar.bz2\r\n\r\n将在/home/sxs/software下生成一个httpd-2.2.12文件夹。\r\n\r\n如果下载的文件后缀是tar.gz,需要用如下命令\r\n# tar -xzf httpd-2.2.12.tar.gz\r\n\r\n3.设置安装目录和参数\r\n进入新解压的httpd-2.2.12文件夹,执行:\r\n# ./configure --prefix=/usr/local/apache --enable-so --enable-mods-shared=proxy\r\n(一般网上都是说./configure --prefix=/usr/local/apache,这里是指定安装mod_proxy模块,如何指定其他模块暂时不清楚,但是安装好apache后可以通过第二部分添加模块)\r\n\r\n4.编译部署apache\r\n# make WITH_PROXY_MODULES=yes //(网上文章一般都是直接:make)\r\n# make install\r\n\r\n5.在/usr/local将会看到apache文件夹,打开httpd.conf文件,可以看到:\r\nLoadModule proxy_module modules/mod_proxy.so等代码,在modules文件夹下也可以看到相应的mod_proxy.so文件。\r\n\r\n默认linux下安装apache是不安装mod_proxy等模块的。\r\n\r\n\r\n二、安装apache后编译加载其他模块\r\n\r\n假定现在需要编译加载mod_rewrite.so\r\n\r\n1.进入解压后的apache目录,在第一部分是/home/sxs/software/httpd-2.2.12\r\n\r\n2.找到要编译的文件\r\n# find ./ -name mod_rewrite.c\r\n\r\n3.进入mod_rewrite.c所在目录\r\n# cd modules/mappers\r\n\r\n4.编译mod_rewrite.c\r\n# /usr/local/apache/bin/apxs -c mod_rewrite.c\r\n\r\n5.安装mod_rewrite模块\r\n# /usr/local/apache/bin/apxs -ian rewrite mod_rewrite.la\r\n\r\n注:以上4、5两个步骤也可以合并为一个步骤\r\n# /usr/local/apache/bin/apxs -iac mod_rewrite.c\r\n\r\n\r\n注:\r\napxs是一个为Apache HTTP服务器编译和安装扩展模块的工具,用于编译一个或多个源程序或目标代码文件为动态共享对象,使之可以用由mod_so提供的LoadModule指令在运行时加载到Apache服务器中。\r\n\r\n因此,要使用这个扩展机制,你的平台必须支持DSO特性,而且Apache httpd必须内建了mod_so模块。\r\n\r\napxs工具详细使用见另外的文章《apxs-apache扩展工具》\r\n\r\napxs是一个为Apache HTTP服务器编译和安装扩展模块的工具,用于编译一个或多个源程序或目标代码文件为动态共享对象,使之可以用由mod_so提供的LoadModule指令在运行时加载到Apache服务器中。\r\n\r\n因此,要使用这个扩展机制,你的平台必须支持DSO特性,而且Apache httpd必须内建了mod_so模块。apxs工具能自动探测是否具备这样的条件,你也可以自己用这个命令手动探测:\r\n\r\n$ httpd -l\r\n\r\n该命令的输出列表中应该有mod_so模块。如果所有这些条件均已具备,则可以很容易地借助apxs安装你自己的DSO模块以扩展Apache服务器的功能:\r\n\r\n$ apxs -i -a -c mod_foo.c\r\ngcc -fpic -DSHARED_MODULE -I/path/to/apache/include -c mod_foo.c\r\nld -Bshareable -o mod_foo.so mod_foo.o\r\ncp mod_foo.so /path/to/apache/modules/mod_foo.so\r\nchmod 755 /path/to/apache/modules/mod_foo.so\r\n[activating module 'foo' in /path/to/apache/etc/httpd.conf]\r\n$ apachectl restart\r\n/path/to/apache/sbin/apachectl restart: httpd not running, trying to start\r\n[Tue Mar 31 11:27:55 1998] [debug] mod_so.c(303): loaded module foo_module\r\n/path/to/apache/sbin/apachectl restart: httpd started\r\n$ _\r\n\r\n其中的参数files可以是任何C源程序文件(.c)、目标代码文件(.o)、甚至是一个库(.a)。apxs工具会根据其后缀自动编译C源程序或者连接 目标代码和库。但是,使用预编译的目标代码时,必须保证它们是地址独立代码(PIC),使之能被动态地加载。如果使用GCC编译,则应该使用 -fpic 参数;如果使用其他C编译器,则应该查阅其手册,为apxs使用相应的编译参数。\r\n\r\n有关Apache对DSO的支持的详细信息,可以阅读mod_so文档,或者直接阅读src/modules/standard/mod_so.c源程序。\r\n\r\n语法\r\n\r\napxs -g [ -S name=value ] -n modname\r\n\r\napxs -q [ -S name=value ] query ...\r\n\r\napxs -c [ -S name=value ] [ -o dsofile ] [ -I incdir ] [ -D name=value ] [ -L libdir ] [ -l libname ] [ -Wc,compiler-flags ] [ -Wl,linker-flags ] files ...\r\n\r\napxs -i [ -S name=value ] [ -n modname ] [ -a ] [ -A ] dso-file ...\r\n\r\napxs -e [ -S name=value ] [ -n modname ] [ -a ] [ -A ] dso-file ...\r\n\r\n选项\r\n一般选项\r\n\r\n-n modname\r\n它明确设置了 -i(安装)和 -g(模板生成)选项的模块名称。对 -g 选项,它是必须的;对 -i 选项,apxs工具会根据源代码判断,或(在失败的情况下)按文件名推测出这个模块的名称。\r\n\r\n查询选项\r\n\r\n-q\r\n查询某种apxs设置的信息。该选项的query参数可以是下列一个或多个字符串:CC, CFLAGS, CFLAGS_SHLIB, INCLUDEDIR, LD_SHLIB, LDFLAGS_SHLIB, LIBEXECDIR, LIBS_SHLIB, SBINDIR, SYSCONFDIR, TARGET 。\r\n\r\n这个参数用于手动查询某些设置。比如,要手动处理Apache的C头文件,可以在Makefile中使用:\r\n\r\nINC=-I`apxs -q INCLUDEDIR`\r\n\r\n配置选项\r\n\r\n-S name=value\r\n此选项可以改变apxs的上述设置。\r\n\r\n模板生成选项\r\n\r\n-g\r\n此选项生成一个名为name的子目录(见选项 -n)和其中的两个文件:一个是名为mod_name.c的样板模块源程序,可以用来建立你自己的模块,或是学习使用apxs机制的良好开端;另一个则是对应的Makefile ,用于编译和安装此模块。\r\n\r\nDSO编译选项\r\n\r\n-c\r\n此选项表示需要执行编译操作。它首先会编译C源程序(.c)files为对应的目标代码文件(.o),然后连接这些目标代码和files中其余的目标代码 文件(.o和.a),以生成动态共享对象dsofile 。如果没有指定 -o 选项,则此输出文件名由files中的第一个文件名推测得到,也就是默认为mod_name.so 。\r\n-o dsofile\r\n明确指定所建立的动态共享对象的文件名,它不能从files文件列表中推测得到。如果没有明确指定,则其文件名将为mod_unknown.so 。\r\n-D name=value\r\n此选项直接传递到给编译命令,用于增加自定义的编译变量。\r\n-I incdir\r\n此选项直接传递到给编译命令,用于增加自定义的包含目录。\r\n-L libdir\r\n此选项直接传递到给连接命令,用于增加自定义的库文件目录。\r\n-l libname\r\n此选项直接传递到给连接命令,用于增加自定义的库文件。\r\n-Wc,compiler-flags\r\n此选项用于向编译命令 libtool --mode=compile 中附加compiler-flags ,以增加编译器特有的选项。\r\n-Wl,linker-flags\r\n此选项用于向连接命令 libtool --mode=link 中附加linker-flags ,以增加连接器特有的选项。\r\n\r\nDSO的安装和配置选项\r\n\r\n-i\r\n此选项表示需要执行安装操作,以安装一个或多个动态共享对象到服务器的modules目录中。\r\n-a\r\n此选项自动增加一个LoadModule行到httpd.conf文件中,以激活此模块,或者,如果此行已经存在,则启用之。\r\n-A\r\n与 -a 选项类似,但是它增加的LoadModule命令有一个井号前缀(#),即此模块已经准备就绪但尚未启用。\r\n-e\r\n表示需要执行编辑操作,它可以与 -a 和 -A 选项配合使用,与 -i 操作类似,修改Apache的httpd.conf文件,但是并不安装此模块。\r\n\r\n\r\n举例\r\n\r\n假设有一个扩展Apache功能的模块mod_foo.c ,使用下列命令,可以将C源程序编译为共享模块,以在运行时加载到Apache服务器中:\r\n\r\n$ apxs -c mod_foo.c\r\n/path/to/libtool --mode=compile gcc ... -c mod_foo.c\r\n/path/to/libtool --mode=link gcc ... -o mod_foo.la mod_foo.slo\r\n$ _\r\n\r\n然后,必须修改Apache的配置,以确保有一个LoadModule指令来加载此共享对象。为了简化这一步骤,apxs可以自动进行该操作,以安装此共享对象到"modules"目录,并更新httpd.conf文件,命令如下:\r\n\r\n$ apxs -i -a mod_foo.la\r\n/path/to/instdso.sh mod_foo.la /path/to/apache/modules\r\n/path/to/libtool --mode=install cp mod_foo.la /path/to/apache/modules ... chmod 755 /path/to/apache/modules/mod_foo.so\r\n[activating module 'foo' in /path/to/apache/conf/httpd.conf]\r\n$ _\r\n\r\n如果配置文件中尚不存在,会增加下列的行:\r\n\r\nLoadModule foo_module modules/mod_foo.so\r\n\r\n如果你希望默认禁用此模块,可以使用 -A 选项,即:\r\n\r\n$ apxs -i -A mod_foo.c\r\n\r\n要快速测试apxs机制,可以建立一个Apache模块样板及其对应的Makefile :\r\n\r\n$ apxs -g -n foo\r\nCreating [DIR] foo\r\nCreating [FILE] foo/Makefile\r\nCreating [FILE] foo/modules.mk\r\nCreating [FILE] foo/mod_foo.c\r\nCreating [FILE] foo/.deps\r\n$ _\r\n\r\n然后,立即可以编译此样板模块为共享对象并加载到Apache服务器中:\r\n\r\n$ cd foo\r\n$ make all reload\r\napxs -c mod_foo.c\r\n/path/to/libtool --mode=compile gcc ... -c mod_foo.c\r\n/path/to/libtool --mode=link gcc ... -o mod_foo.la mod_foo.slo\r\napxs -i -a -n "foo" mod_foo.la\r\n/path/to/instdso.sh mod_foo.la /path/to/apache/modules\r\n/path/to/libtool --mode=install cp mod_foo.la /path/to/apache/modules ... chmod 755 /path/to/apache/modules/mod_foo.so\r\n[activating module 'foo' in /path/to/apache/conf/httpd.conf]\r\napachectl restart\r\n/path/to/apache/sbin/apachectl restart: httpd not running, trying to start\r\n[Tue Mar 31 11:27:55 1998] [debug] mod_so.c(303): loaded module foo_module\r\n/path/to/apache/sbin/apachectl restart: httpd started\r\n$ _\r\n\r\nhttp://www.bumao.com/index.php/2009/12/apache-mod_proxy.html\r\n

Apache上编译mod_proxy模块的注意事项

\r\n

Posted in 2009年12月7日 ¬ 10:06 下午h.bumao没有评论 »

\r\n

\r\n\r\n在Linux系统下,需要给已经运行的Apache增加mod_proxy模块,编译的时候应该这样:\r\n\r\napxs -c -i mod_proxy.c proxy_util.c\r\n\r\n否则你可能会收到这样的错误信息\r\n\r\n[root@server1 proxy]# /apache/httpd/bin/apachectl configtest\r\nhttpd: 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: undefined symbol: proxy_lb_workers\r\n\r\n如果你还加载了mod_proxy_ajp.so那应该\r\n\r\napxs -c -i mod_proxy_ajp.c ajp*.c\r\n\r\n[root@server1 proxy]# /apache/httpd/bin/apachectl configtest\r\nhttpd: 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: undefined symbol: ajp_msg_reset\r\n\r\n
5 06 2009

APACHE启用GZIP压缩优化

bigCat Posted in Linux - 2 Comments

如果你想将压缩限制在几种特定的MIME类型上,可以使用AddOutputFilterByType指令。下面的例子仅仅允许对html、css、txt、php、js文档进行压缩:\r\n<IfModule mod_deflate.c>\r\nAddOutputFilterByType DEFLATE text/html text/css text/plain text/xml application/x-httpd-php application/x-javascript\r\n</IfModule>\r\n\r\n更详细的设置:http://lamp.linux.gov.cn/Apache/ApacheMenu/mod/mod_deflate.html\r\n\r\nmediatemple dv 设置\r\n\r\n#\r\n# Deflate output configuration\r\n#\r\nAddOutputFilterByType DEFLATE text/html text/plain text/xml text/css application/x-httpd-php application/x-javascript\r\nBrowserMatch ^Mozilla/4 gzip-only-text/html\r\nBrowserMatch ^Mozilla/4\.0[678] no-gzip\r\nBrowserMatch \bMSIE !no-gzip !gzip-only-text/html\r\n\r\n参考 http://kb.mediatemple.net/questions/1567/Compressing+web+pages+with+mod_deflate

6 04 2009

查看Apache的并发请求数及其TCP连接状态

bigCat Posted in Linux - 0 Comment

查看Apache的并发请求数及其TCP连接状态:\n\n#netstat -n | awk '/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}'\n\n上面这句来自己我一个新浪的朋友张宴.\n\n返回结果示例:\nLAST_ACK 5\nSYN_RECV 30\nESTABLISHED 1597\nFIN_WAIT1 51\nFIN_WAIT2 504\nTIME_WAIT 1057\n其中的SYN_RECV表示正在等待处理的请求数;ESTABLISHED表示正常数据传输状态;TIME_WAIT表示处理完毕,等待超时结束的请求数。\n\n状态:描述\nCLOSED:无连接是活动的或正在进行\nLISTEN:服务器在等待进入呼叫\nSYN_RECV:一个连接请求已经到达,等待确认\nSYN_SENT:应用已经开始,打开一个连接\nESTABLISHED:正常数据传输状态\nFIN_WAIT1:应用说它已经完成\nFIN_WAIT2:另一边已同意释放\nITMED_WAIT:等待所有分组死掉\nCLOSING:两边同时尝试关闭\nTIME_WAIT:另一边已初始化一个释放\nLAST_ACK:等待所有分组死掉\n\n可以使用Linux下的webbench来作压力测试.

Host: (miao) | Word: Press | Code: HTML5