0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

Socket采用C/S模型进行设计的服务器模型

Q4MP_gh_c472c21 ? 来源:未知 ? 作者:李倩 ? 2018-03-24 11:20 ? 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

Socket的中文翻译为“插座”,在计算机世界里称为套接字。Socket最初是作为网络上不同主机之间进程的通信接口,后来应用越来越广,在同一主机上的不同进程之间通信也可以用Socket。简单来说,当网络上不同主机之间的两个进程(A、B)采用Socket进行通信时,那么它们之间需要建立一个通信端点,即创建Socket,创建Socket时就分配端口号和网络地址。当进程A向进程B发送数据时,那么进程A必须要知道进程B的网络地址及端口号。

Socket采用C/S模型进行设计的,即Client/Server,面向客户端—服务器模型。

每一个Socket都用一个半相关描述:

{协议,本地地址,本地端口}

一个完整的Socket则用一个相关描述:

{协议,本地地址,本地端口,远程地址,远程端口}

一、Socket的类型

Socket有三种类型:

1、字节流套接字(SOCK_STREAM)

字节流的套接字可以提供可靠的数据传输、面向连接的通讯流。数据按何种顺序发送,就按何种顺序接收。例如,当我们按顺序发送A-B-C,那么在数据到达接收端时,它的顺序也是A-B-C。字节流套接字采用的是TCP(Transmission Control Protocol)协议。保证了数据传输的可靠性。

