分类: LINUX
2011-11-29 09:36:21
网络协议
OSI 与 UNIX系统中协议的对应关系图,及不同网络在OSI中的位置
OSI 开放式系统互联参考模型 | UNIX系统 |
应用层(Application) | ------> ------> ------>
------>
------> | Network 网络文件系统(NFS) | ||||||||
表示层(Presentation) | ||||||||||
会话层 (Session) | SNMP | FTP | SMTP | Telnet.. | ||||||
传输层(Transport) | TCP | UDP | ||||||||
网络层(Network) |
IP
| |||||||||
数据链路层(Data Link) | LAN驱动器 LLC -----------------------介质访问控制MAC CSMA/CD(载波侦听/多路访问) | 在多个网卡驱动程序间交换 | ||||||||
WinNT(NDIS) | IEEE802.3 EthernetMAC | IEEE802.5 Token ringMAC | FDDIDMAC | 网络接口卡驱动器 | ||||||
物理层(Physical) | 物理层 |
链接
| <========> |
| <====> |
| <========> |
| ||||
|| | ||||||||||
|
收包过程
MAC从译码/解码器接收到来的数据包,首先检查SFD,检查完毕后,MAC认为SFD后面所有的位为帧数据位.读目的地址DA,把它和已变成的地址过滤中地址比较,如果DA通过了地址过滤层,这个帧会被放入网卡的存储空间.在整个整接收完成后,MAC检查FCS的有效性.
101010... | SFD | 目的地址DA | 源地址SA | Length Field | LLC Data | Pad | FCS |
可多达7字节 | 1字节 | 6字节 | 6字节 | 2字节 | 4字节 | ||
帧引导头(preamble) | 帧的长度约64字节-----1500字节 | ||||||
<========传输方向 |
SFD=Start of Frame Delimite
DA=Destination Address
SA=Source Address
LLC=Logical Link Control
FCS=Frame Check Sequence or Cyclic Redundancy Check(CRC)
SNMP
用来管理网络设备和获得外围设备信息,属于TCP/IP的一部分,具有协议独立性.利用SNMP, 一个管理工作站可以远程管理所有支持这种协议的网络设备,包括监视网络状态、修改网络设备配置、接收网络事件警告等。
管理信息库(MIB):
两种类型 MIB-1, MIB-2.MIB是一个树形结构,SNMP协议消息通过遍历MIB树形目录中的节点(OID)来访问网络中的设备.
MIB 树的每个节点被指定为一个数字(非负数),同一层的节点用不同的数字区分.这些节点数字由标准组织指定.MIB树中的任何一个节点由其所处的位置来命名.因为同一层的节点数字皆不同,到达某个节点的路由可以由从树根到此节点所经过的节点的数字串来表示.这个数字串称为相应MIB对象的对象标识符(OID).
例如, ODI,1.3.6.1.2.1.1 代表的对象是从 命名为“1”的根节点开始,后续的下级节点“3”,再下一级是“6”,依此类推.
管理信息结构标识(SMI): 定义MIB中行的技术规范.
SNMP目前有两种版本 SNMP v1 和 SNMP v2.
SNMP协议单元(PDU)实现代理和管理站间的通信,及Server 和 Target的通信.
通信类型
类型 | PDU类型 | 传输方向 | 说明 |
0 | GetRequest | Server--->Target | 用来从Target上获得一个或多个SNMP的对象(OID)值 |
1 | GetNextRequest | Server--->Target | 在Target上的MIB中获得下一个SNMP的对象(OID)值 |
2 | GetResponse | Target---->Server | Target响应ServerSNMP对象请求 |
3 | SetRequest | Server--->Target | Server上程序为TargetMIB中的OID赋值 |
4 | Trap | Target---->Server | Target用它来通知Server有一个特定时间发生 |
目前好的SNMP网络管理软件是惠普公司的 OpenView.
BSD Sockets 使用的最广泛的网络程序编程方法,主要用于应用程序的编写,用于网络上主机与主机之间的相互通信.
UNIX,Linux,VxWorks均支持BSD Sockets,Windows的Winsock基本上是来自BSD Sockets
Socket分为Stream Sockets和Data Sockets.
Stream Sockets是可靠性的双向数据传输用TCP,如HTTP,FTP等
Data Sockets是不可靠连接用UDP,如多点广播,DHCP,SNMP,RIP等.
- TCP服务器端和一个TCP客户端通信的程序过程
服务器 | 客户机 |
| 两个浅蓝色的函数是两个Sockets的握手函数,即在这里建立连接 |
|
- UDP服务器端和一个UDP客户端通信的程序过程
服务器 | 客户机 |
|
这里不建立连接,只是数据收发 <----------
|
|
UDP广播包程序示例
发送UDP广播包,查找本地网络中所有运行SNMP服务设备的IP信息。
winsock, win32控制台程序。#define SNMP_PORT 161
void SearchIP_In_LAN()
{
WSADATA wsaData;
SOCKET sockListener;
SOCKADDR_IN saUdpCli,saUdpServ;
BOOL fBroadcast = TRUE;
char sendBuff[40]= //SNMP查询包内容
{
'\x30','\x26','\x02','\x01','\x00',
'\x04','\x06','\x70','\x75','\x62',
'\x6c','\x69','\x63','\xa0','\x19',
'\x02','\x01','\x03','\x02','\x01',
'\x00','\x02','\x01','\x00','\x30',
'\x0e','\x30','\x0c','\x06','\x08',
'\x2b','\x06','\x01','\x02','\x01',
'\x01','\x01','\x00','\x05','\x00'
};
char recvBuff[600];
int nSize,err,timeoutnum = 1;;
ULONG HostIpAddr;
int rv;
int ncount=0;
if(WSAStartup(MAKEWORD( 2, 2),&wsaData)!=0)
{
printf("Winsocket start error!\n");
return;
}
sockListener=socket(AF_INET,SOCK_DGRAM,0);
err = setsockopt ( sockListener,
SOL_SOCKET,
SO_BROADCAST,
(CHAR *)&fBroadcast,
sizeof ( BOOL ));
if ( SOCKET_ERROR == err ) return ;
int TimeOut=10000;
err = setsockopt ( sockListener,
SOL_SOCKET,
SO_RCVTIMEO,
(CHAR *) &TimeOut,
sizeof (TimeOut)
);
if ( SOCKET_ERROR == err ) return ;
saUdpCli.sin_family = AF_INET;
saUdpCli.sin_port = htons(0);
saUdpCli.sin_addr.s_addr = htonl(INADDR_ANY);
if(bind( sockListener, (SOCKADDR *)&saUdpCli, sizeof(SOCKADDR_IN))!=0)
{
printf("Can't bind socket to local port!Program stop.\n");
return;
}
err = gethostname(recvBuff,sizeof(recvBuff));
if ( SOCKET_ERROR == err )
return ;
struct hostent *hp = gethostbyname(recvBuff);
if (!hp) return ;
saUdpServ.sin_family = AF_INET;
memcpy(&(saUdpServ.sin_addr),hp->h_addr,hp->h_length);
HostIpAddr=ntohl(saUdpServ.sin_addr.s_addr);
saUdpServ.sin_addr.s_addr = htonl ( INADDR_BROADCAST );
saUdpServ.sin_port = htons (SNMP_PORT);
nSize = sizeof ( SOCKADDR_IN );
if((rv = sendto ( sockListener,
sendBuff,
sizeof(sendBuff),0,
(SOCKADDR *) &saUdpServ,
sizeof ( SOCKADDR_IN )))==SOCKET_ERROR)
{
printf("Send error!\n");
closesocket(*((SOCKET*)sockListener));
return;
}
printf("Send successful!\n");
do // waiting to receive
{
if((rv=recvfrom ( sockListener,
recvBuff,sizeof(recvBuff),0,
(SOCKADDR *) &saUdpCli,&nSize))==SOCKET_ERROR)
{
if(WSAGetLastError()==WSAETIMEDOUT)
{
if (timeoutnum > 6 ) //Wait for 1 minute.
break;
else
timeoutnum++;
}
}
else
{
CString Ip(inet_ntoa ( saUdpCli.sin_addr ));
printf("\t IP Adress-> %s ",Ip);
}
}while(TRUE);
closesocket(*((SOCKET*)sockListener));
return ;
}
网络软件设计框图(个人理解,仅供参考)
|
|
|