文档章节

linux 本地socket

t
 taoanran
发布于 2014/05/08 09:33
字数 422
阅读 125
收藏 3
server 端:

void *recvData(void *arg)
{
    char recvbuf[1024];
    int conn = *(int *)arg;
    while(1)
    {
        memset(recvbuf,0,1024);
        recv(conn, recvbuf, sizeof(recvbuf),0);
    }
}

main 函数:
int listenfd;
int conn;
char sendbuf[1024];
char recvbuf[1024];
char sig_strength[16];
char radio_if[16];
if ((listenfd = socket(PF_UNIX, SOCK_STREAM, 0)) < 0)
    LOGE("socket error");
unlink("/tmp/test_socket"); //地址复用
struct sockaddr_un servaddr;
memset(&servaddr, 0, sizeof(servaddr));
servaddr.sun_family = AF_UNIX;
strcpy(servaddr.sun_path, "/tmp/test_socket");
if (bind(listenfd, (struct sockaddr *)&servaddr, sizeof(servaddr)) < 0)
    LOGE("bind error");
if (listen(listenfd, SOMAXCONN) < 0)
    LOGE("listen error");
while(1)
{
    conn = accept(listenfd, NULL, NULL);
    if (conn == -1)
    {
        if (conn == EINTR)
            continue;
    }
    pthread_create(&thread_socket_recv, NULL, recvData, &conn);
    
    while(1)
    {
        memset(sendbuf,0,1024);
        strncpy(sendbuf,"xxxx, strlen("xxx"));
        send(conn, sendbuf, strlen(sendbuf),0);
    }
    close(conn);
    close(listenfd);
}

client端(非阻塞socket)
typedef struct QMISocket{
int socketfd;
struct timeval timeout;
pthread_mutex_t mMutex;
}QMISocket;
extern QMISocket mSocket;

static int sockConnect()
{
    struct sockaddr_un servaddr;
    int retval ;
    fd_set set;
    int flags;
    int ret=-1;
    
    if ((mSocket.socketfd = socket(PF_UNIX, SOCK_STREAM, 0)) < 0)
        printf("socket error");
    mSocket.timeout.tv_sec = 3;
    mSocket.timeout.tv_usec = 0;
    setsockopt(mSocket.socketfd,SOL_SOCKET,SO_SNDTIMEO,(char *)&(mSocket.timeout),sizeof(struct timeval));
    setsockopt(mSocket.socketfd,SOL_SOCKET,SO_RCVTIMEO,(char *)&(mSocket.timeout),sizeof(struct timeval));
    memset(&servaddr, 0, sizeof(servaddr));
    servaddr.sun_family = AF_UNIX;
    strcpy(servaddr.sun_path, "/tmp/test_socket");
    flags = fcntl(mSocket.socketfd, F_GETFL, 0);
    fcntl(mSocket.socketfd, F_SETFL, flags | O_NONBLOCK);
    ret = connect(mSocket.socketfd, (struct sockaddr *)&servaddr, sizeof(servaddr));
    if (0 == ret)
    {
        printf("connected\n");
    }
    else{
        if (errno != EINPROGRESS)
        {
		perror("connect");
		return-1;
	}
	FD_ZERO(&set);
	FD_SET(mSocket.socketfd,&set);
	retval = select(mSocket.socketfd+ 1,NULL, &set,NULL,&mSocket.timeout);
	if(retval==-1)
	{
	    perror("select");
	    return -1;
	}
	else if(retval== 0)
	{
		fprintf(stderr,"timeout\nn");
		printf("%d\n",time(NULL));
		return 0;
	}
	printf("connected\n");
	}
    }
    flags = fcntl(mSocket.socketfd, F_GETFL, 0);
    fcntl(mSocket.socketfd, F_SETFL, flags & ~O_NONBLOCK);
    return mSocket.socketfd;
}

int main()
{
    while(1)//wait the reboot-daemon
    {
        if (sockConnect() > 0)
            break;
        sleep(1);
    }
    while(1)
    {
        char recvbuf[1024]={0};  
        ret = recv(mSocket.socketfd, recvbuf, sizeof(recvbuf),0);
    }
}

