主要注意流程:

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. Oracle的序列

    Oracle的序列 序列介绍 序列是Oracle提供的用于产生一系列唯一数字的数据库对象. 使用序列能够实现自己主动产生主键值.序列也能够在很多用户并发环境中使用.为所实用户生成不反复的顺序数字,并且 ...

  2. 网页WEB打印控件

    网页WEB打印控件制作 在WEB系统中,打印的确是比较烦人的问题,如果我们能制作一个属于自己的自定义的打印插件,那么我们在后续自定义打印的时候能随心所欲的控制打印,这样的效果对于程序员来说是非常开心的 ...

  3. 如何将内存中的位图数据绘制在DC上

    假如你定义了一个位图类,里面包含位图头,位图信息头,调色板,位图数据.然后你按照位图的格式将位图文件读入你的类中,现在你知道了位图的全部信息了.主要信息包含在位图信息头里面,数据则在位图数据缓冲里面. ...

  4. 80 多个 Linux 系统管理员必备的监控工具

    随着互联网行业的不断发展,各种监控工具多得不可胜数.这里列出网上最全的监控工具.让你可以拥有超过80种方式来管理你的机器.在本文中,我们主要包括以下方面: 命令行工具 网络相关内容 系统相关的监控工具 ...

  5. K. Perpetuum Mobile

    The world famous scientist Innokentiy almost finished the creation of perpetuum mobile. Its main par ...

  6. LLBL Gen Pro 5.0

    LLBL Gen Pro 5.0 企业应用开发入门 Solutions Design 公司于2016年5月发布了LLBL Gen Pro 5.0,这个新版本的发布出乎于我的意料.我的猜想是从4.2升级 ...

  7. mysql基础:mysql列类型--时间和日期

    mysql列类型--整型 http://blog.csdn.net/jk110333/article/details/9342283 mysql列类型--字符串http://blog.csdn.net ...

  8. Processing_百度百科

    Processing_百度百科 Processing

  9. 代码写解压zip文件

    最近项目中服务器方返回了zip文件类型的文件,在网上搜了好多资料做成一个Demo,这里用来详解一下. ZipArchive类来源于网络.还望多多交流. 1.首先添加libz.dylib框架 2.前往h ...

  10. matlab画棋盘格程序

    转载请注明出处:zhouyelihua**http://blog.csdn.net/zhouyelihua/article/details/46674191** 意义 在摄像机标定过程中经常须要打印棋 ...