socket函数接口

1、int socket(int protofamily, int type, int protocol)

(1)protofamily:即协议域,又称为协议族(family)。

常用的协议族有,AF_INET(IPV4)、AF_INET6(IPV6)、AF_LOCAL(或称AF_UNIX,Unix域socket)、AF_ROUTE等等。协议族决定了socket的地址类型,在通信中必须采用对应的地址,如AF_INET决定了要用ipv4地址(32位的)与端口号(16位的)的组合、AF_UNIX决定了要用一个绝对路径名作为地址。

(2)type:指定socket类型。

常用的socket类型有,SOCK_STREAM、SOCK_DGRAM、SOCK_RAW、SOCK_PACKET、SOCK_SEQPACKET等等(socket的类型有哪些?)。

(3)protocol:就是指定协议。

常用的协议有,IPPROTO_TCP、IPPTOTO_UDP、IPPROTO_SCTP、IPPROTO_TIPC等,它们分别对应TCP传输协议、UDP传输协议、STCP传输协议、TIPC传输协议(这个协议我将会单独开篇讨论!)。

2、int bind(int sockfd, const struct sockaddr *addr, socklen_t addrlen)

(1)sockfd:即socket()返回的套接字描述符,bind()函数就是为了给这个套接字绑定一个名字

(2)addr:指要绑定给socketfd的地址;不同的协议绑定的地址不一样

- struct sockaddr_in {

  sa_family_t sin_family; /* address family: AF_INET */

  in_port_t sin_port; /* port in network byte order */

  struct in_addr sin_addr; /* internet address */

};

/* Internet address. */struct in_addr {

  uint32_t s_addr; /* address in network byte order */

};

- ipv6对应的是:

struct sockaddr_in6 { 

  sa_family_t sin6_family; /* AF_INET6 */ 

  in_port_t sin6_port; /* port number */ 

  uint32_t sin6_flowinfo; /* IPv6 flow information */ 

  struct in6_addr sin6_addr; /* IPv6 address */ 

  uint32_t sin6_scope_id; /* Scope ID (new in 2.4) */ 

};

struct in6_addr { 

  unsigned char s6_addr[16]; /* IPv6 address */ 

};

- Unix域对应的是:

#define UNIX_PATH_MAX 108

struct sockaddr_un { 

  sa_family_t sun_family; /* AF_UNIX */ 

  char sun_path[UNIX_PATH_MAX]; /* pathname */ 

};

(3)addrlen:对应的是地址的长度。

3、int listen(int sockfd, int backlog)

(1)sockfd: 要监听的socket描述字;

(2)backlog:相应socket可以排队的最大连接个数。

socket()函数创建的socket默认是一个主动类型的,listen函数将socket变为被动类型的,等待客户的连接请求。

4、int connect(int sockfd, const struct sockaddr *addr, socklen_t addrlen)

(1)sockfd:客户端的socket描述字;

(2)addr:服务器的socket地址;

(3)addrlen:socket地址的长度;

客户端通过调用connect函数来建立与TCP服务器的连接。

5、int accept(int sockfd, struct sockaddr *addr, socklen_t *addrlen)

(1)sockfd: 监听套接字,这个套接字用来监听一个端口,当有一个客户与服务器连接时关联这个端口号,在socket创建后绑定时地址参数的端口号

(2)addr: 这是一个结果参数,它用来接受一个返回值,这返回值指定客户端的地址,当然这个地址是通过某个地址结构来描述的,用户应该知道这一个什么样的地址结构。如果对客户的地址不感兴趣,那么可以把这个值设置为NULL。

(3)addrlen: 如同大家所认为的,它也是结果的参数,用来接受上述addr的结构的大小的,它指明addr结构所占有的字节个数。同样的,它也可以被设置为NULL。

如果accept成功返回,则服务器与客户已经正确建立连接了,此时服务器通过accept返回的套接字来完成与客户的通信。

注意:

  accept默认会阻塞进程,直到有一个客户连接建立后返回,它返回的是一个新可用的套接字,这个套接字是连接套接字。