这里在recv的时候,如果send端发送非常快,那么可能会导致一次recv到多个数据包的情况,那可需要在每个数据包结尾打上标记,表示一个个数据包。recv根据这些flags去截取每一个数据包

char  *remainBuf = NULL;
remainBuf = recvbuf;
char *tmp = strstr(remainBuf, "@");
memset(key,0,1024);
if (tmp != NULL)
{
	strncpy(key, remainBuf, tmp - remainBuf);
	remainBuf = remainBuf+(tmp - remainBuf)+1;
}


© 著作权归作者所有

共有 人打赏支持
t
粉丝 7
博文 64
码字总数 7186
作品 0
南京
使用ssh隧道+privoxy实现Linux全局代理

使用ssh隧道+privoxy实现Linux全局代理 ssh简介 SSH 为 Secure Shell 的缩写,由 IETF 的网络小组(Network Working Group)所制定;SSH 为建立在应用层基础上的安全协议。SSH 是目前较可靠,...

aaronchou0
07/18
0
0
用 python 获取本地/公网 ip 地址

1、Windows下2种方法: 1. 使用拨号上网的话,一般都有一个本地ip和一个外网ip,使用python可以很容易的得到这两个ip 使用gethostbyname和gethostbyname_ex两个函数可以实现 import socket lo...

大数据之路
2012/08/11
0
0
【转载】配置开发支持高并发TCP连接的Linux应用程序全攻略

1、修改用户进程可打开文件数限制 在Linux平台上,无论编写客户端程序还是服务端程序,在进行高并发TCP连接处理时,最高的并发数量都要受到系统对用户单一进程同时可打开文件数量 的限制(这是...

晨曦之光
2012/03/09
0
0
Linux下端口复用(SO_REUSEADDR与SO_REUSEPORT)(转载)

http://blog.chinaunix.net/uid-7390305-id-2057201.html 作者:迷失千夏——拾露赏云 解决性参考:Currently, Linux does not allow reuse of same local port for both TCP server and TC......

老汉-憨憨
2014/12/08
0
0
配置开发支持高并发TCP连接的Linux应用程序全攻略

1、修改用户进程可打开文件数限制 在Linux平台上,无论编写客户端程序还是服务端程序,在进行高并发TCP连接处理时,最高的并发数量都要受到系统对用户单一进程同时可打开文件数量 的限制(这是...

囧南风囧
2010/10/22
0
1

没有更多内容

加载失败,请刷新页面

加载更多

下一页

c语言之内存分配笔记

先看一个数组: short array[5] = {1,2} // 这儿定义的一个int类型的数组,数组第1和第2个元素值是1和2.其余后面默认会给值为0; 或者 short array[] = {1,2};//这儿数组第1和第2个元素,数组...

DannyCoder
32分钟前
0
0
Shell | linux安装包不用选择Y/N的方法

apt-get install -y packageOR echo "y" | sudo apt-get install package

云迹
今天
1
0
Hadoop的大数据生态圈

基于Hadoop的大数据的产品圈 大数据产品的一句话概括 Apache Hadoop: 是Apache开源组织的一个分布式计算开源框架,提供了一个分布式文件系统子项目(HDFS)和支持MapReduce分布式计算的软件架...

zimingforever
今天
4
0
八大包装类型的equals方法

先看其中一个源码 结论:八大包装类型的equals方法都是先判断类型是否相同,不相同则是false,相同则判断值是否相等 注意:包装类型不能直接用==来等值比较,否则编译报错,但是数值的基本类型...

xuklc
今天
2
0
NoSQL , Memcached介绍

什么是NoSQL 非关系型数据库就是NoSQL,关系型数据库代表MySQL 对于关系型数据库来说,是需要把数据存储到库、表、行、字段里,查询的时候根据条件一行一行地去匹配,当量非常大的时候就很耗...

TaoXu
昨天
4
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部