精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

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

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

引入消息隊(duì)列會多出哪些問題

Linux愛好者 ? 來源:蘇三說技術(shù) ? 作者:熱愛所以堅(jiān)持ing ? 2021-09-23 14:53 ? 次閱讀

前言

最近,消息隊(duì)列(Message Queue ,簡稱 MQ)越來越火。很多公司在用,很多人在用,其重要性不言而喻。

如果讓你回答下面這些問題,你的心中是否有答案了呢?

為什么要用 MQ?

引入 MQ 會多出哪些問題?

如何解決這些問題?

本文將會一一為你解答,這些看似平常卻很有意義的問題。

1. 傳統(tǒng)模式有哪些痛點(diǎn)

痛點(diǎn) 1

有些復(fù)雜的業(yè)務(wù)系統(tǒng),一次用戶請求可能會同步調(diào)用 N 個(gè)系統(tǒng)的接口,需要等待所有的接口都返回才能真正的獲取執(zhí)行結(jié)果。

這種同步接口調(diào)用的方式總耗時(shí)比較長,非常影響用戶體驗(yàn)。特別是在網(wǎng)絡(luò)不穩(wěn)定的情況下,極容易出現(xiàn)接口超時(shí)問題。

痛點(diǎn) 2

很多復(fù)雜的業(yè)務(wù)系統(tǒng),一般都會拆分成多個(gè)子系統(tǒng)。以用戶下單為例,請求會先通過訂單系統(tǒng),然后分別調(diào)用支付系統(tǒng)、庫存系統(tǒng)、積分系統(tǒng)和物流系統(tǒng)。

系統(tǒng)之間耦合性太高,如果調(diào)用的任何一個(gè)子系統(tǒng)出現(xiàn)異常,整個(gè)請求都會異常。對系統(tǒng)的穩(wěn)定性非常不利。

痛點(diǎn) 3

為了吸引用戶,有時(shí)候會搞一些活動,比如秒殺等。

如果用戶少還好,不會影響系統(tǒng)的穩(wěn)定性。但如果用戶突增,一時(shí)間所有的請求都到數(shù)據(jù)庫,可能會導(dǎo)致數(shù)據(jù)庫無法承受這么大的壓力,響應(yīng)變慢或者直接掛掉。

對于這種突然出現(xiàn)的請求峰值,無法保證系統(tǒng)的穩(wěn)定性。

2. 為什么要用 MQ

對于上面?zhèn)鹘y(tǒng)模式的三類問題,使用 MQ 就能輕松解決。

2.1 異步

對于痛點(diǎn) 1 同步接口調(diào)用導(dǎo)致響應(yīng)時(shí)間長的問題。使用 MQ 之后,將同步調(diào)用改成異步調(diào)用,能夠顯著減少系統(tǒng)響應(yīng)時(shí)間。

系統(tǒng) A 作為消息的生產(chǎn)者,在完成本職工作后就能直接返回結(jié)果了。無需等待消息消費(fèi)者的返回,它們最終會獨(dú)立完成所有的業(yè)務(wù)功能。

這樣能避免總耗時(shí)比較長,從而影響用戶的體驗(yàn)的問題。

2.2 解耦

對于痛點(diǎn) 2 子系統(tǒng)間耦合性太大的問題,使用 MQ 之后,只需要依賴于 MQ。避免了各個(gè)子系統(tǒng)間的強(qiáng)依賴問題。

訂單系統(tǒng)作為消息生產(chǎn)者,保證它自己沒有異常即可,不會受到支付系統(tǒng)等業(yè)務(wù)子系統(tǒng)的異常影響。并且各個(gè)消費(fèi)者業(yè)務(wù)子系統(tǒng)之間,也互不影響。

這樣就把之前復(fù)雜的業(yè)務(wù)子系統(tǒng)的依賴關(guān)系,轉(zhuǎn)換為只依賴于 MQ 的簡單依賴,從而顯著的降低了系統(tǒng)間的耦合度。

2.3 削峰

對于痛點(diǎn) 3,由于突然出現(xiàn)的請求峰值導(dǎo)致系統(tǒng)不穩(wěn)定的問題。使用 MQ 后,能夠起到削峰的作用。

訂單系統(tǒng)接收到用戶請求之后,將請求直接發(fā)送到 MQ;

