在一个虚拟机里开两个终端可以实现通信,但是换成两个虚拟机就在connect函数那里失败了,返回-1,输出的错误提示是:connect:connection timed out。我在网上搜了很久都解决不了。我的设备是virtualbox里的两台ubuntu虚拟机,ip地址分别为10.0.2.15和10.0.3.15,能上网,能ping通,防火墙已关闭,端口没被占用,请问这可能是什么原因呢?
服务器端
#include <sys/types.h>
#include <sys/socket.h>
#include <stdio.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <unistd.h>
#include <string.h>
#include <stdlib.h>
#include <fcntl.h>
#include <sys/shm.h>
#define MYPORT 8887
#define QUEUE 20
#define BUFFER_SIZE 1024
int main()
{
///定义sockfd
int server_sockfd = socket(AF_INET,SOCK_STREAM, 0);
///定义sockaddr_in
struct sockaddr_in server_sockaddr;
server_sockaddr.sin_family = AF_INET;
server_sockaddr.sin_port = htons(MYPORT);
server_sockaddr.sin_addr.s_addr = htonl(INADDR_ANY);
///bind,成功返回0,出错返回-1
if(bind(server_sockfd,(struct sockaddr *)&server_sockaddr,sizeof(server_sockaddr))==-1)
{
perror("bind");
exit(1);
}
///listen,成功返回0,出错返回-1
if(listen(server_sockfd,QUEUE) == -1)
{
perror("listen");
exit(1);
}
///客户端套接字
char buffer[BUFFER_SIZE];
struct sockaddr_in client_addr;
socklen_t length = sizeof(client_addr);
///成功返回非负描述字,出错返回-1
int conn = accept(server_sockfd, (struct sockaddr*)&client_addr, &length);
if(conn<0)
{
perror("connect");
exit(1);
}
while(1)
{
memset(buffer,0,sizeof(buffer));
int len = recv(conn, buffer, sizeof(buffer),0);
if(strcmp(buffer,"exit\n")==0)
break;
fputs(buffer, stdout);
send(conn, buffer, len, 0);
}
close(conn);
close(server_sockfd);
return 0;
}
客户端
#include <sys/types.h>
#include <sys/socket.h>
#include <stdio.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <unistd.h>
#include <string.h>
#include <stdlib.h>
#include <fcntl.h>
#include <sys/shm.h>
#define MYPORT 8887
#define BUFFER_SIZE 1024
int main()
{
///定义sockfd
int sock_cli = socket(AF_INET,SOCK_STREAM, 0);
///定义sockaddr_in
struct sockaddr_in servaddr;
memset(&servaddr, 0, sizeof(servaddr));
servaddr.sin_family = AF_INET;
servaddr.sin_port = htons(MYPORT); ///服务器端口
servaddr.sin_addr.s_addr = inet_addr("10.0.3.15"); ///服务器ip
///连接服务器,成功返回0,错误返回-1
if (connect(sock_cli, (struct sockaddr *)&servaddr, sizeof(servaddr)) < 0)
{
perror("connect");
exit(1);
}
char sendbuf[BUFFER_SIZE];
char recvbuf[BUFFER_SIZE];
while (fgets(sendbuf, sizeof(sendbuf), stdin) != NULL)
{
send(sock_cli, sendbuf, strlen(sendbuf),0); ///发送
if(strcmp(sendbuf,"exit\n")==0)
break;
recv(sock_cli, recvbuf, sizeof(recvbuf),0); ///接收
fputs(recvbuf, stdout);
memset(sendbuf, 0, sizeof(sendbuf));
memset(recvbuf, 0, sizeof(recvbuf));
}
close(sock_cli);
return 0;
}
代码来自博客园--旭东的博客,谢谢博主。原博客链接
NAT你除非端口映射出去才行,但访问的也上HOST的地址,而不是虚拟机的地址了,其实你开了服务端程序,然后telnet一下,不通就是不通了。
你可以用Host only方式或桥接的方式,Host only方式虚拟机之间是可以通迅的,外网要另外设置
桥接方式如果你自己用的是路由上网,地址应该和路由地址是同一网段的,随便乱设置是上不了网的
是不是虚拟机的网络设置有问题?看看虚拟机的网络设置是不是桥接。
1.根据你提到的在一个操作系统中,开两个terminal可以通信,可知服务端代码和客户端代码没有问题,排除connect等时的语法错误;
2.两个操作系统之间不能通信,至少要保证的是客户端能ping通服务端ip,能ping通说的不明确;
3.查看路由route -n,看客户端有没有到服务器子网的路由,没有就加路由;
遇到了同一问题,可我还是公网服务器。。。。。也是127过,公网链接就超时QAQ
相同问题,但是我的情况好像是连通的一瞬间就断开了,然后显示connect:success,不清楚是哪里出错了,查看端口监听状态发现客户端的close_wait的状态,没有establish的过程