在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

Socket采用C/S模型進行設計的服務器模型

Q4MP_gh_c472c21 ? 來源:未知 ? 作者:李倩 ? 2018-03-24 11:20 ? 次閱讀

Socket的中文翻譯為“插座”,在計算機世界里稱為套接字。Socket最初是作為網(wǎng)絡上不同主機之間進程的通信接口,后來應用越來越廣,在同一主機上的不同進程之間通信也可以用Socket。簡單來說,當網(wǎng)絡上不同主機之間的兩個進程(A、B)采用Socket進行通信時,那么它們之間需要建立一個通信端點,即創(chuàng)建Socket,創(chuàng)建Socket時就分配端口號和網(wǎng)絡地址。當進程A向進程B發(fā)送數(shù)據(jù)時,那么進程A必須要知道進程B的網(wǎng)絡地址及端口號。

Socket采用C/S模型進行設計的,即Client/Server,面向客戶端—服務器模型。

每一個Socket都用一個半相關描述:

{協(xié)議,本地地址,本地端口}

一個完整的Socket則用一個相關描述:

{協(xié)議,本地地址,本地端口,遠程地址,遠程端口}

一、Socket的類型

Socket有三種類型:

1、字節(jié)流套接字(SOCK_STREAM)

字節(jié)流的套接字可以提供可靠的數(shù)據(jù)傳輸、面向連接的通訊流。數(shù)據(jù)按何種順序發(fā)送,就按何種順序接收。例如,當我們按順序發(fā)送A-B-C,那么在數(shù)據(jù)到達接收端時,它的順序也是A-B-C。字節(jié)流套接字采用的是TCP(Transmission Control Protocol)協(xié)議。保證了數(shù)據(jù)傳輸?shù)目煽啃浴?/p>

