'STORY'에 해당되는 글 398건

그냥 보내니깐 열라 빠름

하지만 데이타의 손실이 치명적이면 안쓰는게 좋음

 

#include <sys/socket.h>

ssuze_t sendto(int sock, void *buff, size_t nbytes, int flags,struct sockaddr *to, socklen_t addrlen);

 

sockaddr *to 이게 중요함 보내는곳이 있움

 

#include <sys/socket.h>

ssize_t recvfrom(int sock, void *buff, size_t nbytes, int flags, struct sockaddr *from, socklen_t *addrlen);

 

데이터 송수신을 확인함

 

 

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <arpa/inet.h>
#include <sys/socket.h>

#define BUF_SIZE 30
viod error_handling(char *message);

int main(int argc, char *argv[])
{
	int serv_sock;
    char message[BUF_SIZE];
    int str_len;
    socklen_t clnt_adr_sz;
    
    struct sockaddr_in serv_adr, clnt_adr;
    if(argc!=2)
    {
    	printf("Usage : %s <port>\n", argv[0]);
        exit(1);
    }
    
    serv_sock=socket(PF_INET, SOCK_DGRAM, 0);
    if(serv_sock == -1)
    	error_handling("UDP socket creation error");
        
    memset(&serv_adr, 0, sizeof(serv_adr));
    serv_adr.sin_family=AF_INET;
    serv_adr.sin_addr.s_addr=htonl(INADDR_ANY);
    serv_adr.sin_port=htons(atoi(argv[1]));
    
    if(bind(serv_sock, (struct sockaddr*)&serv_adr, sizeof(serv_adr))==-1)
    	error_handling("bind() error");
    
    while(1)
    {
    	clnt_adr_sz=sizeof(clnt_adr);
        str_len=recvfrom(serv_sock, message, BUF_SIZE, 0, 
        	(struct sockaddr*)&clnt_adr, &clnt_adr_sz);
        sendto(serv_sock, message, str_len, 0,
        	(struct sockaddr*)&clnt_adr, clnt_adr_sz);
    }
    close(serv_sock);
    return 0;
}

void error_handling(char *message)
{
	fputs(message, stderr);
    fputc('\n', stderr);
    exit(i); 
}

신기한거같음 상관업이 보네도되는건가?

 

클라이언트 엔받는애인거 같은데

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <arpa/inet.h>
#include <sys/socket.h>

#define BUF_SIZE 30
viod error_handling(char *message);

int main(int argc, char *argv[])
{
	int sock;
    char message[BUF_SIZE];
    int str_len;
    socklen_t adr_sz;
    
    struct sockaddr_in serv_adr, from_adr;
    if(argc!=3)
    {
    	printf("Usage : %s <IP> <port>\n", argv[0]);
        exit(1);
    }
    
    sock=socket(PF_INET, SOCK_DGRAM, 0);
    if(serv_sock == -1)
    	error_handling("socket() error");
        
    memset(&serv_adr, 0, sizeof(serv_adr));
    serv_adr.sin_family=AF_INET;
    serv_adr.sin_addr.s_addr=inet_addr(argv[1]);
    serv_adr.sin_port=htons(atoi(argv[2]));
 
    while(1)
    {
    	fputs("Insert message(q to quit): ", stdout);
        fgets(message, sizeof(message), stdin);
        if(!strcmp(message,"q\n") || !strcmp(message,"Q\n"))
        	break;
            
        sendto(sock, message, strlen(message), 0,
        	(struct sockaddr*)&serv_adr, sizeof(serv_adr));
        adr_sz=sizeof(from_adr);
        str_len=recvfrom(sock, message, BUF_SIZE, 0,
        	(struct sockaddr*)&from_adr, &adr_sz);
        message[str_len]=0;
        printf("Message from server: %s", message);
    }
    close(sock);
    return 0;
}

void error_handling(char *message)
{
	fputs(message, stderr);
    fputc('\n', stderr);
    exit(i); 
}

잘 받은듯 하다 

 

