主要注意流程:

STREAM SOCKET:

Server :  socket() --->  bind() ---> listen()  ---> accept()

Client:    scoket() ---> connect()

参考文章一篇就够:http://troydhanson.github.io/misc/Unix_domain_sockets.html

自己写的 一个 Server 和 一个Client:

//Server
//
// unix_domain_server.c
// UnixDomainServer
//
// Created by gtliu on 7/11/13.
// Copyright (c) 2013 GT. All rights reserved.
// #include "MITLogModule.h"
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <errno.h>
#include <stddef.h>
#include <unistd.h>
#include <sys/socket.h>
#include <sys/un.h> #define FUNC_FAIL -1
#define FUNC_SUCCESS 0
#define SOCKADDR_UN_SUN_PATH_MAX_LEN 103 // 104 - 1
#define SER_ACCEPT_CON_NUM 1 /**
* Create a server endpoint of a connection.
*
* @param scok_path: the unix domain socket path
* @return return the file descirption if all ok, <0 on err
*/
int create_serv_listen(const char *sock_path)
{
size_t path_len = strlen(sock_path);
if (path_len == 0) {
MITLogWrite(MITLOG_LEVEL_ERROR, "socket path can't be empty");
return FUNC_FAIL;
} else if (path_len > SOCKADDR_UN_SUN_PATH_MAX_LEN) {
MITLogWrite(MITLOG_LEVEL_ERROR, "socket path length must less than%d", SOCKADDR_UN_SUN_PATH_MAX_LEN);
return FUNC_FAIL;
} int fd = 0, size = 0;
struct sockaddr_un server_un;
memset(&server_un, 0, sizeof(server_un));
server_un.sun_family = AF_UNIX;
strncpy(server_un.sun_path, sock_path, sizeof(server_un.sun_path) - 1); if ((fd = socket(AF_UNIX, SOCK_STREAM, 0)) < 0) {
MITLogWrite(MITLOG_LEVEL_ERROR, "socket() faild:%s", strerror(errno));
return FUNC_FAIL;
}
/* in case it already exists */
unlink(sock_path); size = offsetof(struct sockaddr_un, sun_path) + strlen(server_un.sun_path);
if (bind(fd, (struct sockaddr *)&server_un, size) < 0) {
MITLogWrite(MITLOG_LEVEL_ERROR, "bind() failed:%s", strerror(errno));
close(fd);
return FUNC_FAIL;
} if (listen(fd, 0) < 0) {
MITLogWrite(MITLOG_LEVEL_ERROR, "listen() failed:%s", strerror(errno));
close(fd);
return FUNC_FAIL;
} return fd;
} /**
* Accept a client's connection and return the relative file descriptor.
*
* @param listen_fd: the server socket file descriptor
* @return return the file descirption if all ok, <0 on err
*/
int serv_accept(int listen_fd)
{
int child_fd = 0, len = 0;
struct sockaddr_un income_un;
len = sizeof(income_un); if ((child_fd = accept(listen_fd, (struct sockaddr *)&income_un, &len)) < 0) {
MITLogWrite(MITLOG_LEVEL_ERROR, "accept() failed:%s", strerror(errno));
/* often errno=EINTR, if signal caught */
return FUNC_FAIL;
}
return child_fd;
} int main(int argc, const char * argv[])
{ MITLogOpen("unix_domain_server"); char *sock_path = "/tmp/domain_socket_one";
if (argc > 1) {
sock_path = (char *) argv[1];
} MITLogWrite(MITLOG_LEVEL_COMMON, "Starting the server...");
int listen_fd = create_serv_listen(sock_path);
if (listen_fd == FUNC_FAIL) {
return FUNC_FAIL;
} MITLogWrite(MITLOG_LEVEL_COMMON, "Wait for the client... listen_fd:%d", listen_fd);
int child_fd = serv_accept(listen_fd);
if (child_fd == FUNC_FAIL) {
close(listen_fd);
return FUNC_FAIL;
} char recv_buffer[1024] = {0};
while (1) {
MITLogWrite(MITLOG_LEVEL_COMMON, "Wait for the message...");
if(read(child_fd, recv_buffer, sizeof(recv_buffer) - 1) > 0) {
printf("Recieve message:%s\n", recv_buffer);
}
sleep(2);
} MITLogClose();
return 0;
}
//Client
//
// main.c
// UnixDomainClient
//
// Created by gtliu on 7/11/13.
// Copyright (c) 2013 GT. All rights reserved.
// #include "MITLogModule.h"
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <errno.h>
#include <stddef.h>
#include <unistd.h>
#include <sys/socket.h>
#include <sys/un.h>
#include <sys/stat.h> #define FUNC_FAIL -1
#define FUNC_SUCCESS 0
#define SOCKADDR_UN_SUN_PATH_MAX_LEN 103 // 104 - 1
#define SER_ACCEPT_CON_NUM 1 /**
* Create a server endpoint of a connection.
*
* @param scok_path: the unix domain socket path
* @return return the file descirption if all ok, <0 on err
*/
int client_connection(const char *sock_path)
{
size_t path_len = strlen(sock_path);
if (path_len == 0) {
MITLogWrite(MITLOG_LEVEL_ERROR, "socket path can't be empty");
return FUNC_FAIL;
} else if (path_len > SOCKADDR_UN_SUN_PATH_MAX_LEN) {
MITLogWrite(MITLOG_LEVEL_ERROR, "socket path length must less than%d", SOCKADDR_UN_SUN_PATH_MAX_LEN);
return FUNC_FAIL;
} int fd = 0, len = 0;
if ((fd = socket(AF_UNIX, SOCK_STREAM, 0)) < 0) {
MITLogWrite(MITLOG_LEVEL_ERROR, "socket() faild:%s", strerror(errno));
return FUNC_FAIL;
} struct sockaddr_un client_un;
memset(&client_un, 0, sizeof(client_un));
client_un.sun_family = AF_UNIX;
strncpy(client_un.sun_path, sock_path, sizeof(client_un.sun_path) - 1); len = offsetof(struct sockaddr_un, sun_path) + strlen(client_un.sun_path);
if ((connect(fd, (struct sockaddr *)&client_un, len)) < 0) {
MITLogWrite(MITLOG_LEVEL_ERROR, "connect() failed:%s", strerror(errno));
close(fd);
return FUNC_FAIL;
} return fd;
} int main(int argc, const char * argv[])
{ MITLogOpen("unix_domain_client"); char *sock_path = "/tmp/domain_socket_one";
if (argc > 1) {
sock_path = (char *) argv[1];
} MITLogWrite(MITLOG_LEVEL_COMMON, "Starting the client...");
int client_fd = client_connection(sock_path);
if (client_fd == FUNC_FAIL) {
return FUNC_FAIL;
} for (int i=1; i < 100; ++i) {
MITLogWrite(MITLOG_LEVEL_COMMON, "Send message to server...");
char msg[256] = {0};
sprintf(msg, "client message :%d", i);
if(write(client_fd, msg, strlen(msg)) > 0) {
MITLogWrite(MITLOG_LEVEL_COMMON, "Send message :%d success", i);
}
sleep(2);
} MITLogClose();
return 0;
}

