首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 操作系统 > UNIXLINUX >

linux虚拟机udp环回通讯实验

2013-02-24 
linux虚拟机udp环回通信实验我想在虚拟机linux中做一个udp通信的实验,在虚拟机客户端中发送某一数字A,服务

linux虚拟机udp环回通信实验
我想在虚拟机linux中做一个udp通信的实验,在虚拟机客户端中发送某一数字A,服务器程序接收到A,就求取阶乘并发回给客户端程序。
客户端和服务器都是虚拟机下的linux。虚拟机我选用NAT联网方式。

虚拟机的ip:192.168.10.140,如下ifconfig

eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
        inet 192.168.10.140  netmask 255.255.255.0  broadcast 192.168.10.255
        inet6 fe80::20c:29ff:fe9c:bbb3  prefixlen 64  scopeid 0x20<link>
        ether 00:0c:29:9c:bb:b3  txqueuelen 1000  (Ethernet)
        RX packets 838  bytes 77159 (75.3 KiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 287  bytes 24226 (23.6 KiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0
        device interrupt 19  base 0x2024  

lo: flags=73<UP,LOOPBACK,RUNNING>  mtu 16436
        inet 127.0.0.1  netmask 255.0.0.0
        inet6 ::1  prefixlen 128  scopeid 0x10<host>
        loop  txqueuelen 0  (Local Loopback)
        RX packets 57  bytes 4884 (4.7 KiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 57  bytes 4884 (4.7 KiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

virbr0: flags=4099<UP,BROADCAST,MULTICAST>  mtu 1500
        inet 192.168.122.1  netmask 255.255.255.0  broadcast 192.168.122.255
        ether 52:18:bf:00:ed:f9  txqueuelen 0  (Ethernet)
        RX packets 0  bytes 0 (0.0 B)
        RX errors 0  dropped 0  overruns 0  frame 0


客户端程序为
#include<stdio.h>

#include<sys/socket.h>

#include<errno.h>

#include<netdb.h>

#include<netinet/in.h>

#include<arpa/inet.h>

#include<stdlib.h>

#include<string.h>



main(int argc,char *argv[])

{

int n,nSend,len;

int nSocket;

long IResult;

struct sockaddr_in sin;



if(argc != 2)

{

fprintf(stderr,"Usage:%s number\n",argv[0]);

exit(0);

}



nSend = atoi(argv[1]);



if((nSocket = socket(PF_INET,SOCK_DGRAM,0))<0)

{

fprintf(stderr,"socket error:%s\n",strerror(errno));



exit(0);

}



bzero(&sin,sizeof(struct sockaddr_in));



if(inet_pton(AF_INET,"192.168.10.140",&(sin.sin_addr))!=1)

{

fprintf(stderr,"inet_pton error:%s\n",strerror(errno));

exit(0);

}



sin.sin_family=AF_INET;

sin.sin_port=htons(6000);



if(sendto(nSocket,(void *)&nSend,sizeof(int),0,(struct sockaddr *)&sin,sizeof(struct sockaddr_in))<0)

{

fprintf(stderr,"sendto error:%s\n",strerror(errno));

close(nSocket);

exit(0);

}



len=sizeof(struct sockaddr_in);

recvfrom(nSocket,(void *)&IResult,sizeof(long),0,(struct sockaddr *)&sin,&len);



printf("%ld\n",IResult);

close(nSocket);

return;

}



服务器程序:
#include <stdio.h>
#include <sys/socket.h>
#include <error.h>
#include <netdb.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include<stdlib.h>
#include<string.h>

long ComputeFact(int nFact)
{
int n;
long IResult = 1;

if(nFact<0)
return nFact;

if(nFact==0)
return 1;

for(n=1;n<nFact;n++)
{
IResult *= n;
}
return IResult;
}


main()
{
int n,len;
int nRecvVar;
int nSocket;
long ISendVar;
struct sockaddr_in sin,cin;
if((nSocket=socket(PF_INET,SOCK_DGRAM,0))<0)
{
perror("socket");
exit(0);
}
bzero(&sin,sizeof(struct sockaddr_in));
sin.sin_family=AF_INET;
sin.sin_addr.s_addr=htonl(INADDR_ANY);
sin.sin_port=htons(6000);

if(bind(nSocket,(struct sockaddr *)&sin,sizeof(struct sockaddr_in ))<0)
{
perror("bind");
exit(0);
}

for(;;)
{
len=sizeof(struct sockaddr_in);
bzero(&cin,sizeof(struct sockaddr_in));
n=recvfrom(nSocket,(void *)&nRecvVar,sizeof(int),0,(struct sockaddr *)&cin,&len);

if(nRecvVar<0)
break;
}
close(nSocket);
return;
}

但是运行客户端程序和服务器程序,都没有反应。
求大神告知是为什么??? 虚拟机 linux 服务器 socket
[解决办法]
NAT的方式不对 设置为bridge
实际上 你使用NAT方式 如果client 和server不是部署在同一台主机上的话  这2个地址根本不可见
[解决办法]
同一台虚拟机的话是不应该的。
[解决办法]
当然没有反应啦。

服务器的函数的主函数recvfrom后就return了, 然后客户端没有接收到返回,然后...
然后就没有反应了!

热点排行