Boa服务器在ARM+Linux上的移植

来源:互联网 发布:大唐通讯科技软件 编辑:程序博客网 时间:2024/05/15 05:27

一、Boa服务器介绍

Boa是一种非常小巧的Web服务器,其可执行代码只有大约60KB左右。

作为一种单任务Web服务器,Boa只能依次完成用户的请求,而不会fork出新的进程来处理并发连接请求。但Boa支持CGI,能够为CGI程序fork出一个进程来执行。Boa的设计目标是速度和安全。

二、移植环境

(1) 源码的获取

Boa的源码可以从网站www.boa.org获取

(2) Boa移植平台

 PC机(RedHat9.0操作系统)

 交叉编译工具,arm-linux,最好是2.9的

三、移植步骤

(1)  解压源码$ tar xzvf boa-0.94-14.tar.gz

(2)  $cd boa-0.94-14 目录下,进入src目录中

(3)  ./configure 配置安装文件,自动根据Makefile.in 生成Makefile文件

(4)  生成的Makefile文件是针对X86平台的,为了生成能够在ARM上运行的boa,

需要修改Makefile文件,用vi或则gedit修改Makefile文件中的CC = CC ;CPP = CC –E修改为自己的交叉编译器如:

CC = arm-linux-gcc ;和CC = arm-linux-gcc –E(这是在交叉编译器环境变量配置好的情况下,如果没有配置好,需要把路径填写完整)

(5)  然后执行make,生成可执行程序boa,就在src目录下面,后面就要用到这个可执行程序。


三、Boa.conf文件分析

 

在Boa源码目录下已有一个示例boa.conf,可以在其基础上进行修改,下面解释一下该文件的含义:

#监听的端口号,缺省都是80,一般无需修改注意,如果你你的httpd服务时已经开启,那么你必须关掉或者重新设定端口号,当你修改了模式http端口那么访问的时候要加上端口号,如http://192.168.0.2:1100

Port 80

# bind调用的IP地址,一般注释掉,表明绑定到INADDR_ANY,通配于服务器的所有IP地址,

#Listen 192.68.0.5

#作为哪个用户运行,即它拥有该用户的权限,一般都是nobody,需

要 /etc/passwd中有nobody用户

User nobody

#作为哪个用户组运行,即它拥有该用户组的权限,一般都是nogroup,需要在/etc/group文件中有nogroup组

Group nogroup

#当服务器发生问题时发送报警的email地址,目前未用,注释掉

#ServerAdmin root@localhost

#错误日志文件。如果没有以/开始,则表示从服务器的根路径开始。如果不需要错误日志,则用#/dev/null。在下面设置时,注意一定要建立/var/log/boa目录,也可以将其注释掉否则为出现Can’t open /var/log/boa/error_log错误

ErrorLog /var/log/boa/error_log

#访问日志文件。如果没有以/开始,则表示从服务器的根路径开始。如果不需要错误日志,则用#/dev/null或直接注释掉。(在这里我遇到的问题是,cannot open /usr/boa/log/boa/access_log for logging,permission denied.<前面的路径是我定义的路径,大家依据自己的情况作适当修改>这是权限不足的问题,可是其它的方法我都试了一遍,也没有成功,最好把AcessLog /usr/boa/log/boa/access_log前面加个#号,也就是注掉,如下面,问题就解决了)                        在下面设置时,注意一定要建立/var/log/boa目录,也可以将其注释掉否则会出错

#AccessLog /var/log/boa/access_log

#是否使用本地时间。如果没有注释掉,则使用本地时间。注释掉则使用UTC时间

#UseLocaltime

#是否记录CGI运行信息,如果没有注释掉,则记录,注释掉则不记录

#VerboseCGILogs

#服务器名字

ServerName www.shuzhengfeng.com

#是否启动虚拟主机功能,即设备可以有多个网络接口,每个接口都可以拥有一个虚拟的Web服务器。一般注释掉,即不需要启动
#VirtualHost

#非常重要,HTML文档的主目录。如果没有以/开始,则表示从服务器的根路径开始。注意,如果此处设置不正确,将不能打开网页

DocumentRoot /var/www

#如果收到一个用户请求的话,在用户主目录后再增加的目录名

UserDir public_html

#HTML目录索引的文件名,也是没有用户只指明访问目录时返回的文件名

DirectoryIndex index.html

#当HTML目录没有索引文件时,用户只指明访问目录时,boa会调用该程序生成索引文件然后返回给用户,因为该过程比较慢最好不执行,可以注释掉或者给每个HTML目录加上DirectoryIndex指明的文件