Unix Domain Socket 域套接字实现的更多相关文章

  1. 【转】PHP实现系统编程(四)--- 本地套接字(Unix Domain Socket)

    原文:http://blog.csdn.net/zhang197093/article/details/78143687?locationNum=6&fps=1 --------------- ...

  2. Unix domain socket

    转载:http://www.cnblogs.com/chekliang/p/3222950.html socket API原本是为网络通讯设计的,但后来在socket的框架上发展出一种IPC机制,就是 ...

  3. (unix domain socket)使用udp发送>=128K的消息会报ENOBUFS的错误

    一个困扰我两天的问题, Google和Baidu没有找到解决方法! 此文为记录这个问题,并给出原因和解决方法. 1.Unix domain socket简介 unix域协议并不是一个实际的协议族,而是 ...

  4. [apue] 作为 daemon, 启动 Unix Domain Socket 侦听失败?

    前段时间写一个传递文件句柄的小 demo,有 server 端.有 client 端,之间通过 Unix Domain Socket 通讯. 在普通模式下,双方可以正常建立连接,当server端作为d ...

  5. Envoy 基础教程:使用 Unix Domain Socket(UDS) 与上游集群通信

    Envoy Proxy 在大多数情况下都是作为 Sidecar 与应用部署在同一网络环境中,每个应用只需要与 Envoy(localhost)交互,不需要知道其他服务的地址.然而这并不是 Envoy ...

  6. Unix domain socket 简介

    Unix domain socket 又叫 IPC(inter-process communication 进程间通信) socket,用于实现同一主机上的进程间通信.socket 原本是为网络通讯设 ...

  7. mysql unix domain socket and network socket, ssh key

    当主机填写为localhost时mysql会采用 unix domain socket连接 当主机填写为127.0.0.1时mysql会采用tcp方式连接 这是linux套接字网络的特性,win平台不 ...

  8. linux一切皆文件之Unix domain socket描述符(二)

    一.知识准备 1.在linux中,一切皆为文件,所有不同种类的类型都被抽象成文件(比如:块设备,socket套接字,pipe队列) 2.操作这些不同的类型就像操作文件一样,比如增删改查等 3.主要用于 ...

  9. Unix domain socket IPC

    UNIX Domain socket 虽然网络socket也可用于同一台主机的进程间通讯(通过lo地址127.0.0.1),但是unix domain socket用于IPC更有效率:不需要经过网络协 ...

