[Comm] Socet server bind debug

Alexandr R. Ogurtzoff =?iso-8859-1?q?iscander_=CE=C1_mercuri=2Emk=2Eua?=
Вт Авг 26 12:56:56 MSD 2003


> программка-то завершилась, а соединение еще не закрылось, см  netstat
Гхм! Действительно по netstat открыто, но как?
#include <stdio.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include "tst.h"

int ConnectionProccessing(int sd)
{
  char buffer[ BUFFER_SIZE ];
  int count;
  memset(buffer,0,sizeof(buffer));
  count= recv(sd, buffer,sizeof(buffer), 0);
    if (count < 0)
    {perror("Recive error, stop proccessing"); return 1;};
    if (count >= BUFFER_SIZE)
    {perror("Buffer overflow error"); return 2;};
    if (buffer[0]=='0')
    {perror("Conection terminated by remote side..."); return -1;};

   buffer[count+1]=0;
   printf("Recive \n %s \n", buffer);
   return 0;
}

int main (int argc, char *argv[] )
{
    int sd, exit_flag, port=DEFAULT_PORT;
    struct sockaddr_in  addr;

	printf ("\n %s test control started sucsesfully \n", argv[0]);
	 if((sd = socket(PF_INET,SOCK_STREAM,0))==-1)
	   panic("Error socket creation,exit");
 memset(&addr,0, sizeof(addr));
        addr.sin_family = PF_INET;
	addr.sin_port = htons(port);
	addr.sin_addr.s_addr = INADDR_ANY;
  if(  bind(sd, &addr, sizeof(addr) )!=0 )
	    panic("Error on binding, exit");
	 if ( listen(sd, MAX_LISTEN) !=0 )
	    panic("Error on listening,exit");
	exit_flag=0;
	while( exit_flag == 0 )
		{
		 int client, len=sizeof(addr);
			client = accept(sd, &addr,&len);
			printf ("\nHost ( %s : %d 
)",inet_ntoa(addr.sin_addr),ntohs(addr.sin_port));
			exit_flag=ConnectionProccessing(client);
			close(client);                                     /*Здесь закрыл*/
			printf ("\nClient closed\n");
		}
	close(sd);                                    /* И здесь тоже закрыл, факт?*/
	printf ("\n%s  finished\n", argv[0]);
	return 0;
}

 От вет на посылку '0' в качстве первого символа, то есть завершаем программку
[iscander на iscander gatedeamon]$ ./gatectrl

 ./test test control started sucsesfully

Conection terminated by remote side...: Success
Host ( 127.0.0.1 : 34431 )Client closed /*Здесь закрыл*/
 
./test test  finished /* И здесь тоже закрыл, факт?*/
[iscander на iscander gatedeamon]$ ./test

 ./test test control started sucsesfully
Error on binding, exit: Address already in use
Ну понятно что при этом он висит открытым
-- 
С наилучшими пожеланиями
Александр Огурцов




Подробная информация о списке рассылки community