㈠ RocketMQ系列4-長輪詢模式實現推送消息
RocketMQ提供兩種方式進行消費消息pull vs push,這也是很多涉及到Client和Server之間的交互模型
主要是Consumer主動從Broker獲取消息,可以設置多久拉取一次、可以設置一次拉取多少條消息等參數。
Push模式服務端主動向客戶端發送消息,Push方式下,消息隊列RocketMQ版還支持批量消費功能,可以將批量消息統一推送至Consumer進行消費。
在現實中更多根據實際場景進行選擇,大多場景更喜歡使用Push模式進行消費消息,那麼Push是真正Broker端發送給Consumer的嗎?答案肯定不是的,現實場景會有成百上千的Consumer對應的消息隊列,Broker不會主動發送消息請求的。所以消息隊列如何進行設計消息推送的呢?答案是長輪詢。
長輪詢本質上也是客戶端發起槐州春定時輪訓請求,會保持請求到服務端,直到設置的時長(該hold時長要小於HTTP超時時間)到期或者服務端收到消息,進行返回數據。consumer收到響應後根據狀態判斷是否有消息。
首先是Consumer啟動,啟動過程會執行各種定時任務和守護線程。其中一個pullMessageService 定時發起請求拉取消息服務,一個MQClientInstance 只會啟動一個消息拉取線程,就是push模式使用pull封裝一下。
可以看到啟動後Consumer則不斷輪詢 Broker 獲取消鉛耐息。 Rocketmq將每次請求參數放入pullRequestQueue進行緩沖。這樣做的好處:consumer可能對應很多topic。當拉取到消息或者長輪詢請求到跡慶期後進行回調PullCallback進行下一輪拉取消息。
Consumer處理的邏輯包括:
PullCallback則根據pullStatus狀態判斷是否有消息。不管何種狀態最終會調用 executePullRequestImmediately 將拉取請求放入隊列中進行下一輪消息請求。
可以思考一下Broker端需要面臨哪些設計?
如果broker沒有獲取到新消息,並不會馬上返回pullRequest,會在suspendPullRequest方法中,把當前的請求信息(主要是offset,group,topic,requestId這幾個值)放到PullRequestHoldService.pullRequestTable中,而在ReputMessageService的doReput--->messageArrivingListener.arriving--->pullRequestHoldService.notifyMessageArriving--->mpr = this.pullRequestTable.get(key)--->requestList = mpr.cloneListAndClear() 把剛才存進去的所有pullRequest取出來,取到消息再返回。這樣就避免了不停的輪詢。
hold的請求存放在 ConcurrentHashMap<String, ManyPullRequest> 中,key 為 topic@queueId ,value 是 ManyPullRequest 實際是List<PullRequest> 可以理解對應的多個相同的topic客戶端。
Broker端啟動線程 PullRequestHoldService 不斷輪訓檢測hold請求是否超時,然後喚醒請求並返回給consumer端。其中輪訓時間設置可以是5s一次或者設定時長,進行定期檢測。
Procer寫入消息,Broker端有消息通知Consumer端。
當 Broker 是主節點 && Broker 開啟的是長輪詢,通知消費隊列有新的消息。當拉取消息請求獲取不到消息則進行阻塞。當有消息或者或者阻塞超時,重新執行獲取消息邏輯,主要是NotifyMessageArrivingListener 會 調用 PullRequestHoldService#notifyMessageArriving(…) 方法通知消費端有消息到達。這時候克隆hold的請求列表,從掛起的請求列表中找到當前新的消息的匹配的,匹配到然後在reput這個操作中順帶激活了長輪詢休眠的PullRequest。
當生產者發送最新消息過來後,首先持久化到commitLog文件,通過非同步方式同時持久化consumerQueue和index。然後激活consumer發送來hold的請求,立即將消息通過channel寫入consumer客戶。
如果沒有消息到達且客戶端拉取的偏移量是最新的,會hold住請求。其中hold請求超時時間 < 請求設定的超時時間。同時Broker端也定時檢測是否請求超時,超時則立即將請求返回,狀態code為NO_NEW_MESSAGE。
㈡ STM32HAL輪詢模式串口接收函數超時等待問題
是的,HAL裡面這個HAL_UART_Receive()函數已經明明白白地寫了,它是阻塞式查詢工作方式,只要標志不置位或者超時不結束,就乾等到天荒地老。
如果你不需要阻塞式查詢工作方式,就應當選用中斷工作方式,改用 HAL_UART_Receive_IT()函數並配置對應的NVIC模塊、調用對應的中斷服務函數並且鉤上對應的回調。
㈢ 三旺通信的工業級交換機怎麼設置
設置比較簡單,進入web界面,輸入用戶名和密碼,在進行具體設置。或者通過串口進入後台進行設置
㈣ 連接串口伺服器時, 開機要麼顯示注冊表故障恢復,要麼無法連接
應該是驅動軟體的問題,串口伺服器驅動軟體可能是被病毒修改或者注冊表兄高被修改了或者是操作系統缺少主鍵,建議客戶卸載羨蔽尺驅動軟並談件,重新安裝驅動軟體
,我在使用三旺串口伺服器的時候咨詢過這個問題
㈤ 請問串口伺服器的TCP Server和TCP Client兩種模式的具體使用場景
TCP Server是伺服器端
TCP Client是客戶端
㈥ 串口伺服器怎麼連接乙太網
串口伺服器是為RS-232/485/422到TCP/IP 之間完成數據轉換的通訊介面轉換器。提供RS-232/485/422終端串口與TCP/IP網路的數據雙向透明傳輸,提供串口轉網路功能。有專用RJ45介面,直接連上網線通過路由器或者交換機實現上網功能。
㈦ 三旺有485串口伺服器嗎
你好,有的。你說的485應該是指支持支持RS-232/RS-485/RS-422三種串口形式的串口伺服器吧。我們有NP301、NP302、NP304等等型轎手號。可以上我逗擾們網站上看看。www.3onedata.com.cn。閉指嫌希望能幫助到你。
㈧ 工業用的串口伺服器哪個牌子啊
諾控通訊
Teri 品牌Model 5210S三合一串口設備聯網伺服器(以下簡稱:串口伺服器)是我公司自主研發的RS-232/422/485三合一串口終端設備聯網產品。採用32位處理器,結合高效的嵌入式系統,使設備運行更加安全、穩定。
5210S系列串口伺服器讓您無需投入大量資金來進行更換或升級,就可以讓原有的RS-232/422/485串口設備立即具備網瞎賣絡互聯能力,為串口數據信息提供高效、安全、穩定的數據通道。5210S被廣泛應用於通信、控制領域,如電力監控、機房監控、PLC、智能電表、煤氣表、生物識別裝置、讀卡器等環境,是連接串口磨豎逗設備及TCP/IP乙太網絡的橋梁。
功能特點
功能特點
◆採用32位高性能處理器,超低運行功耗.
◆10/100M自適應乙太網介面,三合一串口界面,並軟體可選
◆所有信號內置15 KV ESD保護,RS485 每線600W TVS保護,網路1.5KV電磁隔離
◆保證最高波特率下,長時間雙向文件傳輸不丟1個bit
◆支持Windows實COM串口驅動程序,支持離線設置虛擬串口,上電即插即用。
◆支持通用Socket操作模式,包括TCP Server/Client和UDP。
◆支持最大同時6個socket連接,支持最大6台伺服器同時備份。
◆支持兩台串口伺服器背靠背成對連接使用,並且保證雙向纖閉文件傳輸不丟任何數據
◆支持斷電或者斷網自動恢復。
◆支持狀態監視,多指示燈來分析伺服器的工作狀態
◆通過網頁監視每個介面的收發情況
◆支持Web/Telnet/Console控制台多種方式進行管理和配置
◆增強的網路安裝設置和IP/MAC過濾規則,保證你的配置和網路安全性。
◆支持9-30V DC寬電壓輸入,並提供Terminal和Power Jack兩種電源介面方式
◆提供方便的固件升級,保證不斷提升產品性能和可靠性
◆採用工業標准模塊,方便導軌安裝規范與標准
㈨ 三旺串口伺服器接電是哪一個
三旺串口伺服器接電是NP301是一款能讓串口設備立即具備聯網能力的串口伺服器,可以把分散的串列設備、主機等通過網路集中管理,簡易、方便。支持TCP、UDP、ARP、灶虧ICMP、HTTP、DNS和DHCP協議,支持Windows Native COM和網路中斷自動恢復連接功能。
產品介紹:
NP301是三旺通信(3onedata)一款能讓串口設備立即具備聯網能力的串口伺服器,可以把分散的串列設備、主機等通過網路集中管隱桐神理,簡易、方便。支持TCP、UDP、ARP、ICMP、HTTP、DNS和DHCP協議,支持Windows Native COM和網路中斷自動恢復連輪散接功能
㈩ 串口伺服器的工作原理
一、串口伺服器的定義及簡介:
串口伺服器是為RS-232/485/422到TCP/IP 之間完成數據轉換的通訊介面轉換器。提供RS-232/485/422終端串口與TCP/IP網路的數據雙向透明傳輸,提供串口轉網路功能,RS-232/485/422轉網路的解決方案。可以讓串口設備立即聯接網路。
隨著Internet的廣泛普及,「讓全部設備連接網路」已經成為全世界企業的共識。為了能跟上網路自動化的潮流,不至於失去競爭優勢,必須建立高品位的數據採集、生產監控、即時成本管理的聯網系統。利用基於TCP/IP的串口數據流傳輸的實現來控制管理的設備硬體,無需投資大量的人力、物力來進行管理、更換或者升級。
串口伺服器就使得基於TCP/IP的串口數據流傳輸成為了可能,它能將多個串口設備連接並能將串口數據流進行選擇和處理,把現有的RS 232介面的數據轉化成IP埠的數據,然後進行IP化的管理,IP化的數據存取,這樣就能將傳統的串列數據送上流行的IP通道,而無需過早淘汰原有的設備,從而提高了現有設備的利用率,節約了投資,還可在既有的網路基礎上簡化布線復雜度。串口伺服器完成的是一個面向連接的RS 232鏈路和面向無連接乙太網之間的通信數據的存儲控制,系統對各種數據進行處理,處理來自串口設備的串口數據流,並進行格式轉換,使之成為可以在乙太網中傳播的數據幀;對來自乙太網的數據幀進行判斷,並轉換成串列數據送達響應的串口設備。
二、串口伺服器的特點:
內部集成 ARP,IP,TCP ,HTTP,ICMP,SOCK5,UDP,DNS等協議。RS-485/422轉換提供數據自動控制。RS-232/422/485三合一串列介面 , 300-230.4KBPS波特率。支持動態IP(DHCP)和靜態IP,支持網關和代理伺服器,可以通過Internet傳輸數據。提供數據雙向透明傳輸,用戶不需要對原有系統做任何修改。所有串口內置600W防雷 。10/100M乙太網、自動偵測直連或交叉線。可以同時支持多個連接。
三、串口伺服器工作方式及通訊模式:
工作方式:
1.伺服器方式:在該工作方式下,串口聯網伺服器作為TCP伺服器端, 轉換器在指定的TCP埠上監聽平台程序的連接請求,該方式比較適合於一個轉換器與多個平台程序建立連接(一個轉換器不能同時與多個平台程序建立連接)。
2.客戶端方式:在該工作方式下,串口聯網伺服器 作為 TCP 客戶端,轉換器上電時主動向平台程序請求連接,該方式比較適合於多個轉換器同時向一個平台程序建立連接。
通訊模式:
1.點對點通訊模式:該模式下,轉換器成對的使用,一個作為伺服器端,一個作為客戶端,兩者之間建立連接,實現數據的雙向透明傳輸。該模式適用於將兩個串口設備之間的匯流排連接改造為 TCP/IP 網路連接。
2.使用虛擬串口通訊模式:該模式下,一個或者多個轉換器與一台電腦建立連接,實現數據的雙向透明傳輸。由電腦上的虛擬串口軟體管理下面的轉換器,可以實現一個虛擬串口對應多個轉換器, N 個虛擬串口對應 M 個轉換器( N<=M )。該模式適用於串口設備由電腦控制的 485 匯流排或者 232 設備連接。
3.基於網路通訊模式: 該模式下,電腦上的應用程序基於SOCKET 協議編寫了通訊程序,在轉換器設置上直接選擇支持 SOCKET 協議即可。
四、串口伺服器應用領域:
它主要應用在門禁系統、考勤系統、售飯系統、 POS 系統、樓宇自控系統、自助銀行系統電信機房監控,電力監控等。
五、硬體系統及其模塊:
1.硬體系統
硬體系統是實現整個系統功能的基礎,是整個設計實現的關鍵。
整個串口伺服器的關鍵在於串口數據包與TCP/IP數據報之間的轉換以及雙方數據因為速率不同而存在的速率匹配問題,在對串口伺服器的實現過程中,也必須著重考慮所做的設計和所選擇的器件是否能夠完成這些功能。
(1)硬體系統組成模塊
在制定設計方案和選定器件時遇到的技術難點是如何利用處理器對串口數據信息進行TCP/IP協議處理,使之變成可以在互聯網上傳輸的IP數據包。目前解決這個問題很多時候採用32位MCU + RTOS方案,這種方案是採用32位高檔單片機,在RTOS(實時多任務操作系統)的平台上進行軟體開發,在嵌入式系統中實現TCP/IP的協議處理。它的缺點是:單片機價格較高,開發周期較長;需要購買昂貴的RTOS開發軟體,對開發人員的開發能力要求較高。
借鑒上述方案的優缺點,我們決定把串口伺服器的硬體部分分為幾個模塊設計,這就是主處理模塊、串口數據處理模塊和乙太網介面及控制模塊等幾大模塊來共同完成串口伺服器的功能。
在器件的選擇上,選用Intel公司的801086晶元作為主處理模塊的處理器晶元,它是一種非常適合於嵌入式應用的高性能、高集成度的16位微處理器,功耗低。由於考慮到串口數據速率較低而乙太網的數據傳輸速率高所造成的兩邊速率不匹配的問題,我們決定採用符合匯流排規范的大容量存儲器來作為數據存儲器;由於主處理模塊還涉及到數據線/地址線復用、串並轉換、器件中斷信號解碼、時鍾信號生成、控制信號接入等功能,若是選用不同的器件來完成,勢必會造成許多諸如時延不均等問題,我們選用了一片大容量的高性能可編程邏輯器件來完成上述所提到的功能,這樣的優點在於,我們保證了穩定性和高可靠性,並且可編程邏輯器件的可編程功能使得對於信號的處理的空間更大,且具有升級的優勢。
乙太網介面及控制模塊在串口伺服器的硬體裡面起著很重要的作用,它所處理的是來自於乙太網的IP數據包,考慮到通用性的原則,我們採用一片乙太網控制晶元來完成這些功能,並在主處理模塊中添加了一片AT24C01來存儲乙太網控制晶元狀態。通過主處理模塊對於乙太網控制晶元數據及寄存器的讀/寫,我們可以完成對IP數據包的分析、解/壓包的工作。
串口數據處理模塊主要完成的是對於串口數據流的電平轉換和數據格式的處理,判斷串列數據的起始位及停止位,完成對數據和校驗位的提取。一般的設計採用的是MAX232和一片UART的設計思想,這里我們也是遵從這種設計理念,不過我們採用的是集成了MAX232+UART功能的晶元,小尺寸、低成本、低功耗,而且採用與SPITM/QS-PITM/MICROWIRETM兼容的串列介面,節省線路板尺寸與微控制器的I/O埠。
這種模塊化的方案的優點在於:採用高速度的16位微控制器,外圍器件少,系統成本低;並且採用Intel公司的開發平台,可以大幅度地縮短開發周期並降低開發成本。
(2)硬體工作流程及應用架構
主處理器首先初始化網路及串口設備,當有數據從乙太網傳過來,處理器對數據報進行分析,如果是ARP(物理地址解析)數據包,則程序轉入ARP處理程序;如果是IP數據包且傳輸層使用UDP,埠正確,則認為數據報正確,數據解包後,將數據部分通過埠所對應的串口輸出。反之,如果從串口收到數據,則將數據按照UDP格式打包,送入乙太網控制晶元,由其將數據輸出到乙太網中。可以知道,主處理模塊主要處理TCP/IP的網路層和傳輸層,鏈路層部分由乙太網控制晶元完成。應用層交付軟體系統來處理,用戶可以根據需求對收到的數據進行處理。
2.硬體系統模塊
根據硬體系統的具體結構和不同功能,我們可以將硬體系統劃分為下述的幾大模塊。
(1)主處理器模塊
該模塊是串口伺服器的核心部分,主要由主處理器、可編程邏輯器件、數據及程序存儲器等器件構成。
主處理模塊完成的功能主要有:在串口數據和乙太網IP數據之間建立數據鏈路;通過對乙太網控制晶元的控制讀寫來實現對IP數據包的接收與發送;判別串列數據流的格式,完成對串口設備的選擇以及對串列數據流格式的指定;控制串口數據流與IP數據包之間的速率控制,對數據進行緩沖處理;對UART和乙太網控制晶元的寄存器進行讀寫操作,並存儲轉發器件狀態;完成16位匯流排數據的串並行轉換;完成匯流排地址鎖存功能;完成對各個串口以及各個存儲器件的片選功能;完成對各個串口的中斷口的狀態判別等功能。
(2)乙太網介面及控制模塊
這個模塊主要由乙太網介面部分和乙太網控制部分構成。
乙太網介面部分完成的是串口伺服器與乙太網介面電路的功能,控制器對所有模塊均有控製作用,使整個介面電路能協調地配合後續電路完成乙太網的收發功能。
乙太網控制部分由收端和發端組成,在他們之間還有乙太網狀態檢測和控制單元,以及收發協調控制器,見圖5。由於乙太網是半雙工工作的,所以這個部分必須隨時地監視乙太網的狀態,並且要根據需要對乙太網進行控制,同時還要協調好內部收發端電路的工作狀態。乙太網檢測單元和收發協調控制器就是完成這樣的功能的。乙太網狀態檢測單元與乙太網介面的控制器介面,將介面的狀態送到收發協調控制器,同時將協調控制器的控制信號進行處理,並送到乙太網介面的控制器,以控制介面的狀態。
在收端,接收到的串列數據流信號通過主處理模塊進行串並轉換和編碼,乙太網控制單元控制各部分協調,將產生的地址、數據、寫信號送到RAM讀寫控制單元進行處理。相應的,發端的工作流程和收端相反。