找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 2387|回復(fù): 0
打印 上一主題 下一主題
收起左側(cè)

網(wǎng)絡(luò)服務(wù)器的項(xiàng)目總結(jié)

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:72008 發(fā)表于 2015-1-11 23:41 | 只看該作者 回帖獎勵 |倒序?yàn)g覽 |閱讀模式
萬惡的網(wǎng)絡(luò)服務(wù)器的項(xiàng)目做完了,昨晚調(diào)試好程序之后,感覺自己又老了一大截,就像阿科一直說的那樣,IT男傷不起啊。
本次項(xiàng)目是網(wǎng)絡(luò)終端管理系統(tǒng),程序代碼不多,就是網(wǎng)絡(luò)協(xié)議,線程等把人都快搞瘋了。項(xiàng)目很簡單,做一個網(wǎng)絡(luò)服務(wù)器,有服務(wù)端和客戶端,客戶端連接上服務(wù)器之后,能夠注冊登錄,多客戶端連接,有心跳機(jī)制,有配置文件,客戶端發(fā)送shell命令能夠在客戶端顯示,客戶端有聊天功能,類似QQ,所有日志文件和聊天信息均保存。
這次項(xiàng)目沒有規(guī)劃好時間,起初很快就把基本的框架和注冊登錄寫好了,后來幾天沒有做多少東西,一直以為時間還多,等到最后真的是不夠了哇。昨天還和理武兄去上海植物園逛了一圈;貋砝^續(xù)寫代碼,一直到凌晨兩點(diǎn)。
第一個問題是shell 命令,起初shell命令寫好了,重定向到客戶端屏幕顯示正常,輸入ls的時候可以用,但是pstree –p的時候就不行了,經(jīng)檢查后當(dāng)發(fā)現(xiàn)邏輯有一定問題,緩存空間太小,必須循環(huán)讀取數(shù)據(jù)。后來雖然是能夠循環(huán)讀寫了,但是忘記加結(jié)束符’\0’,命令顯示也不正常。
第二個問題是心跳機(jī)制,所謂心跳機(jī)制就是客戶端連接服務(wù)器之后,隔一段時間向服務(wù)器發(fā)送一個信號,表示該用戶在線,當(dāng)用戶意外退出或者無操作時,服務(wù)器端的心跳處理函數(shù)開始處理,定時器時間到了就會把客戶端用戶置為不在線狀態(tài)。我想了一個很簡單的辦法,在用戶鏈表里面設(shè)了一個heart,注冊時置-1,正常退出置-1,在客戶端用alarm函數(shù),循環(huán)向服務(wù)器發(fā)信號,如果服務(wù)器收到信號,就將heart置為10,服務(wù)器心跳處理函數(shù)就是當(dāng)heart10時,用戶在線正常,當(dāng)heart>0時,heart1heart=0時用戶離線成功。服務(wù)器也是用alarm函數(shù)循環(huán)處理心跳。
第三個問題是線程,起初客戶端只開了兩個線程,其中一個線程只處理聊天信息,但是在退出聊天的時候,無法正常退出。當(dāng)時我在想,主線程和子線程應(yīng)該是同時讀取服務(wù)器發(fā)來的信號,后來經(jīng)過我很多次的實(shí)驗(yàn),發(fā)現(xiàn)在子線程發(fā)給服務(wù)器的信號,只有子線程能接收到,這樣我就想了一個辦法,先結(jié)束子線程,再用pthread_join回收子線程資源,然后在主線程發(fā)送一個信號給服務(wù)器,這樣主線程就能讀取到服務(wù)器的信號了。后來我用了三個線程,兩級菜單兩個線程,處理聊天信息一個線程,其中一個我用了return結(jié)束子線程,還有一個用了pthread_exit結(jié)束子線程,都成功了。不知道我的想法對不對。
pthread_join的作用:使一個線程等待另一個線程結(jié)束。代碼中如果沒有pthread_join主線程會很快結(jié)束從而使整個進(jìn)程結(jié)束,從而使創(chuàng)建的線程沒有機(jī)會開始執(zhí)行就結(jié)束了。加入pthread_join后,主線程會一直等待直到等待的線程結(jié)束自己才結(jié)束,使創(chuàng)建的線程有機(jī)會執(zhí)行。
第四個問題是保存和讀取文件的問題。以前做項(xiàng)目都是保存二進(jìn)制文件,這次保存日志文件和讀取配置文件。經(jīng)百度之后知道了操作文本文件的辦法。保存代碼:
printffd,”%s”,buf);
printffd,”%d”,i);
fprintf用法和printf用法一樣,多了一個文件描述符。
讀取代碼如下:
FILE *fp;
fp = fopen(“./ip”,”r”);
while(!feof(fp))
       ipbuf[i++]=getc(fp);
       ipbuf[i-2]= ‘\0’;
fopen第一個參數(shù)是文件路徑。ipbuf里面存放的就是ip文件的數(shù)據(jù)。
第五個問題是獲取系統(tǒng)時間,保存日志文件時,保存項(xiàng)目有ip、用戶、操作、操作時間。操作時間就是系統(tǒng)時間咯,代碼如下:
#include<time.h>
#include<stdio.h>
char *buf = NULL;
time_t now;
struct tm *timenow;
time(&now);
timenow=localtime(&now);
printf("time : %s\n",asctime(timenow));
buf = asctime(timenow);
printf("buf:%s\n",buf);
第六點(diǎn)就是字節(jié)序?qū)R問題。到現(xiàn)在還不是很理解,需要在再深入理解一下。
軟件運(yùn)行暫時能夠?qū)崿F(xiàn)項(xiàng)目的要求。這次沒做好的很重要的一點(diǎn)就是,沒有時間寫代碼注釋了,代碼存放得相當(dāng)亂,因?yàn)樾薷牧撕芏啻,宏定義和函數(shù)名、變量名等取名很垃圾。網(wǎng)絡(luò)數(shù)據(jù)包傳送的無用東西太多,為了圖方便,所有信息全部存在了數(shù)據(jù)包里面,占用了大量的網(wǎng)絡(luò)資源。還有一個重要的問題是線程沒有做同步浪費(fèi)了內(nèi)核資源。

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復(fù)

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

手機(jī)版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表