• Selenium Video Tutorials

Selenium Grid - 架構



Selenium Grid 被開發為一組元件,每個元件執行自己的任務,以便 Selenium Grid 作為一個單元工作。各個元件的工作方式可能聽起來有點複雜。最新版本的 Selenium Grid 4 是在沒有利用 Selenium Grid 舊版本程式碼庫的情況下開發的。

Selenium Grid 的元件

Selenium Grid 的關鍵元件列在下面:

  • 事件匯流排 - 事件匯流排用於傳送可能在其他元件之間非同步獲得的訊息。

  • 分發器 - 分發器跟蹤 Selenium Grid 中每個可訪問的資源,這些資源可用於啟動會話(稱為插槽)並接收新的傳入請求併為其分配插槽。

  • 節點 - 節點用於執行 webdriver 會話。每個會話都會被分配一個插槽,並且節點可以擁有多個插槽,也可以不擁有。

  • 會話對映 - 會話對映維護會話 ID 與會話正在執行的節點位置之間的關係。

  • 新會話佇列 - 新會話佇列儲存傳入會話的列表,這些會話沒有分發器分配的節點。

  • 路由器 - 路由器就像 Selenium Grid 的門面,並公開到 Web。路由器將傳入請求重定向到新會話佇列或正在進行會話的節點。

  • 插槽 - 插槽是會話可以執行的位置。插槽應具有一些新會話請求應匹配的最低功能,以便分發器可以將該請求排程到具有插槽的節點。

  • 網格模型 - 網格模型描述了分發器如何監視 Selenium Grid 的效能。

元件之間的通訊方法

Selenium Grid 中元件之間的通訊方法列在下面:

  • 透過 HTTP 請求同步 JSON。

  • 非同步事件分派到事件匯流排。

在正在執行的任務是同步的場景中,或者如果難以錯放響應,則進行同步通訊。但是,在僅廣播資訊的場景中,或者如果錯放響應是可以的,則將非同步通訊傳送到事件匯流排。

Selenium Grid 元件之間的依賴關係

任何 Selenium Grid 元件都可以以任何順序開始,但理想情況下,元件以以下順序啟動:

  • 會話對映和事件匯流排首先開始。它們彼此獨立,可以同時工作。

  • 接下來,會話佇列參與。

  • 接下來,分發器可以進入畫面。它將以一定間隔連線到會話佇列並輪詢作業。輪詢可以以一定間隔或透過事件來完成。

  • 此時,可以啟動路由器。新會話請求被髮送到會話佇列,分發器將嘗試搜尋一個插槽來執行會話。

  • 接下來,可以啟動節點。節點註冊完成後,Selenium Grid 可以處理流量。

事件匯流排 分發器 節點 路由器 會話對映 會話佇列
事件匯流排
分發器
節點
路由器
會話對映
會話佇列

上表顯示了元件之間的依賴關係,其中“是”表示元件之間存在同步依賴關係。

Selenium Grid 中如何完成節點註冊?

整個節點註冊過程是一個輕量級過程。當節點變為活動狀態時,它應該以一定間隔釋出“心跳”事件。這提供了節點狀態的指示。

分發器偵聽“心跳”事件。當它接收到“心跳”事件時,它會嘗試獲取節點的 /status 端點。此資訊用於配置 Selenium Grid。分發器執行的此檢查以有條理的方式完成。但是,即使節點在開始工作後也應始終排程“心跳”事件。這樣做是為了在沒有 Selenium Grid 狀態的一致儲存的情況下,可以恢復分發器。

Selenium Grid 中節點狀態物件中的欄位

節點狀態作為 JSON 物件接收,其中包含以下欄位:

名稱 型別 描述
可用性 字串 可以是三個字串值之一 - up、draining 和 down。最常見的是 draining,它表示不應該將新的會話定向到節點,並且一旦節點上的先前會話完成,節點將終止或重新啟動。
外部 URL 字串 Selenium Grid 中每個元件都應聯絡的 URL。
上次建立的會話 整數 節點上次會話的紀元時間戳。如果所有其他引數都相似,則分發器會嘗試將新會話定向到最長時間未使用的節點。
最大會話數 整數 此整數值表示在被視為已滿之前,應在節點上並行執行的最大會話數。
節點 ID 字串 用於標識此節點物件的 UUID。
作業系統資訊 物件 具有三個欄位之一的物件 - arch、name 和 version。這些由 GridUI 和 GraphQL 查詢使用。
插槽 陣列 插槽物件陣列
版本 字串 節點版本

最好在所有上述欄位中設定值。

Selenium Grid 中的插槽物件

插槽物件指向節點內的某個插槽。特定會話可以在插槽內執行。插槽物件中的欄位列在下面:

名稱 型別 描述
ID 字串 UUID 用於標識插槽。
上次啟動 字串 這指示上次會話以 ISO-8601 格式開始的時間。
原型 物件 插槽應具有的最小功能組。例如:{"browserName": "chrome"}
會話物件 物件 指示會話物件。

Selenium Grid 中的會話物件

會話物件用於引用插槽內的當前會話。會話物件中的欄位列在下面:

名稱 型別 描述
功能 物件 會話提供的正確功能。
startTime 字串 這指示會話的開始時間,採用 ISO-8601 格式。
原型 物件 插槽應具有的最小功能組。例如:{"browserName": "chrome"}
uri 字串 與會話互動的節點 uri。

至此,我們對 Selenium Grid 架構教程的全面概述就結束了。我們首先介紹了 Selenium Grid 的關鍵元件是什麼,通訊方法是什麼,這些元件之間的依賴關係是什麼,節點註冊是如何完成的,Selenium Grid 中的節點狀態物件、槽物件和會話物件中的欄位是什麼。

這使您具備了 Selenium Grid 架構的深入知識。明智的做法是不斷實踐您所學到的知識,並探索與 Selenium 相關的其他知識,以加深您的理解並擴充套件您的視野。

廣告