2、數(shù)據(jù)報套接字(SOCK_DGRAM

數(shù)據(jù)報套接字定義了一種無連接的服務。所謂無連接服務,簡單來說,即在發(fā)送數(shù)據(jù)時,無需在收發(fā)兩端建立類似TCP那樣的握手連接,在發(fā)送時,將數(shù)據(jù)打包,然后加上遠程IP地址,即可把該數(shù)據(jù)包發(fā)送出去。

數(shù)據(jù)通過相互獨立的報文進行傳輸。并且是無序的、不可靠的傳輸。

3、原始套接字(SOCK_ROW)

原始套接字是我們需要關心的,因為我們的Socket CAN采用的即是原始套接字。該接口允許對較底層協(xié)議進行操作,如IP、ICMP等。原始套接字常用于檢驗新的協(xié)議實現(xiàn)或訪問現(xiàn)有服務中配置的新設備。

套接字的工作流程如下:

先啟動服務器,通過調用socket()函數(shù)建立一個套接字,然后調用bind()函數(shù)將該套接字和本地網(wǎng)絡地址聯(lián)系在一起,再調用listen()函數(shù)使套接字做好偵聽的準備,并規(guī)定它的請求隊列的長度,之后就調用accept()函數(shù)來接收連接。客戶端在建立套接字之后就可調用 connect()和服務器建立連接。連接一旦建立,客戶端和服務器之間就可以通過調用recv()/recvfrom()函數(shù)和send()/sendto函數(shù)來進行發(fā)收數(shù)據(jù)。最后,待數(shù)據(jù)傳送結束后,雙方調用close()函數(shù)關閉套接字。

下面我們來寫兩個簡單的基于Socket的CAN應用程序,但是我們采用的是SOCK_ROW,因此在套接字工作流程上有區(qū)別于SOCK_STREAM和SOCK_DGRAM。由于Socket采用C/S模型進行設計的,所以我們的這兩個程序也分別為Server和Client。

首先是server端的程序,我們需要寫一個服務器的程序,該程序接收來自客戶端發(fā)來的數(shù)據(jù),代碼如下:

int can_recv()

{

int sock_fd;

unsigned long nbytes, len;

struct sockaddr_can addr;

struct ifreq ifr;

/*為了能夠接收CAN報文,我們需要定義一個CAN數(shù)據(jù)格式的結構體變量*/

struct can_frame frame;

struct can_frame *ptr_frame;

/*建立套接字,設置為原始套接字,原始CAN協(xié)議*/

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協(xié)議*/

addr.can_family = AF_CAN;

addr.can_ifindex = 0;

/*將剛生成的套接字與網(wǎng)絡地址進行綁定*/

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

/*開始接收數(shù)據(jù)*/

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數(shù)據(jù)打印出來,其中ID為標識符,DLC為CAN的字節(jié)數(shù),DATA為1幀報文的字節(jié)數(shù)*/

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的發(fā)送程序,即客戶端,代碼如下:

int can_send()

{

int sock_fd;

unsigned long nbytes;

struct sockaddr_can addr;

struct ifreq ifr;

struct can_frame frame;

/*建立套接字,設置為原始套接字,原始CAN協(xié)議*/

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號,可區(qū)分為標準幀和擴展幀的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);

/*開始發(fā)送數(shù)據(jù)*/

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

return 0;

}

上面兩個程序看完后,大家可能會有疑問,為什么這兩個程序沒有l(wèi)isten()和accept()函數(shù)呢?其實這兩個程序是獨立的運行的,并不像字節(jié)流套接字(SOCK_STREAM)和數(shù)據(jù)報套接字(SOCK_DGRAM),需要先運行服務器進行偵聽。SOCK_STREAM和SOCK_DGRAM的兩個server和client程序是通過網(wǎng)絡相互收發(fā)數(shù)據(jù)。而CAN的socket的server和client程序收發(fā)數(shù)據(jù)的對象是CAN總線。server從CAN總線上接收數(shù)據(jù),client將數(shù)據(jù)發(fā)到CAN總線上,當CAN總線上有數(shù)據(jù)時,server才能接收數(shù)據(jù),當CAN總線空閑時,client才能將數(shù)據(jù)發(fā)送出去。

以上是對套接字的簡單理解,并附上socket CAN的簡單上層應用代碼。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • CAN
    CAN
    +關注

    關注

    57

    文章

    2757

    瀏覽量

    463917
  • 服務器
    +關注

    關注

    12

    文章

    9235

    瀏覽量

    85648
  • Socket
    +關注

    關注

    0

    文章

    212

    瀏覽量

    34743

原文標題:為了能夠對Socket CAN的深入理解,我們需要了解Socket的機制

文章出處:【微信號:gh_c472c2199c88,微信公眾號:嵌入式微處理器】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    服務器 Flexus X 實例:RAG 開源項目 FastGPT 部署,玩轉大模型

    本篇文章主要通過 Flexus 云服務器 X 實例 部署 RAG 開源項目 FastGPT,通過 FastGPT 可以使用大模型生成用戶需要的內容。 Flexus 云服務器 X 實例具有柔性算力,六
    的頭像 發(fā)表于 01-08 11:49 ?77次閱讀
    云<b class='flag-5'>服務器</b> Flexus X 實例:RAG 開源項目 FastGPT 部署,玩轉大<b class='flag-5'>模型</b>

    基于 Flexus 云服務器 X 實例體驗大模型部署體驗測評

    也很快。但是大家目前都是在體驗,能不能部署一下試試呢? 今天,我們就以華為云 Flexus 云服務器 X 實例來部署一下,順便測測其性能看看。 在華為云 828 B2B 企業(yè)節(jié)狂潮中,F(xiàn)lexus X 實例的限時大促銷震撼來襲,絕對是你不容錯過的超級福利!對于那些追求極致算力、對自
    的頭像 發(fā)表于 12-24 12:27 ?231次閱讀
    基于 Flexus 云<b class='flag-5'>服務器</b> X 實例體驗大<b class='flag-5'>模型</b>部署體驗測評

    【「大模型啟示錄」閱讀體驗】如何在客服領域應用大模型

    多個因素以確保所選模型能夠滿足企業(yè)的具體需求和目標。首先,企業(yè)需要明確自己的客服需求和目標。例如,是否需要24小時在線客服服務?是否需要處理復雜問題的能力?是否需要個性化服務?明確這些需求有助于企業(yè)更好
    發(fā)表于 12-17 16:53

    socket 客戶端與服務器的實現(xiàn)

    1. 理解Socket 在計算機網(wǎng)絡中,socket是一種通信機制,允許兩個程序(一個客戶端和一個服務器)通過網(wǎng)絡進行通信。在Python中,可以使用
    的頭像 發(fā)表于 11-12 14:30 ?355次閱讀

    socket 與 RESTful API 的使用

    Socket是一種網(wǎng)絡通信協(xié)議,它允許程序在網(wǎng)絡中進行雙向通信。Socket分為客戶端Socket服務器
    的頭像 發(fā)表于 11-12 14:22 ?319次閱讀

    AI模型托管原理分析

    AI模型托管是指將訓練好的AI模型部署在云端或邊緣服務器上,由第三方平臺提供模型運行、管理和優(yōu)化等服務。以下,AI部落小編將對AI
    的頭像 發(fā)表于 11-07 09:33 ?207次閱讀

    GPU服務器AI網(wǎng)絡架構設計

    眾所周知,在大型模型訓練中,通常采用每臺服務器配備多個GPU的集群架構。在上一篇文章《高性能GPU服務器AI網(wǎng)絡架構(上篇)》中,我們對GPU網(wǎng)絡中的核心術語與概念
    的頭像 發(fā)表于 11-05 16:20 ?429次閱讀
    GPU<b class='flag-5'>服務器</b>AI網(wǎng)絡架構設計

    AI服務器的特點和關鍵技術

    AI服務器,即人工智能服務器,是一種專門設計用于運行和加速人工智能(AI)算法與模型的硬件設備。隨著人工智能技術的快速發(fā)展和普及,AI服務器在數(shù)據(jù)處理、
    的頭像 發(fā)表于 07-17 16:34 ?1771次閱讀

    Al大模型機器人

    )大模型AI機器人采用中英文雙語應用,目前的知識圖譜包括了金航標和薩科微所有的產(chǎn)品內容、應用場景、產(chǎn)品的家屬參數(shù)等,熱賣的型號S8050、TL431、SS8550、FR107、LM321、ZMM5V6
    發(fā)表于 07-05 08:52

    如何利用ESP32C3做UDP的服務器

    請教一下,我利用了ESP32C3 建立了Soft AP ,我想利用ESP32C3做UDP的服務器。熱點的建立,參考例程都沒有問題。關鍵是如何形成UDP的服務器。教程有教如何制作成TCP
    發(fā)表于 06-12 08:18

    為什么Cubeai導入模型的時候報錯[AI:persondetection] ModuleNotFoundError: No module named \'_socket\'?

    在使用CubeIde導入ai模型進行模型分析的時候報錯[AI:persondetection] ModuleNotFoundError: No module named \'_socket
    發(fā)表于 05-21 06:44

    使用lwip socket udp功能,開發(fā)板為客戶端時不能夠接收服務器端發(fā)送過來的數(shù)據(jù) ?

    請教下,使用 lwip socket udp 功能,開發(fā)板為客戶端時不能夠接收服務器端發(fā)送過來的數(shù)據(jù) ? 1,如果開發(fā)板為 服務器端,收發(fā)都可以 2,如果開發(fā)板為 客戶端,不能夠接收服務器
    發(fā)表于 04-16 06:01

    商湯SenseChat大模型成功通過與華為Atlas服務器的相互兼容性測試

    近日,經(jīng)華為綜合評測,SenseCore商湯大裝置AI云、商湯日日新·商量SenseChat大語言模型成功通過與華為Atlas系列服務器的相互兼容性測試,獲得HUAWEI COMPATIBLE證書及認證徽標的使用權。
    的頭像 發(fā)表于 03-22 13:38 ?691次閱讀
    商湯SenseChat大<b class='flag-5'>模型</b>成功通過與華為Atlas<b class='flag-5'>服務器</b>的相互兼容性測試

    在MPU上實現(xiàn)AI模型的遷移與應用流程

    模型訓練的程序和模型轉換腳本程序,可根據(jù)自己的需要在個人電腦或服務器進行環(huán)境搭建和應用。
    發(fā)表于 03-04 14:14 ?996次閱讀
    在MPU上實現(xiàn)AI<b class='flag-5'>模型</b>的遷移與應用流程

    求助,請問使用AT_SOCKET是否可以使用WEBNET組件實現(xiàn)網(wǎng)頁服務器

    server功能的,進而意味著無法實現(xiàn)網(wǎng)頁服務器功能。 不知道我這樣理解是否正確? 如果是這樣的話,那么能否有其他手段實現(xiàn)呢?或者RTT是否有機會改進at_socket的功能?
    發(fā)表于 02-19 06:36
    主站蜘蛛池模板: 永久福利盒子日韩日韩免费看| 天天艹天天操| 久久久免费网站| 日本在线视频一区二区| 免费国产综合视频在线看| 黄网观看| 四虎h789fcom| 91极品视频在线观看| 午夜国产精品久久影院| 久久亚洲国产成人影院| 1024免费永久福利视频| 亚洲免费一| 国产男人搡女人免费视频| 国产欧美日韩视频免费61794| 天天射天天干天天插| 一夜七次郎久久综合伊人| 窝窝午夜看片| 狠狠艹视频| 在线免费公开视频| 一级在线免费视频| 色婷婷亚洲十月十月色天| 4438x成人全国| 美女下面小内内的沟| 天天摸天天做| 午夜在线观看完整高清免费| 在线 你懂的| 四虎国产在线| 色aaa| 毛片网页| 开心综合网| wwww亚洲| 久久综合视频网| 一区二区三区四区五区| 中文字幕天堂网| 日韩天堂| 免费黄色在线观看| cijilu刺激 国产免费的| 华人黄网站大全| 久久久久国产一级毛片高清板| 久久99国产精品久久99| 四虎国产成人亚洲精品|