'[ 충남인력개발원 ] (2019) > ┗TCP&IP' 카테고리의 다른 글

짠거 에러날때 주의  (0) 2019.11.25
UDP 호출 과정  (0) 2019.11.24
버퍼링 에대해서  (0) 2019.11.24
에코 클라이언트의 완벽 구현!  (0) 2019.11.24
Iterative 서버의 구현  (0) 2019.11.24
블로그 이미지

Or71nH

,

버퍼링은 상대입장에서 남은 용량을 보고 받고 

내가 보내려는 양에서 뚝 때서 조금씩 보내주는중임

 

입력 햇다고 바로 가는게 아니라 저장소에 잠시 저장 되고 조금씩 보내줌

 

 

보내는애랑  받는애의 끝남은

 

 

받는는애가 끝네겟다고 하면

보내는애가 끝넬지 말지 생각함

보낼꺼 있으면 계속 보내기만함

보낼꺼 없어지면 나도 끝네겟다고함

그러럼 받는애가 알앗다고 끊음

 

'[ 충남인력개발원 ] (2019) > ┗TCP&IP' 카테고리의 다른 글

UDP 호출 과정  (0) 2019.11.24
UDP 는 뭐지?  (0) 2019.11.24
에코 클라이언트의 완벽 구현!  (0) 2019.11.24
Iterative 서버의 구현  (0) 2019.11.24
TCP 클라이언트 구연  (0) 2019.11.24
블로그 이미지

Or71nH

,

전에 그거 해결 하려면

보낸애가  보낸 크기만큼 읽을때까지 기다리면 되는거지 ㅇㅇ

 

그럼 받는애가 끊어서 받든 다 받든 상관없이 

 

내가 보낸 만큼 읽어졋을때 맞는지 틀리는지 알수 있으니깐

 

 

이거는echo_client2.c

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <arpa/inet.h>
#include <sys/socket.h>
#define BUF_SIZE 1024
void error_handling(char *message);

int main(int argc, char *argv[])
{
	int sock;
    char message[BUF_SIZE];
    int str_len, recv _len, recv_cnt;
    struct sockaddr_in serv_adr;
    
    if(argc!=3) {
    	printf("Usage : %s <IP> <port>\n", argv[0]);
        exit(1);
    }
    
    sock=socket(PF_INET, SOCK_STRAM, 0);
    if(sock==-1)
    	error_handling("socket() error");
    
    memset(&serv_adr, 0, sizeof(serv_adr));
    serv_adr.sin_family=AF_INT;
    serv_adr.sin_addr.s_addr=int_addr(argv[1]);
    serv_adr.sin_port=htons(atoi(argv[2]));
    
    if(connect(sock, (struct sockaddr*)&serv_adr, sizeof(serv_adr))==-1)
    	error_handling("connect() error!");
    else
    	put("connected...........");
    
    while(1)
    {
    	fputs("Input message(Q to quit): ", stdout);       // stdout 이거 어디서 나온거지?
        fgets(message, BUF_SIZE, stdin);
        if(!strcmp(message,"q\n") || ! strcmp(message,"Q\n"))    // cmp? 알아봐야할듯
        	break;
        
        str_len=write(sock, message, strlen(message));
        
        recv_len= 0;
        while(recv_len<str_len)
        {
        	recv_cnt=read(sock, &message[recv_len], BUF_SIZE-1);
            if(recv_cnt==-1)
            	error_handling("read() error!");
            recv_len+=recv_cnt;
        }
        message[recv_cnt]=0;
        printf("Message from server: %s", messeage);
   }
   close(sock);
   return 0;
}

void error_handling(char *message)
{
	fputs(message, stderr);
    fputc('\n', stderr);
    exit(1);
}

 

밑은 op_client.c임

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <arpa/inet.h>
#include <sys/socket.h>
#define BUF_SIZE 1024
#define RLT_SIZE 4
#define OPSZ 4
void error_handling(char *message);