此时我们需要区分两种套接字,

  监听套接字: 监听套接字正如accept的参数sockfd,它是监听套接字,在调用listen函数之后,是服务器开始调用socket()函数生成的,称为监听socket描述字(监听套接字)

  连接套接字:一个套接字会从主动连接的套接字变身为一个监听套接字;而accept函数返回的是已连接socket描述字(一个连接套接字),它代表着一个网络已经存在的点点连接。

6、read()、write()

  #include <unistd.h>

  ssize_t read(int fd, void *buf, size_t count);

  ssize_t write(int fd, const void *buf, size_t count);

  #include <sys/types.h>

  #include <sys/socket.h>

  ssize_t send(int sockfd, const void *buf, size_t len, int flags);

  ssize_t recv(int sockfd, void *buf, size_t len, int flags);

  ssize_t sendto(int sockfd, const void *buf, size_t len, int flags, const struct sockaddr *dest_addr, socklen_t addrlen);

  ssize_t recvfrom(int sockfd, void *buf, size_t len, int flags, struct sockaddr *src_addr, socklen_t *addrlen);

  ssize_t sendmsg(int sockfd, const struct msghdr *msg, int flags);

  ssize_t recvmsg(int sockfd, struct msghdr *msg, int flags);

7、int close(int fd)

close一个TCP socket的缺省行为时把该socket标记为以关闭,然后立即返回到调用进程。该描述字不能再由调用进程使用,也就是说不能再作为read或write的第一个参数。

注意:close操作只是使相应socket描述字的引用计数-1,只有当引用计数为0的时候,才会触发TCP客户端向服务器发送终止连接请求。

<think>好的,用户想了解MCP(Model Context Protocol)的相关信息及其在IT领域的应用。首先,我需要从提供的引用资料中提取关键点,并组织成一个结构清晰的回答。 根据引用[1],MCP是一个开放协议,用于AI应用与本地或远程资源的安全交互。引用[2]提到它实现了LLM应用与外部数据源的无缝集成,由uv这个Python包管理器支持。引用[3]则说明了其客户端-服务器架构、数据交换形式、安全机制和未来扩展计划。 接下来,我需要将信息分点整理,确保涵盖定义、核心功能、技术架构、应用场景、安全机制和未来发展。同时,要生成相关问题,帮助用户深入理解。要注意使用中文,正确应用LaTeX格式,比如提到协议版本时用$v1.0$,并引用标识。最后,检查是否符合所有系统级指令,特别是引用标注的位置和格式是否正确。</think>### MCP(Model Context Protocol)模型上下文协议解析 #### 一、定义与核心功能 MCP是一种实现AI应用程序与本地/远程资源安全交互的开放协议,通过标准化接口支持LLM与外部数据源的无缝集成[^1][^2]。其核心功能包括: 1. 构建$AI \leftrightarrow Resource$双向通信通道 2. 支持JSON、XML、Protobuf等多种数据格式交换 3. 提供动态资源分配机制,如内存管理$M_{alloc}(size)$ 4. 实现访问控制策略$P_{access} = \{user, resource, permission\}$ #### 二、技术架构 采用客户端-服务器模式,当前架构包含: $$Client \xrightarrow[SSL/TLS]{REST API} Server \xrightarrow{Resource Manager} Data Sources$$ 其中uv工具包(Rust编写)提供快速部署能力,支持Python环境下的依赖管理 #### 三、典型应用场景 1. 企业知识库实时检索:$\exists x \in KB, query(x) \rightarrow result$ 2. 分布式计算资源调度 3. 多模态数据处理流水线 4. 联邦学习中的安全数据交换 #### 四、安全机制 协议内置三重防护: 1. 传输层加密:$E_{AES-256}(data)$ 2. 访问控制矩阵:$ACL = \bigcup_{i=1}^{n}(user_i, resource_i)$ 3. 操作审计日志:$\log(t)=\sum event(t_i)$ #### 五、未来发展路径 根据路线图,2024年将实现: 1. OAuth 2.0集成:$Auth_{flow} = code \rightarrow token$ 2. 跨云平台适配:$AWS \oplus Azure \oplus GCP$ 3. 量子安全加密升级:$QKD_{BB84}$协议支持[^3] ```python # MCP基础调用示例 import mcp client = mcp.Client(api_key="your_key") response = client.query( resource="database", operation="SELECT * FROM table WHERE condition='value'", format="SQL" ) print(response.data) ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值