信息安全产品开发实践并发服务器ii——多线程

信息安全产品开发实践并发服务器ii——多线程

ID:22714725

大小:409.24 KB

页数:15页

时间:2018-10-31

信息安全产品开发实践并发服务器ii——多线程_第1页
信息安全产品开发实践并发服务器ii——多线程_第2页
信息安全产品开发实践并发服务器ii——多线程_第3页
信息安全产品开发实践并发服务器ii——多线程_第4页
信息安全产品开发实践并发服务器ii——多线程_第5页
资源描述:

《信息安全产品开发实践并发服务器ii——多线程》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、四川大学计算机学院、软件学院实验报告学号:1143111172姓名:_柴承训—专业:_软件工程—班级:_9班_笫7周课程名称实验课时5信息安全产品开发实践实验项S并发服务器II一一多线程实验时间2013.10.25实验目的1)继续了解Linux下C语言程序幵发的过程2)了解线程库Pthreads及提供的基木线程的操作线程的属性,了解线程的属性,线程的互斥和同步3)掌握多线程网络服务器模型4)能在Linux环境实现TCP多线程并发服务器模型5)能编写多线程端口扫描程序实验环境X86,WindowsXP,VMwar

2、eWorkstation5.0.0,RcdHatLinux,SSHSecureShellClient-3.2.9试验题目1修改远程控制程序服务器程序,将其从循环模式或多进程模式修改为多线程模式试验题目2多线程端口扫描程序实现一个多线程端口扫描程序:要求:1.能同时扫描5个IP地址;2.针对每个iP地址,幵设100个线程对其进行扫描;实验内容(算法、程序、步骤和方法)3.如果端口打开,使用函数getservbyport获取其服务名,在屏幕上打印:IPportservername,如果是未知服务,贝1J屏幕显示:i

3、pportunkonown实验一:先来回顾一下上次实验实现的多进程并发服务器:Unix下的大多数网络服务器程序都是这么编写的,即父进程接受连接,派生子进程,子进程处理与客户的交互。虽然这种模型很多年来使用得很好,但是fork时有一些问题:(1)fork是昂贵的。内存映像要从父进程拷贝到子进程,所有描述字要在子进程中复制等等。目前有的Unix实现使用一种叫做写时拷贝(copy-on-write)的技术,可避免父进程数据空间向子进程的拷贝。尽管有这种优化技术,fork仍然是昂贵的;(2)fork子进程后,需要用进程

4、间通信(IPC)在父子进程之间传递信息。Fork之前的信息容易传递,因为子进程从一开始就冇父进程数据空间及所有描述字的拷贝。但是从子进程返回信息给父进程需要做更多的工作。;而上述两个问题可以通过用线程代替进程的方法来克服,接下来我们再来看下进程的一些特点:•线程有助于解决这两个问题。线程有时被称为轻权进程(lightweightprocess),因为线程比进程“轻权”,一般来说,创建一个线程要比创建一个进程快10〜100倍。•一个进程屮的所有线程共享相同的全局A存,这使得线程很容易共享信息,但是这种简易性也带來

5、了同步问题。•一个进程中的所有线程不仅共享全局变量,而且共享:进程指令、大多数数据、打开的文件(如描述字)、信号处理程序和信号处罝、当前工作目录、用户ID和组ID。•但是每个线程冇自己的线程TD、寄存器集合(包括程序计数器和栈指针)、栈(用于存放局部变量和返回地址)、error,信号掩码、优先级。•程序的编译gcc-otesttest.c-lpthread有了这些理论准备之后我们就可以编程來实现我们的多线程并发服务器了。源代码:/Version:1.0*Created:2013骞?9鏈?4鏃?20鏃?9蹂?2绉

6、?*Revision:none*Compiler:gcc氺Filename:udpserver.c氺Description:Thisprogramisusedtodemostratchowtoimplementaudprpcserver*Author:GangLiang氺Organization:ComputerScienceCollege,SichuanUniverstiy氺氺^include^include^include〈string.h>^include

7、ocket.h>^include#include々include^include#include^definePORT8888/^serverport*/defineSIZE2048/*2KBUFFER*/void*startroutine(void*arg);//声明线程处理函数intexec(char*command,char*result){FILE*in;intlcn;charc;l

8、en=0;bzero(result,sizeof(result));in=popen(command,Wif(NULL==in){fprintf(stderr,〃errorincreateapipe〃);return-1;}whi1e(((c=fgetc(in))!=EOF)&&(len

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。