然后,訂單消費(fèi)者從 MQ 中消費(fèi)消息,做寫庫操作;

當(dāng)出現(xiàn)請求峰值的情況,由于消費(fèi)者的消費(fèi)能力有限,會按照自己的節(jié)奏來消費(fèi)消息。多余請求不處理,保留在 MQ 的隊(duì)列中,不會對系統(tǒng)的穩(wěn)定性造成影響。

3. 引入 MQ 會多出哪些問題

引入 MQ 后讓子系統(tǒng)間耦合性降低了,異步處理機(jī)制減少了系統(tǒng)的響應(yīng)時(shí)間。同時(shí)能夠有效的應(yīng)對請求峰值問題,提升了系統(tǒng)的穩(wěn)定性。

但是,引入 MQ 的同時(shí)也會帶來一些問題。

3.1 重復(fù)消費(fèi)問題

重復(fù)消費(fèi)問題可以說是 MQ 中普遍存在的問題,不管你用哪種 MQ 都無法避免。

有哪些場景會出現(xiàn)重復(fù)的消息呢?

消息生產(chǎn)者產(chǎn)生了重復(fù)的消息;

Kafka 和 RocketMQ 的 offset 被回調(diào)了;

消息消費(fèi)者確認(rèn)失??;

消息消費(fèi)者確認(rèn)時(shí)超時(shí);

業(yè)務(wù)系統(tǒng)主動發(fā)起重試。

如果重復(fù)消息不做正確的處理,會對業(yè)務(wù)造成很大的影響,產(chǎn)生重復(fù)數(shù)據(jù)或者導(dǎo)致數(shù)據(jù)異常,比如會員系統(tǒng)多開通了一個(gè)月的會員等。

3.2 數(shù)據(jù)一致性問題

很多時(shí)候,如果 MQ 的消費(fèi)者業(yè)務(wù)處理異常,就會出現(xiàn)數(shù)據(jù)一致性問題。

舉個(gè)例子,一個(gè)完整的業(yè)務(wù)流程是,下單成功之后送 100 個(gè)積分。下單寫庫成功了,但是消息消費(fèi)者在送積分的時(shí)候失敗了。這樣就會造成數(shù)據(jù)不一致的情況,即該業(yè)務(wù)流程的部分?jǐn)?shù)據(jù)寫庫了,另外一部分沒有寫庫。

如果下單和送積分在同一個(gè)事務(wù)中,要么同時(shí)成功,要么同時(shí)失敗。這樣不會出現(xiàn)數(shù)據(jù)一致性問題的。

但由于跨系統(tǒng)調(diào)用,為了性能考慮一般不會使用強(qiáng)一致性的方案,而改成達(dá)成最終一致性即可。

3.3 消息丟失問題

同樣消息丟失問題,也是 MQ 中普遍存在的問題,不管你用哪種 MQ 都無法避免。

有哪些場景會出現(xiàn)消息丟失問題呢?

生產(chǎn)者產(chǎn)生消息時(shí),由于網(wǎng)絡(luò)原因發(fā)送到 MQ 失敗了;

MQ 服務(wù)器持久化,存儲磁盤時(shí)出現(xiàn)異常;

Kafka 和 RocketMQ 的 offset 被回調(diào)時(shí),略過了很多消息;

消費(fèi)者剛讀取消息,已經(jīng) ACK 確認(rèn),但業(yè)務(wù)還沒處理完,服務(wù)就被重啟了。

導(dǎo)致消息丟失問題的原因挺多的,生產(chǎn)者、MQ 服務(wù)器、消費(fèi)者都有可能產(chǎn)生問題。我在這里就不一一列舉了。

最終的結(jié)果會導(dǎo)致消費(fèi)者無法正確的處理消息,而導(dǎo)致數(shù)據(jù)不一致的情況。

3.4 消息順序問題

有些業(yè)務(wù)數(shù)據(jù)是有狀態(tài)的,比如訂單有下單、支付、完成、退貨等狀態(tài)。如果訂單數(shù)據(jù)作為消息體,就會涉及順序問題了。

例如消費(fèi)者收到同一個(gè)訂單的兩條消息。第一條消息的狀態(tài)是下單,第二條消息的狀態(tài)是支付,這是沒問題的。

但如果第一條消息的狀態(tài)是支付,第二條消息的狀態(tài)是下單就會有問題了。沒有下單就先支付了?

消息順序問題是一個(gè)非常棘手的問題,比如:

Kafka 同一個(gè) partition 中能保證順序,但是不同的 partition 無法保證順序;

RabbitMQ的同一個(gè) queue 能夠保證順序,但是如果多個(gè)消費(fèi)者同一個(gè) queue 也會有順序問題。

如果消費(fèi)者使用多線程消費(fèi)消息,也無法保證順序。

如果消費(fèi)消息時(shí)同一個(gè)訂單的多條消息中,中間的一條消息出現(xiàn)異常情況,順序?qū)淮騺y。

還有如果生產(chǎn)者發(fā)送到 MQ 中的路由規(guī)則,跟消費(fèi)者不一樣,也無法保證順序。

3.5 消息堆積

如果消息消費(fèi)者讀取消息的速度,能夠跟上消息生產(chǎn)者的節(jié)奏,那么整套 MQ 機(jī)制就能發(fā)揮最大作用。

但是很多時(shí)候,由于某些批處理或者其他原因,導(dǎo)致消費(fèi)速度小于生產(chǎn)速度。這樣會直接導(dǎo)致消息堆積問題,從而影響業(yè)務(wù)功能。

這里以下單開通會員為例,如果消息出現(xiàn)堆積會導(dǎo)致用戶下單之后,很久之后才能變成會員。這種情況肯定會引起大量用戶投訴。

3.6 系統(tǒng)復(fù)雜度提升

這里說的系統(tǒng)復(fù)雜度和系統(tǒng)耦合性是不一樣的。

假設(shè)以前只有系統(tǒng) A、系統(tǒng) B 和系統(tǒng) C 三個(gè)系統(tǒng),引入 MQ 之后,除了需要關(guān)注前面三個(gè)系統(tǒng)之外,還需要關(guān)注 MQ 服務(wù)。需要關(guān)注的點(diǎn)越多,系統(tǒng)的復(fù)雜度越高。

MQ 的機(jī)制需要生產(chǎn)者、MQ 服務(wù)器、消費(fèi)者。有一定的學(xué)習(xí)成本,需要額外部署 MQ 服務(wù)器。

有些 MQ 功能非常強(qiáng)大、用法有點(diǎn)復(fù)雜,例如 RocketMQ。如果使用不好,會出現(xiàn)很多問題。有些問題,不像接口調(diào)用那么容易排查,從而導(dǎo)致系統(tǒng)的復(fù)雜度提升了。

4. 如何解決這些問題?

MQ 是一種趨勢,總體來說對我們的系統(tǒng)是利大于弊的,難道因?yàn)樗鼤霈F(xiàn)一些問題,我們就不用它了?那么我們要如何解決這些問題呢?

4.1 重復(fù)消息問題

不管是由于生產(chǎn)者產(chǎn)生的重復(fù)消息,還是由于消費(fèi)者導(dǎo)致的重復(fù)消息,我們都可以在消費(fèi)者中解決這個(gè)問題。

這就要求消費(fèi)者在做業(yè)務(wù)處理時(shí),要做冪等設(shè)計(jì)。如果有不知道如何設(shè)計(jì)的朋友,可以參考“高并發(fā)下如何保證接口的冪等性?”,里面介紹得非常詳細(xì)。

在這里我推薦增加一張消費(fèi)消息表,來解決 MQ 的這類問題。

消費(fèi)消息表中,使用 messageId 做唯一索引。在處理業(yè)務(wù)邏輯之前,先根據(jù) messageId 查詢一下該消息有沒有處理過。如果已經(jīng)處理過了則直接返回成功,如果沒有處理過,則繼續(xù)做業(yè)務(wù)處理。

4.2 數(shù)據(jù)一致性問題

我們都知道數(shù)據(jù)一致性分為:

強(qiáng)一致性

弱一致性

最終一致性

而 MQ 為了性能考慮使用的是最終一致性,那么必定會出現(xiàn)數(shù)據(jù)不一致的問題。這類問題大概率是因?yàn)橄M(fèi)者讀取消息后,業(yè)務(wù)邏輯處理失敗導(dǎo)致的。這時(shí)候可以增加重試機(jī)制。

重試分為同步重試和異步重試。

有些消息量比較小的業(yè)務(wù)場景,可以采用同步重試。在消費(fèi)消息時(shí)如果處理失敗,立刻重試 3-5 次,如果還是失敗則寫入到記錄表中。

但如果消息量比較大,則不建議使用這種方式。因?yàn)槿绻霈F(xiàn)網(wǎng)絡(luò)異常,可能會導(dǎo)致大量的消息不斷重試,影響消息讀取速度造成消息堆積。

消息量比較大的業(yè)務(wù)場景,建議采用異步重試。在消費(fèi)者處理失敗之后,立刻寫入重試表,有個(gè) job 專門定時(shí)重試。

還有一種做法:如果消費(fèi)失敗,自己給同一個(gè) topic 發(fā)一條消息。在后面的某個(gè)時(shí)間點(diǎn),自己又會消費(fèi)到那條消息,起到了重試的效果。如果對消息順序要求不高的場景,可以使用這種方式。

4.3 消息丟失問題

不管你是否承認(rèn),有時(shí)候消息真的會丟。即使這種概率非常小,也會對業(yè)務(wù)有影響。生產(chǎn)者、MQ 服務(wù)器、消費(fèi)者都有可能會導(dǎo)致消息丟失的問題。為了解決這個(gè)問題,我們可以增加一張消息發(fā)送表。

當(dāng)生產(chǎn)者發(fā)完消息之后,會往該表中寫入一條數(shù)據(jù),狀態(tài) status 標(biāo)記為待確認(rèn);

如果消費(fèi)者讀取消息之后,調(diào)用生產(chǎn)者的 API 更新該消息的 status 為已確認(rèn);

有個(gè) job 每隔一段時(shí)間檢查一次消息發(fā)送表,如果5分鐘(這個(gè)時(shí)間可以根據(jù)實(shí)際情況來定)后還有狀態(tài)是待確認(rèn)的消息,則認(rèn)為該消息已經(jīng)丟失了,重新發(fā)條消息。

這樣不管是由于生產(chǎn)者、MQ 服務(wù)器、還是消費(fèi)者導(dǎo)致的消息丟失問題,job 都會重新發(fā)消息。

4.4 消息順序問題

消息順序問題是一種常見問題。我們以 Kafka 消費(fèi)訂單消息為例,訂單有下單、支付、完成、退貨等狀態(tài)。這些狀態(tài)是有先后順序的,如果順序錯(cuò)了會導(dǎo)致業(yè)務(wù)異常。

解決這類問題之前,我們需要先確認(rèn):消費(fèi)者是否真的需要知道中間狀態(tài),只知道最終狀態(tài)行不行?

其實(shí)很多時(shí)候,我真的需要知道的是最終狀態(tài)。這時(shí)可以把流程優(yōu)化一下:

這種方式可以解決大部分的消息順序問題。

但如果真的有需要保證消息順序的需求,那么可以將訂單號路由到不同的 partition。同一個(gè)訂單號的消息,每次到發(fā)到同一個(gè) partition。

4.5 消息堆積

如果消費(fèi)者消費(fèi)消息的速度小于生產(chǎn)者生產(chǎn)消息的速度,將會出現(xiàn)消息堆積問題。其實(shí)這類問題產(chǎn)生的原因很多。如果想要進(jìn)一步了解,可以看看“我用kafka兩年踩過的一些非比尋常的坑”。

那么消息堆積問題該如何解決呢?這個(gè)要看消息是否需要保證順序。

如果不需要保證順序,可以讀取消息之后用多線程處理業(yè)務(wù)邏輯。

這樣就能增加業(yè)務(wù)邏輯處理速度,解決消息堆積問題。但是線程池的核心線程數(shù)和最大線程數(shù)需要合理配置,不然可能會浪費(fèi)系統(tǒng)資源。

如果需要保證順序,可以讀取消息之后將消息按照一定的規(guī)則分發(fā)到多個(gè)隊(duì)列中,然后在隊(duì)列中用單線程處理。

責(zé)任編輯:haq

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

    關(guān)注

    12

    文章

    9021

    瀏覽量

    85184
  • 消息
    +關(guān)注

    關(guān)注

    0

    文章

    29

    瀏覽量

    12867

原文標(biāo)題:面霸篇:MQ 的 5 大問題詳解

文章出處:【微信號:LinuxHub,微信公眾號:Linux愛好者】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    JavaWeb消息隊(duì)列使用指南

    在現(xiàn)代的JavaWeb應(yīng)用中,消息隊(duì)列(Message Queue)是一種常見的技術(shù),用于異步處理任務(wù)、解耦系統(tǒng)組件、提高系統(tǒng)性能和可靠性。 1. 消息隊(duì)列的基本概念 消息隊(duì)列是一種應(yīng)用程序?qū)?yīng)
    的頭像 發(fā)表于 11-25 09:27 ?67次閱讀

    為什么同一個(gè)隊(duì)列引用的全局變量,運(yùn)行在兩個(gè)子vi中發(fā)現(xiàn)隊(duì)列數(shù)據(jù)丟失了

    我創(chuàng)建了一個(gè)隊(duì)列,然后將隊(duì)列引用做了個(gè)全局變量,運(yùn)行在兩個(gè)子vi中,一個(gè)是只入隊(duì)列,另一個(gè)是只出隊(duì)列。但我發(fā)現(xiàn),一個(gè)字vi數(shù)據(jù)入隊(duì)列成功,檢
    發(fā)表于 11-14 11:47

    在進(jìn)入OPA847放大器之前加了LC高通濾波,請問這樣引入過多噪聲嗎?

    ,發(fā)現(xiàn)如果不濾除直流分量的話,我的互阻增益就很小,所以我在進(jìn)入放大器之前加了LC高通濾波,請問這樣引入過多噪聲么?還有別的方法可以消除直流分量嗎?
    發(fā)表于 09-14 07:17

    嵌入式環(huán)形隊(duì)列與消息隊(duì)列的實(shí)現(xiàn)原理

    嵌入式環(huán)形隊(duì)列,也稱為環(huán)形緩沖區(qū)或循環(huán)隊(duì)列,是一種先進(jìn)先出(FIFO)的數(shù)據(jù)結(jié)構(gòu),用于在固定大小的存儲區(qū)域中高效地存儲和訪問數(shù)據(jù)。其主要特點(diǎn)包括固定大小的數(shù)組和兩個(gè)指針(頭指針和尾指針),分別指向隊(duì)列的起始位置和結(jié)束位置。
    的頭像 發(fā)表于 09-02 15:29 ?341次閱讀

    示波器探頭在測試的時(shí)候引入什么負(fù)載效應(yīng)

    在進(jìn)行電子測試時(shí),示波器探頭作為一種重要的測量工具,其性能對測量結(jié)果的準(zhǔn)確性具有重要影響。然而,在使用示波器探頭進(jìn)行測量時(shí),探頭本身也引入一定的負(fù)載效應(yīng),影響測試結(jié)果。 一、示波器探頭的基本原理
    的頭像 發(fā)表于 08-09 14:30 ?344次閱讀

    玩轉(zhuǎn)RT-Thread之消息隊(duì)列的應(yīng)用

    在嵌入式系統(tǒng)開發(fā)中,實(shí)時(shí)處理串口和ADC數(shù)據(jù)是一項(xiàng)重要的任務(wù)。本文將介紹如何在RT-Thread實(shí)時(shí)操作系統(tǒng)中,利用消息隊(duì)列來同時(shí)處理來自串口和ADC的數(shù)據(jù)。通過這種方法,我們能夠高效地管理和處理
    的頭像 發(fā)表于 07-23 08:11 ?549次閱讀
    玩轉(zhuǎn)RT-Thread之消息<b class='flag-5'>隊(duì)列</b>的應(yīng)用

    嵌入式實(shí)時(shí)操作系統(tǒng)中的隊(duì)列管理與應(yīng)用

    任務(wù) A 將信息存入隊(duì)列,任務(wù)B以先進(jìn)先出的方式提取信息。隊(duì)列通常應(yīng)足夠大,可以承載許多數(shù)據(jù),而不僅僅承載單個(gè)數(shù)據(jù)項(xiàng)。因此,它可以充當(dāng)緩沖或暫存器,為管道提供靈活性。
    發(fā)表于 04-30 14:27 ?535次閱讀
    嵌入式實(shí)時(shí)操作系統(tǒng)中的<b class='flag-5'>隊(duì)列</b>管理與應(yīng)用

    Freertos隊(duì)列項(xiàng)里的字節(jié)長度是否可以獲???

    最近剛學(xué)Freertos, 看到可以獲取Freertos隊(duì)列長度,但是隊(duì)列項(xiàng)里的字節(jié)長度是否可以獲??? 因?yàn)轫?xiàng)目中隊(duì)列中會存放不定長字節(jié),需要對隊(duì)列中的數(shù)據(jù)分揀,每次分揀的時(shí)候遍歷所
    發(fā)表于 04-29 07:17

    進(jìn)程間通信的消息隊(duì)列介紹

    消息隊(duì)列是一種非常常見的進(jìn)程間通信方式。
    的頭像 發(fā)表于 04-08 17:27 ?284次閱讀

    MCU專屬隊(duì)列功能模塊之QueueForMcu應(yīng)用

    當(dāng)需要從隊(duì)列頭部獲取多個(gè)數(shù)據(jù),但又不希望數(shù)據(jù)從隊(duì)列中刪除時(shí),可以使用 Queue_Peek_Array 函數(shù)來實(shí)現(xiàn),該函數(shù)的參數(shù)與返回值與 Queue_Pop_Array 完全相同。
    發(fā)表于 03-20 11:44 ?423次閱讀
    MCU專屬<b class='flag-5'>隊(duì)列</b>功能模塊之QueueForMcu應(yīng)用

    裸機(jī)中環(huán)形隊(duì)列與RTOS中消息隊(duì)列有何區(qū)別呢?

    “環(huán)形隊(duì)列”和“消息隊(duì)列”在嵌入式領(lǐng)域有應(yīng)用非常廣泛,相信有經(jīng)驗(yàn)的嵌入式軟件工程師對它們都不陌生。
    的頭像 發(fā)表于 01-26 09:38 ?686次閱讀
    裸機(jī)中環(huán)形<b class='flag-5'>隊(duì)列</b>與RTOS中消息<b class='flag-5'>隊(duì)列</b>有何區(qū)別呢?

    labview 隊(duì)列最前端插入的應(yīng)用

    LabVIEW是一種用于實(shí)時(shí)測試、測量和控制系統(tǒng)的高級系統(tǒng)設(shè)計(jì)軟件。它采用了數(shù)據(jù)流編程方式,提供了一種直觀、可視化的方法來構(gòu)建復(fù)雜的測試和測量應(yīng)用程序。其中一個(gè)重要的功能是隊(duì)列,它可以在軟件設(shè)計(jì)中
    的頭像 發(fā)表于 01-08 11:45 ?1150次閱讀

    labview隊(duì)列有什么實(shí)際作用

    LabVIEW隊(duì)列是一種數(shù)據(jù)結(jié)構(gòu),常用于解決多任務(wù)并發(fā)處理的問題。它被廣泛應(yīng)用于科學(xué)研究、工程項(xiàng)目和自動化控制等領(lǐng)域。在LabVIEW中,隊(duì)列提供了一種高效、方便的方式來處理不同任務(wù)之間的數(shù)據(jù)
    的頭像 發(fā)表于 01-05 16:42 ?1506次閱讀

    半孔板比常規(guī)pcb板多出什么流程

    半孔板是一種特殊的PCB板,相比于常規(guī)的PCB板,它在制造過程中需要多出一些步驟和流程。在本文中,將介紹半孔板相較于常規(guī)PCB板所多出的流程。 首先,半孔板的制造流程與常規(guī)PCB板的流程在前期步驟上
    的頭像 發(fā)表于 12-25 16:13 ?853次閱讀

    聊一聊消息隊(duì)列技術(shù)選型的7種消息場景

    我們在做消息隊(duì)列的技術(shù)選型時(shí),往往結(jié)合業(yè)務(wù)場景進(jìn)行考慮。今天來聊一聊消息隊(duì)列可能會用到的 7 種消息場景。
    的頭像 發(fā)表于 12-09 17:50 ?1322次閱讀
    聊一聊消息<b class='flag-5'>隊(duì)列</b>技術(shù)選型的7種消息場景