#DirectoryMaker /usr/lib/boa/boa_indexer

#如果DirectoryIndex不存在,并且DirectoryMaker被注释,那么就用Boa自带的索引生成程序来生成目录的索引文件并输出到下面目录,该目录必须是Boa能读写

# DirectoryCache /var/spool/boa/dircache

#一个连接所允许的HTTP持续作用请求最大数目,注释或设为0都将关闭HTTP持续作用

KeepAliveMax 1000

#HTTP持续作用中服务器在两次请求之间等待的时间数,以秒为单位,超时将关闭连接

KeepAliveTimeout 10

#指明mime.types文件位置。如果没有以/开始,则表示从服务器的根路径开始。可以注释掉避免使用mime.types文件,此时需要用AddType在本文件里指明

MimeTypes /etc/mime.types

#文件扩展名没有或未知的话,使用的缺省MIME类型

DefaultType text/plain

#提供CGI程序的PATH环境变量值

CGIPath /bin:/usr/bin:/usr/local/bin

#将文件扩展名和MIME类型关联起来,和mime.types文件作用一样。如果用mime.types
#文件,则注释掉,如果不使用mime.types文件,则必须使用

#AddType application/x-httpd-cgi cgi

#指明文档重定向路径

#Redirect /bar http://elsewhere/feh/bar

#为路径加上别名

Alias /doc /usr/doc

#非常重要,指明CGI脚本的虚拟路径对应的实际路径。一般所有的CGI脚本都要放在实际路径里,用户访问执行时输入站点+虚拟路径+CGI脚本名

ScriptAlias /cgi-bin/ /var/www/cgi-bin/

   用户可以根据自己需要,对boa.conf进行修改,但必须要保证其他的辅助文件和设置必须和boa.conf里的配置相符,不然Boa就不能正常工作。在上面的例子中,我们还需要创建日志文件所在目录/var/log/boa,创建HTML文档的主目录/var/www,将mime.types文件拷贝到/etc目录,创建CGI脚本所在目录/var/www/cgi-bin/。mime.types文件用来指明不同文件扩展名对应的MIME类型,一般可以直接从Linux主机上拷贝一个,大部分也都是在主机的/etc目录下。

四、源码修改

第一、   修改boa-0.94-14/src目录下面的defines.h里的

#ifndef SERVER_ROOT

#define SERVER_ROOT "/etc/boa"

#endif,

"/etc/boa"该路径为boa.conf存放的路径。

第二、   修改boa.conf文件

(1)       Group nogroup

Group nogroup—>改为Group nobody

(2)   DoucmentRoot的修改

修改DoucmentRoot /var/www ,为存放网页的路径

第三、   运行Boa

./Boa

出现boa:server version Boa/0.94.14

     boa: server built Sep 15 2009 at 01:02:14

            boa: starting server pid=14390 ,port 80

五、服务器测试以及网页编写

(1)测试

打开Mozilla浏览器,输入自己的IP地址如:192.168.0.2 就可以打开网页。

(2)简单网页的编写网页

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=gb2312">

<title> Web服务器测试页面</title>

</head>

<body>

Hello veryone!!!!!!!!!!!!!!!!!!!!!!!!

</body>

</html>

六、可能出错及修正

(1) 会出现错误:util.c:100:1: error: pasting "t" and "->" does not give a valid preprocessing token make: *** [util.o] 错误 1

修改 src/compat.h

#define TIMEZONE_OFFSET(foo) foo##->tm_gmtoff

修改成

#define TIMEZONE_OFFSET(foo) (foo)->tm_gmtoff

  

(2) 会出现错误log.c:73 unable to dup2 the error log:bad file descriptor

修改 src/log.c注释掉

  if (dup2(error_log, STDERR_FILENO) == -1) {

  DIE("unable to dup2 the error log");

  }

  为:

  

(3) 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(”initgroups”);

  }为

  #if 0

  if (passwdbuf == NULL) {

  DIE(”getpwuid”);

  }

  if (initgroups(passwdbuf->pw_name, passwdbuf->pw_gid) == -1) {

  DIE(”initgroups”);

  }

  #endif

(4)会出现问题:boa.c:228 - icky Linux kernel bug!: No such file or directory

注释掉下面语句:

  if (setuid(0) != -1) {

  DIE(”icky Linux kernel bug!”);

  }为

  #if 0

  if (setuid(0) != -1) {

  DIE(”icky Linux kernel bug!”);

  }

  #endif