int main(int argc, char *argv[])
{
	int sock;
    char opmsg[BUF_SIZE];                            // 수정좀됫네
    int result, opnd_cnt, i;                          // 수정좀됫네
    struct sockaddr_in serv_adr;
    if(argc!=3) 
    {                                             //이거 3이 뭔뜻이엿지?
    	printf("Usage : %s <IP> <port>\n", argv[0]);
        exit(1);
    }
    
    sock=socket(PF_INET, SOCK_STRAM, 0);
    if(sock==-1)
    	error_handling("socket() error");
    
    memset(&serv_adr, 0, sizeof(serv_adr));
    serv_adr.sin_family=AF_INT;
    serv_adr.sin_addr.s_addr=int_addr(argv[1]);
    serv_adr.sin_port=htons(atoi(argv[2]));
    
    if(connect(sock, (struct sockaddr*)&serv_adr, sizeof(serv_adr))==-1)
    	error_handling("connect() error!");
    else
    	put("connected...........");
    
    fputs("Operand count: ", stdout);
    scanf("%d", &opnd_cnt);
    opmsg[0]=(char)opnd_cnt;
    
    for(i=0; i<opnd_cnt; i++)
    {
    	printf("Operand %d: ", i+1);
        scanf("%d", (int*)&opmsg[i*OPSZ+1]);    //이거 뭐지배열 추가인가?
    }
    fgetc(stdin);
    fputs("Operator: ", stdout);
    scanf("%c", &opmsg[opnd_cnt*OPSZ+1]);
    write(sock, opmsg, opnd_cnt*OPSZ+2);
    read(sock, &result, RLT_SIZE);
     
    printf("Operation result: %d \n", result);                 // 왜 주소지???
    close(sock);
    return 0;
}

void error_handling(char *message)
{
	fputs(message, stderr);
    fputc('\n', stderr);
    exit(1);
}

살짝 다르긴 한데 뭐 비슷비슷한듯함

추가건

 

 

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <arpa/inet.h>
#include <sys/socket.h>
#define BUF_SIZE 1024
#define OPSZ 4
void error_handling(char *message);
int calculate(int opnum, int opnds[], chart oprator);

int main(int argc, char *argv[])
{
	int serv_sock, clnt_sock;
    char opinfo[BUF_SIZE];
    int result, opnd_cnt, i;
    int recv_cnt, recv_len;
    struct sockaddr_in serv_adr, clnt_adr;
    socklen_t clnt_adr_sz;
    if(argc!=2)
    {
    	printf("Usage : %s <port>\n", argv[0]);
        exit(1);
    }
    
    serv_sock=socket(PF_INET, SOCK_STREAM, 0);
    if(serv_sock==-1)
    	error_handling("socket() error");
        
    memsetr(&serv_adr, 0, sizeof(serv_adr));
    serv_adr.sin_family=AF_INET;
    serv_adr.sin_addr.s_addr=htonl(INADDR_ANY);
    serv_adr.sin_port=htons(atoi(argv[1]));
    if(bind(serv_sock, (struct sockaddr*)&serv_adr, sizeof(serv_adr))==-1)
    	error_handling("bind() error");
    if(listen(serv_sock, 5)==-1)
    	error_handling("listen() error");
    clnt_adr_sz= sizeof(clnt_adr);
    
    for(i=0; i<5;i++)                //저위에 선언되있움
    {
    	opnd_cnt=0;
        clnt_sock=accept(serv_sock, (struct sockaddr*&)&clnt_adrt, &clnt_adr_sz);
        read(clnt_sock, &opnd_cnt, 1);
        
        recv_len=0;
        while((opnd_cnt*OPSZ+1)>recv_len)
        {
        	recv_cnt= read(clnt_sock, &opinfo[recv_len], BUF_SIZE-1);
            recv_len+=recv_cnt;
        }   
        result=calculate(opnd_cnt, (int*)opinfo, opinfo[recv_len-1]);
        write(clnt_sock, (char*)&result, sizeof(result));
        close(clnt_sock);
    }
    close(serv_sock);
    return 0;
}

