select I/O 复用__2018.07.30

代码(ser.c):

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <assert.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <time.h>

#define SER_IP "127.0.0.1"
#define SER_PORT 6000
#define STDIN 0

int main()
{
    int sockfd=socket(AF_INET,SOCK_STREAM,0);
    assert(sockfd!=-1);

    struct sockaddr_in saddr,caddr;
    memset(&saddr,0,sizeof(saddr));
    saddr.sin_family=AF_INET;
    saddr.sin_port=htons(SER_PORT);//1024 知名端口,1025-4096,临时端口
    saddr.sin_addr.s_addr=inet_addr(SER_IP);

    int res=bind(sockfd,(struct sockaddr*)&saddr,sizeof(saddr));//命名套接字
    assert(res!=-1);

    listen(sockfd,5);//创建监听队列
    while(1)
    {
        int len=sizeof(caddr);
        int c=accept(sockfd,(struct sockaddr*)&caddr,&len);//接收客户端链接
        if(c<0)
        {
            continue;
        }
        printf("accept c=%d,ip=%s,port:%d\n",c,inet_ntoa(caddr.sin_addr),ntohs(caddr.sin_port));

        int fd=STDIN;
        fd_set fdset;
            
        struct timeval timeout={5,0};

        while(1)
        {
            FD_ZERO(&fdset);
            FD_SET(c,&fdset);//循环添加所有描述符
            FD_SET(fd,&fdset);//将键盘也添加进来

            int n=select(c+2,&fdset,NULL,NULL,&timeout);
            if(n==-1)
            {
                printf("selection failure\n");
                break;
            }
            else if(n==0)
            {
                //printf("time out\n");
            }
            if(FD_ISSET(c,&fdset))
            {
                char recv_buff[128]={0};
                if(recv(c,recv_buff,127,0)<=0)
                {
                    break;
                }
                printf("recv:%s",recv_buff);
            }

            if(FD_ISSET(fd,&fdset))
            {
                printf("send:");
                char send_buff[128]={0};
                fgets(send_buff,128,stdin);
                send(c,send_buff,sizeof(send_buff),0);
            }
        }
        close(c);
    }
}

代码(cli.c):

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <assert.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <sys/time.h>
#include <errno.h>//打印错误信息的头文件
#include <sys/types.h>
#include <fcntl.h>

#define IP "127.0.0.1"
#define PORT 6000
#define STDIN 0

int main()
{
    int sockfd=socket(AF_INET,SOCK_STREAM,0);//调用socket函数创建套接字
    assert(sockfd!=-1);

    struct sockaddr_in saddr;
    memset(&saddr,0,sizeof(saddr));
    saddr.sin_family=AF_INET;
    saddr.sin_port=htons(PORT);
    saddr.sin_addr.s_addr=inet_addr(IP);

    int res=connect(sockfd,(struct sockaddr*)&saddr,sizeof(saddr));
    assert(res!=-1);

    int fd=STDIN;
    fd_set fdset;

    struct timeval timeout={5,0};

    while(1)
    {
        //发送数据
        FD_ZERO(&fdset);
        FD_SET(fd,&fdset);//循环添加所有描述符
        FD_SET(sockfd,&fdset);

        int n=select(sockfd+2,&fdset,NULL,NULL,&timeout);
        if(n==-1)
        {
            printf("selection failure\n");
            break;
        }
        else if(n==0)
        {
            //printf("time out\n");
        }
        //对于可读事件,采用普通的recv函数读取数据
        if(FD_ISSET(fd,&fdset))
        {
            printf("send:");
            char send_buff[128]={0};//128字节的发送缓冲区
            fgets(send_buff,128,stdin);
            send(sockfd,send_buff,strlen(send_buff),0);

            if(strncmp(send_buff,"end",3)==0)
            {
                exit(0);
            }
            memset(send_buff,0,128);
        }
        //接收数据
        //对于可读事件,采用普通的recv函数读取数据
        if(FD_ISSET(sockfd,&fdset))
        {
            char recv_buff[128]={0};//128字节的接收缓冲区
            int ret=recv(sockfd,recv_buff,128,0);
            {
                if(ret<=0)
                {
                    break;
                }
            }
            printf("recv:%s",recv_buff);
            fflush(stdout);
            memset(recv_buff,0,128);
        }
    }
    close(sockfd);
}

 

set user_write_ugi:afs://kunpeng.afs.baidu.com:9902=lbs-huiyan,lbs-huiyan; insert overwrite directory 'afs://kunpeng.afs.baidu.com:9902/user/lbs-huiyan/warehouse/huiyan.db/map_huiyan_mall_userpic/event_type=monthly/event_day={FORWARD_MONTH_END}' using CSV options('compression'='GZIP', sep='\t', escapeQuotes=false) SELECT source.mall_id AS mall_id, COUNT(1) AS total FROM (SELECT cuid, mall_id, mall_name, date_type FROM huiyan_ns.huiyan.map_huiyan_mall_basic_source WHERE event_day = '{FORWARD_MONTH_END}') source JOIN (SELECT cuid, * FROM huiyan_ns.huiyan.map_huiyan_parse_userpic WHERE event_day >= '{FORWARD_7_DAY}' AND event_day <= '{FORWARD_MONTH_END}') userpic ON userpic.cuid = source.cuid GROUP BY source.mall_id, source.mall_name, source.date_type; alter table huiyan_ns.huiyan.map_huiyan_mall_userpic_raw add partition(event_day='{FORWARD_MONTH_END}') location 'afs://kunpeng.afs.baidu.com:9902/user/lbs-huiyan/warehouse/huiyan.db/map_huiyan_mall_flow_userpic_raw/event_day={FORWARD_MONTH_END}'; set user_write_ugi:afs://kunpeng.afs.baidu.com:9902=lbs-huiyan,lbs-huiyan; insert overwrite directory 'afs://kunpeng.afs.baidu.com:9902/user/lbs-huiyan/warehouse/huiyan.db/map_huiyan_mall_userpic/event_type=monthly/event_day={FORWARD_MONTH_END}' using CSV options('compression'='GZIP', sep='\t', escapeQuotes=false) SELECT TRANSFORM(mall_id, ) USING 'python3 mall_userpic_streaming.py' AS(mall_id, ) FROM huiyan_ns.huiyan.map_huiyan_mall_userpic_raw WHERE event_day = '{FORWARD_MONTH_END}' ; alter table huiyan_ns.huiyan.map_huiyan_mall_userpic add partition(event_type='monthly', event_day='{FORWARD_MONTH_END}') location 'afs://kunpeng.afs.baidu.com:9902/user/lbs-huiyan/warehouse/huiyan.db/map_huiyan_mall_userpic/event_type=monthly/event_day=${FORWARD_MONTH_END}'; 将这两段代码合并为一段
07-22
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值