【发布时间】:2015-06-05 13:31:18
【问题描述】:
我一直在试验来自http://www.linuxhowtos.org/C_C++/socket.htm 的服务器代码。
常规服务器代码运行良好,我将其稍微更改为硬编码端口号而不是从命令行读取,但我想要一个能够保持多个连接的服务器。它将定期等待来自 3 个不同客户端程序的短字符串。
我已经编译了以下内容,但我收到错误“错误,未提供端口”,这没有任何意义,因为我肯定包含了端口号。
一些初步问题
- 有人知道出了什么问题吗?
- 另外,我希望没有人介意我再问一个问题,这可以适应使用多线程吗?
我在 CentOS 中使用双核迷你处理器。它需要从套接字中读取少量数据,这些数据将定期传递。我知道分叉可能会使 cpu 过载,而且对于这种类型的机器,多线程也可能过于占用内存。
还有其他值得我研究的处理多个套接字连接的替代方法吗?数据将分别每 5 秒、每几个小时、每天两次。
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <string.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
void read_socket(int); /* function prototype */
void error(const char *msg)
{
perror(msg);
exit(1);
}
int main(int argc, char *argv[]){
int store_limit=10; //user input
int store_limit_secs=store_limit * 24 * 60 * 60; //user input
int sockfd, newsockfd, portno, pid;
socklen_t clilen;
struct sockaddr_in serv_addr, cli_addr;
if (argc < 2) {
fprintf(stderr,"ERROR, no port provided\n");
exit(1);
}
sockfd = socket(AF_INET, SOCK_STREAM, 0);
if (sockfd < 0)
error("ERROR opening socket");
bzero((char *) &serv_addr, sizeof(serv_addr));
portno = 15000;
serv_addr.sin_family = AF_INET;
serv_addr.sin_addr.s_addr = INADDR_ANY;
serv_addr.sin_port = htons(portno);
if (bind(sockfd, (struct sockaddr *) &serv_addr,
sizeof(serv_addr)) < 0)
error("ERROR on binding");
listen(sockfd,5);
clilen = sizeof(cli_addr);
while (1) {
newsockfd = accept(sockfd,
(struct sockaddr *) &cli_addr, &clilen);
if (newsockfd < 0)
error("ERROR on accept");
pid = fork();
if (pid < 0)
error("ERROR on fork");
if (pid == 0) {
close(sockfd);
read_socket(newsockfd);
exit(0);
}
else close(newsockfd);
} /* end of while */
close(sockfd);
return 0; /* we never get here */
}
void read_socket (int sock)
{
int n;
char buffer[256];
bzero(buffer,256);
n = read(sock,buffer,255);
if (n < 0) error("ERROR reading from socket");
printf("Here is the message: %s\n",buffer);
n = write(sock,"I got your message",18);
if (n < 0) error("ERROR writing to socket");
}
【问题讨论】:
-
"这个可以适应使用 m" ... 看起来你把中间词留在那里了。