int calculate(int opnum, int opnds[], chart oprator)
{
	int result=opnds[0], i;
    switch(op)
    {
    case '+':
    	for(i=1; i<opnum; i++) result+=opnds[i];
        break;
    case '-':
    	for(i=1; i<opnum; i++) result-=opnds[i];
        break;
    case '*':
    	for(i=1; i<opnum; i++) result*=opnds[i];
        breadk;
    }
    return result;
}   

void error_handling(char *message)
{
	fputs(message, stderr);
    fputc('\n', stderr);
    exit(1);
}

 

다썻다 

하야케 불태웟어~~

으아ㅏ으아아ㅏㅇ

 

어느정도 이해가 되었다 음 계산기는 왜만들었을까 참 궁금하다

 

아 겜한판 하고 담에 또해야지

'[ 충남인력개발원 ] (2019) > ┗TCP&IP' 카테고리의 다른 글

UDP 는 뭐지?  (0) 2019.11.24
버퍼링 에대해서  (0) 2019.11.24
Iterative 서버의 구현  (0) 2019.11.24
TCP 클라이언트 구연  (0) 2019.11.24
TCP/IP 프로토콜 스택  (0) 2019.11.24
블로그 이미지

Or71nH

,

이제 하나 만 보내고 

하나 만 받는 소켓은

지겹다

 

 

걍 끝날때까지 계속 연결되있는 상황을 만드려면

 

accept 함수를 계쏙 다시 하는거임

그럼 위에꺼는 안해도 되잖아 

accept 로 소켓 하나씩 만들고 받으면서 

계속 연결되있는 상태로 만듬

 

줄서서 순서대로 서비스 제공하는 소켓 임

 

 

근데 읽는애는 조금 읽고 

 

주는애는 많이 주면 

이게 읽는애가 읽은만큼만 주는애가 들으면 다시보내겟지뭐

 

 

주는애                                      ----------------->  읽는애 

야 너 오늘 데이트간다며               -----------------> 야 너 오늘 

야 너 오늘                               <----------------   야 너 오늘 

???????????이거 아닌데 잘못 들엇나?          

                                                    들읽은거 --- 데이트간다며

아니 그게 아니고 ----------> 잠시 저장됨 ---대기중 >

(전달 안된줄 알고 또보넴)

데이트 간다며                         <--------------- 데이트간다며

????????????????? 아.......

 

 

이런식인듯 

 

 

 

 

블로그 이미지

Or71nH

,

#listen <sys/type.h>

 

int listen(int sock, int backlog);

 

sock 연결 요청대기상태에 두고자 하는 소켓의 파일 디스크립터 전달 ,이함수의 인자로 전달된 디스트립터의 소켓이 서버 소켓(리스닝) 이 된다

 

backlog 연결 요청 대기 큐(Queue)의 크기정보 전달, 5가 전달되면 큐의 크기가 5가 되어 클라이언트 의 연결요청을 5갸까지 대기시킬 수 있다.

 

 

그니깐

 

sock 은 오는 데이터 경비실 아저씨가 받아서 택배아져씨처럼 잘 분배해주고

 

backlog 는 우체통임 ㅇㅇ

 

 

????

 말달라졋음    

우체통이 아니라 그 뭐냐 호실 주인하고 우체국 아져씨하고 이어줌 

 

 

 

 

CPU는 PORT 를 중복 시킬수 있다 좀 신기하네 우린 못해 컴터만 할 수있음

운영 체제는 맵 핑 주소를 가지고 있어서 가능하다고 한다 뭔개소리야???

211.217.218.90 :8080

 

그니깐 보낸에마다 나눠서 주는건가 

집주인의 엄마 아빠 아들 딸 있으면 집에는 연결하는데 딸친구와서 딸하고 이어주고

엄마 친구는 엄마하고 이어주고 그니깐

저장한 정보로 맞는 사람하고 이어줌

 

#include <sys/socket.h>

 

int accept(int sock, struct sockaddr * addr, socklen_t * addrlen);

 

음 그림으로 이해하자 

블로그 이미지

Or71nH

,