随机推荐

  1. SharePoint 2013 &quot;通知我&quot;简单的功能

    简单的功能 "通知我"内部列表或文档库中的主要项目.加入/删除/修改等操作,用户的E- mail通知设定功能:设置列表或文档库通知的能力,有可能设置通知为一个单一的项目.这是Sha ...

  2. Eclipse用法和技巧九:自动添加try/catch块2

    上一篇介绍了如何给未检查异常快速增加try/catch语句,这里在补充一点其他相关操作.有时候我们增加了try/catch之后还需要在加一个finally块,比如android上每次分配一个curso ...

  3. 高性能JavaScript模板引擎原理解析

    随着 web 发展,前端应用变得越来越复杂,基于后端的 javascript(Node.js) 也开始崭露头角,此时 javascript 被寄予了更大的期望,与此同时 javascript MVC ...

  4. Swift - 多线程实现方式(2) - NSOperation和NSOperationQueue

    1,Swift继续使用Object-C原有的一套线程,包括三种多线程编程技术: (1)NSThread (2)Cocoa NSOperation(NSOperation和NSOperationQueu ...

  5. 从注册流程 分析如何安全退出多个Activity 多种方式(附DEMO)

    前言   由于一个同学问到我如何按照一个流程走好之后回到首页,我以前看到过4个解决方案,后来发现有做个记录和总结的必要,就写了这篇博文.(之前看小强也写过一篇,这里通过自身的分析完整的总结一下以下6种 ...

  6. JQuery 插件之Ajax Autocomplete(ajax自动完成)

    平时用百度,谷歌搜索的时候 会有一个下 拉列表进行提示 这是一个非常好的功能 本文要介绍的这个JQuery 插件 名叫Ajax Autocomplete 顾名思义 ajax 也就是用ajax的方式获取 ...

  7. Boost Thread学习笔记三

    下面先对condition_impl进行简要分析.condition_impl在其构造函数中会创建两个Semaphore(信号量):m_gate.m_queue,及一个Mutex(互斥体,跟boost ...

  8. [置顶] strcpy和memcpy的区别

    strcpy和memcpy都是标准C库函数,它们有下面的特点. strcpy提供了字符串的复制.即strcpy只用于字符串复制,并且它不仅复制字符串内容,还会复制字符串的结束符. 已知strcpy函数 ...

  9. JVM学习笔记(一)------的基本结构

    从Java视台的逻辑结构.我们能够从图中学习JVM: 您可以从图表清楚地看到Java该平台包括各种逻辑模块.还可以学习JDK与JRE差异 于JVM它们的物理结构,我们可以看一下从图计划: 为JVM学习 ...

  10. vc 按钮自绘

    按钮自绘,将按钮区域分成三部分,左边.右边.中间都由贴图绘制,可用于手动进度条按钮,或者左右选择项按钮 cpp代码部分: // LRSkinButton.cpp : implementation fi ...