2、数据报套接字(SOCK_DGRAM

数据报套接字定义了一种无连接的服务。所谓无连接服务,简单来说,即在发送数据时,无需在收发两端建立类似TCP那样的握手连接,在发送时,将数据打包,然后加上远程IP地址,即可把该数据包发送出去。

数据通过相互独立的报文进行传输。并且是无序的、不可靠的传输。

3、原始套接字(SOCK_ROW)

原始套接字是我们需要关心的,因为我们的Socket CAN采用的即是原始套接字。该接口允许对较底层协议进行操作,如IP、ICMP等。原始套接字常用于检验新的协议实现或访问现有服务中配置的新设备。

套接字的工作流程如下:

先启动服务器,通过调用socket()函数建立一个套接字,然后调用bind()函数将该套接字和本地网络地址联系在一起,再调用listen()函数使套接字做好侦听的准备,并规定它的请求队列的长度,之后就调用accept()函数来接收连接。客户端在建立套接字之后就可调用 connect()和服务器建立连接。连接一旦建立,客户端和服务器之间就可以通过调用recv()/recvfrom()函数和send()/sendto函数来进行发收数据。最后,待数据传送结束后,双方调用close()函数关闭套接字。

下面我们来写两个简单的基于Socket的CAN应用程序,但是我们采用的是SOCK_ROW,因此在套接字工作流程上有区别于SOCK_STREAM和SOCK_DGRAM。由于Socket采用C/S模型进行设计的,所以我们的这两个程序也分别为Server和Client。

首先是server端的程序,我们需要写一个服务器的程序,该程序接收来自客户端发来的数据,代码如下:

int can_recv()

{

int sock_fd;

unsigned long nbytes, len;

struct sockaddr_can addr;

struct ifreq ifr;

/*为了能够接收CAN报文,我们需要定义一个CAN数据格式的结构体变量*/

struct can_frame frame;

struct can_frame *ptr_frame;

/*建立套接字,设置为原始套接字,原始CAN协议*/

sock_fd = socket(PF_CAN,SOCK_RAW,CAN_RAW);

/*以下是对CAN接口进行初始化,如设置CAN接口名,即当我们用ifconfig命令时显示的名字*/

strcpy(ifr.ifr_name,"can0");

ioctl(sock_fd, SIOCGIFINDEX, &ifr);

printf("can0 can_ifindex = %x\n",ifr.ifr_ifindex);

/*设置CAN协议*/

addr.can_family = AF_CAN;

addr.can_ifindex = 0;

/*将刚生成的套接字与网络地址进行绑定*/

bind(sock_fd, (struct sockaddr*)&addr, sizeof(addr));

/*开始接收数据*/

nbytes = recvfrom(sock_fd, &frame, sizeof(struct can_frame), 0, (struct sockaddr *)&addr, &len);

/*get interface name of the received CAN frame*/

ifr.ifr_ifindex = addr.can_ifindex;

ioctl(sock_fd, SIOCGIFNAME, &ifr);

printf("Received a CAN frame from interface %s\n",ifr.ifr_name);

/*将接收到的CAN数据打印出来,其中ID为标识符,DLC为CAN的字节数,DATA为1帧报文的字节数*/

printf("CAN frame:\n ID = %x\n DLC = %x\n" \

"DATA = %s\n",frame.can_id,frame.can_dlc,frame.data);

ptr_frame = &frame;

return 0;

}

接下来是CAN的发送程序,即客户端,代码如下:

int can_send()

{

int sock_fd;

unsigned long nbytes;

struct sockaddr_can addr;

struct ifreq ifr;

struct can_frame frame;

/*建立套接字,设置为原始套接字,原始CAN协议*/

sock_fd = socket(PF_CAN,SOCK_RAW,CAN_RAW);

/*以下是对CAN接口进行初始化,如设置CAN接口名,即当我们用ifconfig命令时显示的名字*/

strcpy((char *)(ifr.ifr_name), "can0");

ioctl(sock_fd, SIOCGIFINDEX, &ifr);

printf("can0 can_ifindex = %x\n", ifr.ifr_ifindex);

addr.can_family = AF_CAN;

addr.can_ifindex = ifr.ifr_ifindex;

/*将刚生成的套接字与CAN套接字地址进行绑定*/

bind(sock_fd, (struct sockaddr*)&addr, sizeof(addr));

/*设置CAN帧的ID号,可区分为标准帧和扩展帧的ID号*/

frame.can_id = 0x1122;

strcpy((char *)frame.data,"hello");

frame.can_dlc = strlen(frame.data);

printf("Send a CAN frame from interface %s\n", ifr.ifr_name);

/*开始发送数据*/

nbytes = sendto(sock_fd, &frame, sizeof(struct can_frame), 0, (struct sockaddr*)&addr, sizeof(addr));

return 0;

}

上面两个程序看完后,大家可能会有疑问,为什么这两个程序没有listen()和accept()函数呢?其实这两个程序是独立的运行的,并不像字节流套接字(SOCK_STREAM)和数据报套接字(SOCK_DGRAM),需要先运行服务器进行侦听。SOCK_STREAM和SOCK_DGRAM的两个server和client程序是通过网络相互收发数据。而CAN的socket的server和client程序收发数据的对象是CAN总线。server从CAN总线上接收数据,client将数据发到CAN总线上,当CAN总线上有数据时,server才能接收数据,当CAN总线空闲时,client才能将数据发送出去。

以上是对套接字的简单理解,并附上socket CAN的简单上层应用代码。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • CAN
    CAN
    +关注

    关注

    57

    文章

    2937

    浏览量

    468897
  • 服务器
    +关注

    关注

    13

    文章

    9859

    浏览量

    88416
  • Socket
    +关注

    关注

    1

    文章

    213

    浏览量

    36061

原文标题:为了能够对Socket CAN的深入理解,我们需要了解Socket的机制

文章出处:【微信号:gh_c472c2199c88,微信公众号:嵌入式微处理器】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    FA模型访问Stage模型DataShareExtensionAbility说明

    FA模型访问Stage模型DataShareExtensionAbility 概述 无论FA模型还是Stage模型,数据读写功能都包含客户端和
    发表于 06-04 07:53

    RAKsmart高性能服务器集群:驱动AI大语言模型开发的算力引擎

    RAKsmart高性能服务器集群凭借其创新的硬件架构与全栈优化能力,成为支撑大语言模型开发的核心算力引擎。下面,AI部落小编带您了解RAKsmart如何为AI开发者提供从模型训练到落地的全链路支持。
    的头像 发表于 04-15 09:40 ?315次阅读

    如何在RAKsmart服务器上实现企业AI模型部署

    AI模型的训练与部署需要强大的算力支持、稳定的网络环境和专业的技术管理。RAKsmart作为全球领先的服务器托管与云计算服务提供商,已成为企业部署AI模型的理想选择。那么,如何在RAK
    的头像 发表于 03-27 09:46 ?563次阅读

    利用RAKsmart服务器托管AI模型训练的优势

    AI模型训练需要强大的计算资源、高效的存储和稳定的网络支持,这对服务器的性能提出了较高要求。而RAKsmart服务器凭借其核心优势,成为托管AI模型训练的理想选择。下面,AI部落小编为
    的头像 发表于 03-18 10:08 ?323次阅读

    请问是否可以在模型服务器中使用REST请求OpenVINO?预测?

    是否可以在模型服务器中使用 REST 请求OpenVINO?预测?
    发表于 03-05 08:06

    使用face-detection-retail-0004运行OpenVINO?模型服务器时“缺少特定名称的输入”怎么解决?

    使用 face-detection-retail-0004 OpenVINO?模型服务器启动。 通过与 KServe 兼容的 RESTful API 启动推理: \"inputs
    发表于 03-05 08:05

    昇腾推理服务器+DeepSeek大模型 技术培训在图为科技成功举办

    2月17日,华为政企业务团队受邀莅临图为科技深圳总部,并成功举办了一场聚焦于《昇腾推理服务器+DeepSeek大模型》的专业知识培训。 此次培训活动不仅深化了双方的技术交流,更标志着昇腾AI
    的头像 发表于 02-26 17:38 ?683次阅读
    昇腾推理<b class='flag-5'>服务器</b>+DeepSeek大<b class='flag-5'>模型</b> 技术培训在图为科技成功举办

    如何确保云服务器上的DeepSeek-R1模型安全?

    确保云服务器上DeepSeek-R1模型的安全性,需要从多个方面入手,以下是一些关键措施: 1、使用安全防护工具 Amazon Bedrock Guardrails:AWS提供了Bedrock
    的头像 发表于 02-12 13:15 ?684次阅读

    服务器 Flexus X 实例:RAG 开源项目 FastGPT 部署,玩转大模型

    本篇文章主要通过 Flexus 云服务器 X 实例 部署 RAG 开源项目 FastGPT,通过 FastGPT 可以使用大模型生成用户需要的内容。 Flexus 云服务器 X 实例具有柔性算力,六
    的头像 发表于 01-08 11:49 ?1382次阅读
    云<b class='flag-5'>服务器</b> Flexus X 实例:RAG 开源项目 FastGPT 部署,玩转大<b class='flag-5'>模型</b>

    基于 Flexus 云服务器 X 实例体验大模型部署体验测评

    也很快。但是大家目前都是在体验,能不能部署一下试试呢? 今天,我们就以华为云 Flexus 云服务器 X 实例来部署一下,顺便测测其性能看看。 在华为云 828 B2B 企业节狂潮中,Flexus X 实例的限时大促销震撼来袭,绝对是你不容错过的超级福利!对于那些追求极致算力、对自
    的头像 发表于 12-24 12:27 ?609次阅读
    基于 Flexus 云<b class='flag-5'>服务器</b> X 实例体验大<b class='flag-5'>模型</b>部署体验测评

    【「大模型启示录」阅读体验】如何在客服领域应用大模型

    多个因素以确保所选模型能够满足企业的具体需求和目标。首先,企业需要明确自己的客服需求和目标。例如,是否需要24小时在线客服服务?是否需要处理复杂问题的能力?是否需要个性化服务?明确这些需求有助于企业更好
    发表于 12-17 16:53

    socket 客户端与服务器的实现

    1. 理解Socket 在计算机网络中,socket是一种通信机制,允许两个程序(一个客户端和一个服务器)通过网络进行通信。在Python中,可以使用
    的头像 发表于 11-12 14:30 ?879次阅读

    socket 与 RESTful API 的使用

    Socket是一种网络通信协议,它允许程序在网络中进行双向通信。Socket分为客户端Socket服务器
    的头像 发表于 11-12 14:22 ?1092次阅读

    AI模型托管原理分析

    AI模型托管是指将训练好的AI模型部署在云端或边缘服务器上,由第三方平台提供模型运行、管理和优化等服务。以下,AI部落小编将对AI
    的头像 发表于 11-07 09:33 ?872次阅读

    GPU服务器AI网络架构设计

    众所周知,在大型模型训练中,通常采用每台服务器配备多个GPU的集群架构。在上一篇文章《高性能GPU服务器AI网络架构(上篇)》中,我们对GPU网络中的核心术语与概念
    的头像 发表于 11-05 16:20 ?1356次阅读
    GPU<b class='flag-5'>服务器</b>AI网络架构设计