boa服務器移植

1.從http://www.boa.org/下載Boa源碼
    # tar -zxvf boa-0.94.13.tar.gz
    # cd boa-0.94.13/src
2.生成Makefile文件
    # ./configure
    
修改Makefile文件,
a.找到CC=gcc,將其改成CC = mips-linux-gcc,
b.找到CPP = gcc –E,將其改成CPP = mips-linux-gcc –E,
保存退出。
3.運行make進行編譯,得到的可執行程序爲boa,並將調試信息剝去
    # make
    # arm-linux-strip boa
4. cd  boa-0.94.13/
  vim boa.conf(修改配置文件boa.conf)


#監聽的端口號,缺省都是80,一般無需修改
Port 80


# bind調用的IP地址,一般註釋掉,表明綁定到INADDR_ANY,通配於服務器的所有IP地址
#Listen 192.68.0.5
#作爲哪個用戶運行,即它擁有該用戶的權限,一般都是nobody,需
要 /etc/passwd中有nobody用戶
User 0


#作爲哪個用戶組運行,即它擁有該用戶組的權限,一般都是nogroup,需要在/etc/group文件中有nogroup組
Group 0


#當服務器發生問題時發送報警的email地址,目前未用,註釋掉
#ServerAdmin root@localhost
#錯誤日誌文件。如果沒有以/開始,則表示從服務器的根路徑開始。如果不需要錯誤日誌,則用#/dev/null。在下面設置時,注意一定要建立/var/log/boa目錄
 ErrorLog /var/log/boa/error_log


#訪問日誌文件。如果沒有以/開始,則表示從服務器的根路徑開始。如果不需要錯誤日誌,則用#/dev/null或直接註釋掉。在下面設置時,注意一定要建立/var/log/boa目錄
 AccessLog /var/log/boa/access_log


#是否使用本地時間。如果沒有註釋掉,則使用本地時間。註釋掉則使用UTC時間
#UseLocaltime
#是否記錄CGI運行信息,如果沒有註釋掉,則記錄,註釋掉則不記錄
#VerboseCGILogs
#服務器名字
ServerName www.hyesco.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目錄下。




5.cp boa 到開發板的/bin目錄下或者usr/sbin/,在開發板/etc目錄下建boa目錄,cp boa.conf到板子的/etc/boa目錄。
6.創建日誌文件所在目錄/var/log/boa,創建HTML文檔的主目錄/var/www,創建CGI腳本所在目錄/var/www/cgi-bin/,在/var/www中放置一個index.html文件
7.cp mime.types文件到開發板/etc目錄
8.運行boa:
#boa &(後臺運行)
正常啓動會打印信息在/var/log/boa/error_log 中爲
boa: server version Boa/0.94.13
boa: server built Jan 14 2015 at 16:45:00.
boa: starting server pid=12271, port 80


查看開發板的ip 192.169.1.102
然後通過其他機器訪問 192.169.1.102
就可以訪問到你放置的那個index頁面了。
9.編輯hello.c程序測試cgi的運行


#mips-linux-gcc hello.c -o hello.cgi
#cp hello.cgi 到開發板的/var/www/cgi-bin目錄下
在pc機的瀏覽器地址欄輸入http://192.169.1.102/cgi-bin/hello.cgi,可以看到相關頁面,CGI腳本測試通過。




中間遇到的問題及解決辦法
1.終端上error_log中打印
 boa.c:194 - unable to bind: Address already in use
說明端口已經被其它服務器佔用,ps -A 查看所有進程, 我的是 lighttpd 這個進程佔用了,kill 殺死之後,在啓動boa,查看error_log中的信息
或者把boa.conf中的port 80  改成其它未被佔用的端口號


2.網頁上打印
502 Bad Gateway
The CGI was not CGI/1.1 compliant.


同時終端上error_log中打印
 cgi_header: unable to find LFLF


(1)將.cgi文件拷貝至目標板上後,必須改變其權限 chmod 777 *
(2)首先,檢查你的 printf("Content-type: text/html\n\n");是否少了\n;
   其次,也是最大的可能就是你的程序寫錯了。
(3)修改 BOA 源碼 cgi.c 添加環境變量: my_add_cgi_env(req, "LD_LIBRARY_PATH", "/lib");(函數complete_env中) 再重新交叉編譯即可


上述錯誤是在boa原碼中的cgi_header .c文件中的process_cgi_header函數產生,如下:
    buf = req->header_line;
    c = strstr(buf, "\n\r\n");
    if (c == NULL) {
        c = strstr(buf, "\n\n");
        if (c == NULL) {
            log_error_time();
            fputs("cgi_header: unable to find LFLF\n", stderr);  //出錯信息
#ifdef FASCIST_LOGGING
            log_error_time();
            fprintf(stderr, "\"%s\"\n", buf);
#endif
            send_r_bad_gateway(req);
            return 0;
        }
}
我們可以定義FASCIST_LOGGING,使產生該錯誤時將buf內容打印出來,結果如下:
……cgi_header:unable to find LFIF
Content-type: text/html
<html>
<head><title>CGI Output</title></head>
<body>
<hl>Hello, world.</hl>
<body>
</html>
原來buf中的內容就是helloworld.c中輸出的內容,查看輸出結果,再看process_cgi_header函數中的語句:c = strstr(buf, "\n\n"),很明顯buf中沒有兩個連續的換行符"\n\n",所以是helloworld.c文件中的語句:printf("Content-type: text/html\n\n");錯寫成了printf("Content-type: text/html\n");
上述行通過標準輸出將字符串″Contenttype:text/plain\n\n″傳送給Web服務器。它是一個MIME頭信息,告訴Web服務器隨後的輸出是以純ASCII文本的形式。在這個頭信息中有兩個新行符,這是因爲Web服務器需要在實際的文本信息開始之前先看見一個空行。
發佈了35 篇原創文章 · 獲贊 8 · 訪問量 10萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章