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

发布者:EnchantedMelody最新更新时间:2018-03-25 来源: 嵌入式ARM关键字:CAN  服务器  Socket 手机看文章 扫描二维码
随时随地手机看文章

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  服务器  Socket 引用地址:Socket采用C/S模型进行设计的服务器模型

上一篇:异构环境下的存储管理,关键是选择靠谱软件
下一篇:嵌入式Wi-F的来源以及与普通Wi-Fi的区别

推荐阅读最新更新时间:2024-05-07 17:56

Astera Labs 推出业界首个 CXL™ 2.0 Memory Accelerator SoC Platform
Astera Labs 推出业界首个 CXL™ 2.0 Memory Accelerator SoC Platform Leo CXL™ Memory Accelerator 技术引领新一代服务器分层内存,解决了数据中心和云端的内存容量和带宽瓶颈 中国,北京 - 2021年11月23日-智能系统连接解决方案的先驱 Astera Labs 今日宣布为 Compute Express Link (CXL) 1.1/2.0 互连推出全新 Leo Memory Accelerator Platform,该平台可为处理器、工作负载加速器和智能 I/O 设备实现强大的分解内存池化和扩展。Leo 解决了处理器的内存带宽瓶颈和容量限制,同
[嵌入式]
基于CAN总线模块的网络测控系统的实现
  1 引言        CAN总线控制网络和因特网采用统一的协议标准是 CAN总线控制网络和因特网集成的方式之一,目前,它还是一个探索性的工作。虽然嵌入式控制的应用已经十分广泛,但是 CAN总线控制网络和因特网采用统一的协议标准还是一个崭新的课题。这种方式将成为控制网络和因特网络完全集成的最终解决方案。由于分布式控制网络采用了面向不同应用的协议标准,因此二者集成时需要某种数据格式的转换机制,这将使系统复杂化,而且也不能确保数据的完整性。本文给出了基于 CAN总线模块的网络测控系统的各个硬件模块,以及 CAN通信的软件编程思想。 2 硬件系统的逻辑结构模块    2.1 分布式测控系统结构    图
[嵌入式]
在新基建的催化下,服务器市场机遇与挑战并存
近期,IDC 发布 2019 年第四季度及全年全球服务器市场调查数据,2019 年全球服务器出货量和销售额分别为 1174 万台和 873 亿美元,同比轻微下降 0.9%和 1.7%。其中四季度全球服务器市场增长旺盛,销售额和出货量分别同比增长 7.5%和 14.0%,抵消了前三个季度的部分下滑态势。 戴尔、HPE、浪潮位列 2019 年全球服务器市场的销售额前三,戴尔占比 17.8%,销售额同比下降 6.9%;HPE 占比 13.8%,销售额下降 8.4%;浪潮占比 7%,销售额增长 18.1%,是全球唯一保持两位数增长的服务器厂商。 然而,当前肺炎疫情来势汹汹,全球蔓延,截止到目前为止,全球新冠肺炎疫情确诊人数
[嵌入式]
在新基建的催化下,<font color='red'>服务器</font>市场机遇与挑战并存
PIC18F45K80 CAN通信实例,可通过模拟调试
PIC18F 45K80 CAN 通信实例,可通过模拟调试,注意选编译器,C18是不能通过。 单片机源程序如下: #pragma config XINST = OFF // CONFIG1L #pragma config FOSC = INTIO2, FCMEN = OFF, IESO = OFF ,PLLCFG = OFF // CONFIG1H #pragma config BOREN = OFF, BORV = 0 // CONFIG2L #pragma config WDTEN = OFF
[单片机]
PIC单片机车载仪表带CAN总线通讯源代码
单片机源程序如下: ;****************************************************************************** ; * ; Filename: FB_ZHU_JI_PIC16LF1947.ASM * ; Date: 2012.01.6 * ; File Version: 1.0 * ;
[单片机]
Facebook开源新一代人工智能训练服务器
   Facebook 正式宣布了新一代的服务器设计方案——“Big Basin”,它是AI训练系统Big Sur系列的继承者。这些使用英伟达的GPU作为处理核心的服务器连接起来,形成一个巨大的AI训练网络。下面就随测试测量小编一起来了解一下相关内容吧。 Facebook,表示与 Big Sur 相比,Big Basin 能够训练比之前的规模大 30% 的机器学习模型。根据在标准神经网络模型上的测试,Big Basin 还可以通过压缩训练 AI 系统需要的大量数据集,将训练速度提升一倍。 Facebook 已经宣布开源服务器的设计。Facebook 此前参加并帮助建立了 Open Compute Project (开源计算项目
[测试测量]
服务器和云计算领导厂商共建中国的“绿色计算产业联盟”
2016年4月15日,多家国际领先的服务器与云计算方案提供商以及国内高校、科研机构于共同宣布,成立中国的 绿色计算产业联盟 (Green Computing Consortium,简称 GCC )。该联盟计划在中国建立一个开放、创新的绿色计算生态系统,推动基于ARM 架构的大数据、企业级计算和云计算等关键应用的发展。 组建该联盟的企业包括:阿里巴巴、ARM、百度、中软、戴尔(DELL)、贵州华芯通半导体技术有限公司、Hewlett Packard Enterprise/H3C(HPE)、华为、联想和飞腾。除上述企业外,联盟还包括了上海交通大学、中国电子技术标准化研究院、清华大学、北京大学、北京航空航天大学、中科院计算所等学术和科
[单片机]
英飞凌与台达双强连手:以宽带隙技术抢攻高端服务器及电竞电源市场
【2022年7月8日,德国慕尼黑讯】数字化、低碳化等全球大趋势推升了采用宽带隙 (WBG)器件碳化硅/氮化镓 (SiC/GaN) 器件的需求。这类器件具备独特的技术特性,能够助力电源产品优化性能和能源效率。 英飞凌科技公司 (FSE: IFX / OTCQX: IFNNY) 与台达电子工业股份有限公司 两家全球电子大厂,长期致力于创新的半导体和电力电子领域,今日宣布深化其合作,强化宽带隙SiC及GaN器件在高端电源产品上的应用,为终端客户提供出色的解决方案。 600 V CoolGaN HSOF-8 目前,英飞凌与台达持续加深产品的结合与应用合作,台达最新的 1.4 kW 服务器电源和 1.6 kW 的 80 Plus钛
[网络通信]
英飞凌与台达双强连手:以宽带隙技术抢攻高端<font color='red'>服务器</font>及电竞电源市场
小广播
最新网络通信文章
换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved