久久久精品一区ed2k-女人被男人叉到高潮的视频-中文字幕乱码一区久久麻豆樱花-俄罗斯熟妇真实视频

PHP有哪些關(guān)于高并發(fā)的面試題

PHP有哪些關(guān)于高并發(fā)的面試題?相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。

成都創(chuàng)新互聯(lián)公司網(wǎng)站建設(shè)公司,提供成都網(wǎng)站設(shè)計、做網(wǎng)站、成都外貿(mào)網(wǎng)站建設(shè)公司,網(wǎng)頁設(shè)計,建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);可快速的進行網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴展;專業(yè)做搜索引擎喜愛的網(wǎng)站,是專業(yè)的做網(wǎng)站團隊,希望更多企業(yè)前來合作!

1、什么是rabbitmq

采用AMQP高級消息隊列協(xié)議的一種消息隊列技術(shù),最大的特點就是消費并不需要確保提供方存在,實現(xiàn)了服務(wù)之間的高度解耦

2、為什么要使用rabbitmq

1. 在分布式系統(tǒng)下具備異步,削峰,負(fù)載均衡等一系列高級功能;

2. 擁有持久化的機制,進程消息,隊列中的信息也可以保存下來。

3. 實現(xiàn)消費者和生產(chǎn)者之間的解耦。

4. 對于高并發(fā)場景下,利用消息隊列可以使得同步訪問變?yōu)榇性L問達(dá)到一定量的限流,利于數(shù)據(jù)庫的操作。

可以使用消息隊列達(dá)到異步下單的效果,排隊中,后臺進行邏輯下單

3、使用rabbitmq的場景

1. 服務(wù)間異步通信

2. 順序消費

3. 定時任務(wù)

4. 請求削峰

4、如何確保消息正確地發(fā)送至RabbitMQ? 如何確保消息接收方消費了消息?

發(fā)送方確認(rèn)模式

將信道設(shè)置成confirm模式(發(fā)送方確認(rèn)模式),則所有在信道上發(fā)布的消息都會被指派一個唯一的ID。

一旦消息被投遞到目的隊列后,或者消息被寫入磁盤后(可持久化的消息),信道會發(fā)送一個確認(rèn)給生產(chǎn)者(包含消息唯一ID)。

如果RabbitMQ發(fā)生內(nèi)部錯誤從而導(dǎo)致消息丟失,會發(fā)送一條nack(not acknowledged,未確認(rèn))消息。

發(fā)送方確認(rèn)模式是異步的,生產(chǎn)者應(yīng)用程序在等待確認(rèn)的同時,可以繼續(xù)發(fā)送消息。當(dāng)確認(rèn)消息到達(dá)生產(chǎn)者應(yīng)用程序,生產(chǎn)者應(yīng)用程序的回調(diào)方法就會被觸發(fā)來處理確認(rèn)消息。

接收方確認(rèn)機制

接收方消息確認(rèn)機制

消費者接收每一條消息后都必須進行確認(rèn)(消息接收和消息確認(rèn)是兩個不同操作)。只有消費者確認(rèn)了消息,RabbitMQ才能安全地把消息從隊列中刪除。

這里并沒有用到超時機制,RabbitMQ僅通過Consumer的連接中斷來確認(rèn)是否需要重新發(fā)送消息。也就是說,只要連接不中斷,RabbitMQ給了Consumer足夠長的時間來處理消息。保證數(shù)據(jù)的最終一致性;

下面羅列幾種特殊情況

如果消費者接收到消息,在確認(rèn)之前斷開了連接或取消訂閱,RabbitMQ會認(rèn)為消息沒有被分發(fā),然后重新分發(fā)給下一個訂閱的消費者。(可能存在消息重復(fù)消費的隱患,需要去重)

如果消費者接收到消息卻沒有確認(rèn)消息,連接也未斷開,則RabbitMQ認(rèn)為該消費者繁忙,將不會給該消費者分發(fā)更多的消息。

5.如何避免消息重復(fù)投遞或重復(fù)消費?

在消息生產(chǎn)時,MQ內(nèi)部針對每條生產(chǎn)者發(fā)送的消息生成一個inner-msg-id,作為去重的依據(jù)(消息投遞失敗并重傳),避免重復(fù)的消息進入隊列;

在消息消費時,要求消息體中必須要有一個bizId(對于同一業(yè)務(wù)全局唯一,如支付ID、訂單ID、帖子ID等)作為去重的依據(jù),避免同一條消息被重復(fù)消費。

6、消息基于什么傳輸?

由于TCP連接的創(chuàng)建和銷毀開銷較大,且并發(fā)數(shù)受系統(tǒng)資源限制,會造成性能瓶頸。RabbitMQ使用信道的方式來傳輸數(shù)據(jù)。信道是建立在真實的TCP連接內(nèi)的虛擬連接,且每條TCP連接上的信道數(shù)量沒有限制。

7、消息如何分發(fā)?

若該隊列至少有一個消費者訂閱,消息將以循環(huán)(round-robin)的方式發(fā)送給消費者。每條消息只會分發(fā)給一個訂閱的消費者(前提是消費者能夠正常處理消息并進行確認(rèn))。 通過路由可實現(xiàn)多消費的功能

8、消息怎么路由?

消息提供方->路由->一至多個隊列 消息發(fā)布到交換器時,消息將擁有一個路由鍵(routing key),在消息創(chuàng)建時設(shè)定。 通過隊列路由鍵,可以把隊列綁定到交換器上。

消息到達(dá)交換器后,RabbitMQ會將消息的路由鍵與隊列的路由鍵進行匹配(針對不同的交換器有不同的路由規(guī)則);

常用的交換器主要分為一下三種

· fanout:如果交換器收到消息,將會廣播到所有綁定的隊列上

· direct:如果路由鍵完全匹配,消息就被投遞到相應(yīng)的隊列

· topic:可以使來自不同源頭的消息能夠到達(dá)同一個隊列。 使用topic交換器時,可以使用通配符

9、如何確保消息不丟失?

消息持久化,當(dāng)然前提是隊列必須持久化 RabbitMQ確保持久性消息能從服務(wù)器重啟中恢復(fù)的方式是,將它們寫入磁盤上的一個持久化日志文件,當(dāng)發(fā)布一條持久性消息到持久交換器上時,Rabbit會在消息提交到日志文件后才發(fā)送響應(yīng)。

一旦消費者從持久隊列中消費了一條持久化消息,RabbitMQ會在持久化日志中把這條消息標(biāo)記為等待垃圾收集。如果持久化消息在被消費之前RabbitMQ重啟,那么Rabbit會自動重建交換器和隊列(以及綁定),并重新發(fā)布持久化日志文件中的消息到合適的隊列。

10、使用RabbitMQ有什么好處?

1、服務(wù)間高度解耦

2、異步通信性能高

3、流量削峰

11、rabbitmq的集群

鏡像集群模式

你創(chuàng)建的queue,無論元數(shù)據(jù)還是queue里的消息都會存在于多個實例上,然后每次你寫消息到queue的時候,都會自動把消息到多個實例的queue里進行消息同步。

好處在于,你任何一個機器宕機了,沒事兒,別的機器都可以用。壞處在于,第一,這個性能開銷也太大了吧,消息同步所有機器,導(dǎo)致網(wǎng)絡(luò)帶寬壓力和消耗很重!第二,這么玩兒,就沒有擴展性可言了,如果某個queue負(fù)載很重,你加機器,新增的機器也包含了這個queue的所有數(shù)據(jù),并沒有辦法線性擴展你的queue

12.mq的缺點

系統(tǒng)可用性降低

系統(tǒng)引入的外部依賴越多,越容易掛掉,本來你就是A系統(tǒng)調(diào)用BCD三個系統(tǒng)的接口就好了,人ABCD四個系統(tǒng)好好的,沒啥問題,你偏加個MQ進來,萬一MQ掛了咋整?MQ掛了,整套系統(tǒng)崩潰了,你不就完了么。

系統(tǒng)復(fù)雜性提高

硬生生加個MQ進來,你怎么保證消息沒有重復(fù)消費?怎么處理消息丟失的情況?怎么保證消息傳遞的順序性?頭大頭大,問題一大堆,痛苦不已

13.一致性問題

A系統(tǒng)處理完了直接返回成功了,人都以為你這個請求就成功了;但是問題是,要是BCD三個系統(tǒng)那里,BD兩個系統(tǒng)寫庫成功了,結(jié)果C系統(tǒng)寫庫失敗了,咋整?你這數(shù)據(jù)就不一致了。

所以消息隊列實際是一種非常復(fù)雜的架構(gòu),你引入它有很多好處,但是也得針對它帶來的壞處做各種額外的技術(shù)方案和架構(gòu)來規(guī)避掉,最好之后,你會發(fā)現(xiàn),媽呀,系統(tǒng)復(fù)雜度提升了一個數(shù)量級,也許是復(fù)雜了10倍。但是關(guān)鍵時刻,用,還是得用的

14. 分布式事務(wù)

分段提交。會有一個仲裁者,然后給所有節(jié)點來發(fā)消息。當(dāng)所有節(jié)點都ack之后,才會成功。否則就得等待重發(fā)。

15.針對直播這種突然大流量的情況,該怎么設(shè)計。

1. NGINX加機器

2. cdn緩存靜態(tài)頁面

3. redis隊列,讓用戶慢點進來。

4. 加緩存。緩存用戶數(shù)據(jù),比如用戶信息。

5. 數(shù)據(jù)庫使用主從

6. 彈性擴容

7. 限流熔斷

看完上述內(nèi)容,你們掌握PHP有哪些關(guān)于高并發(fā)的面試題的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!

本文標(biāo)題:PHP有哪些關(guān)于高并發(fā)的面試題
路徑分享:http://sd-ha.com/article32/ghsdsc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供電子商務(wù)全網(wǎng)營銷推廣、企業(yè)網(wǎng)站制作、域名注冊、網(wǎng)頁設(shè)計公司、網(wǎng)站制作

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站網(wǎng)頁設(shè)計