1、作者:冯建,华清远见嵌入式学院讲师。 Boa是一个非常小巧的Web服务器,其可执行代码只有60K左右。它是一个单任务的Web服务器,只能依次完成用户的请求,而不会fork出新的进程处理并发连接请求。但boa支持cgi,能够为cgi程序fork出一个进程来执行。Boa的设计目标是速度和安全,在其站点公布的性能测试中,boa的性能要好于apache服务器。 随着网络技术的迅猛发展,在嵌入式设备的管理和交互中,基于Web方式的应用成为目前的主流,用户可以直接通过远程登录的方式对设备进行管理和维护,大大方便了使用性。下面就为大家讲解一下boa服务器在嵌入式Linux系统中的移植过程。 一、BOA
2、服务器移植 工具链:gcc version 4.3.2 (crosstool-NG-1.8.1-none) 平台: 处理器:s3c2410 内核:linux-2.6.35 1.解压源码 tar xvf boa-0.94.13.tar.tar cd boa-0.94.13 2.进入src/ ./configure 生成Makefile 修改Makefile 修改CC = gcc 为 CC = arm-none-linux-gnueabi-gcc 修改CPP = gcc -E 为 CPP = a
3、rm-none-linux-gnueabi-gcc -E 3.make编译 编译一个linux下的c系统,包含词法和语法分析模块,Linux上用bison和flex。 yacc是一个文法分析器的生成器,bison即是yacc的GNU版本.Lex和YACC是用于构造词法分析机和语法解释器的工具,利用Lex和YACC你可以轻松的构造一个语法解释器。 Apt-get install bison flex 执行make 然后给boa瘦身 Arm-none-linux-gnueabi-strip boa 二、Boa服务器配置 1、 创
4、建目录 mkdir /source/rootfs/etc/boa 2、 将boa源码目录下的boa.conf拷贝到/source/rootfs/etc/boa目录下 cp boa.conf /source/rootfs/etc/boa 3、 修改配置文件boa.conf vim /source/rootfs/etc/boa (1)Group的修改 修改 Group nogroup 为 Group 0 (2)user的修改 修改 User nobody 为 Use
5、r 0 (3)ScriptAlias的修改 修改ScriptAlias /cgi-bin/ /usr/lib/cgi-bin/ 为 ScriptAlias /cgi-bin/ /www/cgi-bin/ (5)DocumentRoot的修改 修改DocumentRoot /var/www 为DocumentRoot /www (6)ServerName的设置 修改#ServerName www.your.org.here 为 ServerName www.your.org.here
6、 否则会出现错误“gethostbyname::No such file or directory” (7)AccessLog修改 修改AccessLog /var/log/boa/access_log 为#AccessLog /var/log/boa/access_log (8)以下配置和boa.conf的配置有关,都是在ARM根文件系统中创建 以下步骤在开发板上进行: 创建HTML文档的主目录/www mkdir /www 创建CGI脚本所在录 /www/cgi-bin
7、 mkdir /www/cgi-bin 当不能使用cgi 时 将#AddType application/x-httpd-cgi cgi改为AddType application/x-httpd-cgi cgi boa器测试 将boa拷贝到开发板根文件系统的/etc/boa下 #cp src/boa /source/rootfs/etc/boa 将ubuntu下/etc/mime.types拷贝到开发板根文件系统的/etc下 #cp /etc/mime.typ
8、es /source/rootfs/etc 将你的主页index.html拷贝到www目录下 运行boa,然后在主机游览器输入开发板网址 [root@farsight boa]# ./boa [30/10/2011:19:10:36 +0000] [root@farsight boa]# boa: server version Boa/0.94.13 [30/10/2011:19:10:36 +0000] boa: server built 10 30 2011 at 19:10:36 [30/10/2
9、011:19:10:36 +0000] boa: starting server pid=968, port 80 附1):boa配置文件参数说明 boa的配置文件是/etc/boa/boa.conf。 Port:boa服务器监听的端口,默认的端口是80。如果端口小于1024,则必须是root用户启动服务器。 Listen:绑定的ip地址。不使用这个参数时,将绑定所有的地址。 User:连接到服务器的客户端的身份,可以是用户名或UID。 Group:连接到服务器的客户端的组,可以是组名或GID。 Se
10、rverAdmin:服务器出故障时要通知的邮箱地址。 ErrorLog:指定错误日志文件。如果路径没有以“/”开始,则相对于ServerRoot路径。没有配置时默认的文件是/dev/stderr。若不想记录日志,指定文件为/dev/null。 AccessLog:设置存取日志文件,与ErrorLog类似。 UseLocaltime:设置使用本地时间,使用UTC时注释这个参数。这个参数没有值。 VerboseCGILogs:在错误日志文件中记录CGI启动和停止时间,若不记录,注释这个参数。这个参数没有值。
11、ServerName:指定服务器的名称,当客户端使用gethostname + gethostbyname时返回给客户端。 VirtualHost:虚拟主机开关。使用此参数,则会在DocumentRoot设定的目录添加一个ip地址作为新的DocumentRoot来 处理客户端的请求。如DocumentRoot设置为/var/www,则http://localhost/ 则转换成/var/www/127.0.0.1/,若注释此参数,则为/var/www/。 DocumentRoot:HTML文件的根目录(也就是网站的目录)。 UserDir:
12、指定用户目录。 DirectoryIndex:指定预生成目录信息的文件,注释此变量将使用DirectoryMaker变量。这个变量也就是设置默认主页的文件名。 DirectoryMaker:指定用于生成目录的程序,注释此变量将不允许列目录。 DirectoryCache:当DirectoryIndex文件不存在,而DirecotryMaker又被注释掉时,将列出这个参数指定目录给客户端。 KeepAliveMax:每个连接允许的请求数量。如果将此值设为" 0 ",将不限制请求的数目。 KeepAliveT
13、imeOut:在关闭持久连接前等待下一个请求的秒数。(秒)。 MimeTypes:设置包含mimetypes信息的文件,一般是/etc/mime.types。 DefaultType:默认的mimetype类型,一般是text/html。 CGIPath:相当于给CGI程序使用的$PATH变量。 SinglePostLimit:一次POST允许最大的字节数,默认是1MB. AddType: 增加MimeType没有指定的类型,例: AddType type extension [extension ...
14、]。要使用cgi,必须添加cgi类型:AddType application/x-httpd-cgi cgi Redirect:重定向文件 Aliases:指定路径的别名。 ScriptAlias:指定脚本路径的虚拟路径。 附2):编译中的出错处理 报错:[01/Jan/1970:00:56:51 +0000] log.c:73 - unable to dup2 the error log: Bad file descriptor 解决:修改 src/log.c 注释掉 if (dup2(error_log, ST
15、DERR_FILENO) == -1) { DIE("unable to dup2 the error log"); } 为: /*if (dup2(error_log, STDERR_FILENO) == -1) { DIE("unable to dup2 the error log"); }*/ 再次执行boa命令 #boa 报错:[0
16、1/Jan/1970:01:01:15 +0000] boa.c:211 - getpwuid: No such file or directory 解决:修改src/boa.c 注释掉下面两句话: if (passwdbuf == NULL) { DIE(”getpwuid”); } if (initgroups(passwdbuf->pw_name, passwdbuf->pw_gid) == -1) { DIE(”initgroup
17、s”); } 为 #if 0 if (passwdbuf == NULL) { DIE(”getpwuid”); } if (initgroups(passwdbuf->pw_name, passwdbuf->pw_gid) == -1) { DIE(”initgroups”); } #en
18、dif 再次运行boa命令 报错:[01/Jan/1970:01:04:24 +0000] boa.c:226 - icky Linux kernel bug!: No such file or directory 解决:src/boa.c if (setuid(0) != -1) { DIE(”icky Linux kernel bug!”); } 为 #if 0 if (setuid(0) != -1) {
19、 DIE(”icky Linux kernel bug!”); } #endif util.c:100:1: error: pasting "t" and "->" does not give a valid preprocessing token make: *** [util.o] Error 1 报错:修改 src/compat.h 找到 #define TIMEZONE_OFFSET(foo) foo##->tm_gmtoff
20、 修改成 #define TIMEZONE_OFFSET(foo) (foo)->tm_gmtoff 1、下载Boa Webserver的源码 http://www.boa.org/boa-0.94.13.tar.gz 2、解压并编译Boa Webserver 编译过程中可能出现错误,部分的错误处理方法 编译时错误处理: 1: 编译需要bison(yacc的GNU版本)和flex,如果没有这2个将报错,因此: $ sudo apt-get install flex bison 2: util.c:100:1: error: pasting "t"
21、and "->" does not give a valid preprocessing token make: *** [util.o] Error 1 解决办法:修改src/compat.h文件。 #define TIMEZONE_OFFSET(foo) foo##->tm_gmtoff 改为 #define TIMEZONE_OFFSET(foo) foo->tm_gmtoff 3: error_log: [24/Mar/2008:16:23:51 +0000] boa.c:226 - icky Linux kernel bug!: Success 解决方法:修改src/
22、boa.c,将下面一段代码注释。 if (setuid(0) != -1) { DIE("icky Linux kernel bug!"); } $ tar -zxvf boa-0.94.13.tar.gz $ cd boa-0.94.13/src/ $ ./configure $ make 3、配置Boa Webserver环境 编译后在boa-0.94.13/src/中有2个二进制文件,那就是我们需要的执行档,只需拷贝到/bin或者/sbin等执行目录里面(建议使用/bin)。同时注意这里的操作权限: $ sudo cp boa/boa-0.94.13/src/b
23、oa /bin $ sudo cp boa-0.94.13/src/boa_indexer /bin Boa Webserver的配置文件是boa.conf。该文件需要被放置在/etc/boa目录下。同时我们需要对boa.conf稍做修改: # mkdir /etc/boa # cp boa/boa-0.94.13/boa.conf /etc/boa # vim /etc/boa/boa.conf a)修改: Group nogroup 为: Group 0 b)修改: ScriptAlias /cgi-bin/ /usr/lib/cgi-bin 为:
24、 ScriptAlias /cgi-bin/ /var/www/cgi-bin 修改Group的参数为0是因为系统中没有nogroup组,如果你没有nobody用户,那么User nobody也要做相应修改(修改成自己的用户名亦可)。其它采用默认设置。如有必要,可以参看<附录>中的参数说明。 建立一些Boa Webserver必要的文件目录: # mkdir -p /var/www/cgi-bin # mkdir -p /var/log/boa 目录/var/www/用于保存HTML文档,而/var/www/cgi-bin用于保存CGI脚本。 目录/var/log/boa是相关的日志文件保存目录。 4、测试 我们也可以做一下Boa CGI测试。拷贝boa-0.94.13/examples/里的cgi-test.cgi脚本文件。 # cp boa-0.94.13/examples/cgi-test.cgi /var/www/cgi-bin 在浏览器中输入: http://[Boa主机IP]/cgi-bin/cgi-test.cgi






