搜尋
首頁php框架Laravel負載平衡,分散式,叢集的理解,多台伺服器程式碼如何同步

負載平衡,分散式,叢集的理解,多台伺服器程式碼如何同步

下面一次解釋下這些名詞的概念

集群

#我們的專案如果跑在一台機器上,如果這台機器出現故障的話,或者用戶請求量比較高,一台機器支撐不住的話。我們的網站可能就訪問不了。那要怎麼解決呢?就需要使用多台機器,部署一樣的程序,讓幾個機​​器同時的運行我們的網站。那怎麼怎麼分發請求的我們所有的機器上。所以負載平衡的概念就出現了。

負載平衡

負載平衡是指基於反向代理能將現在所有的請求根據指定的策略演算法,分發到不同的伺服器上。常用實作負載平衡的可以用nginx,lvs。但是現在也有個問題,如果負載平衡伺服器出現問題了怎麼辦?所有冗餘的概念就出現了。

冗餘

冗餘其實就是兩個或多台伺服器 一個主伺服器,一個從伺服器。假設一個主伺服器的負載平衡伺服器出現了問題,從伺服器能夠取代主伺服器來繼續負載平衡。實現的方式就是使用keepalive來搶佔虛擬主機。

分散式

分散式其實就是將一個大專案的拆分出來,單獨運行。

舉個上面的例子。假設我們的訪問量特別大。我們就可以做成分佈式,跟cdn一樣的機制。在北京,杭州,深圳三個地方都搭建一個一模一樣的集群。離北京近的用戶就訪問北京的集群,離深圳近的就訪問深圳這邊的集群。這樣就將我們網戰給拆分3個區域了,各自獨立。

再舉個例子比如我們redis分散式。 redis分散式是將redis中的資料分散到不同的伺服器上面,每台伺服器儲存不同的內容,而mysql叢集是每台伺服器都放著一樣的資料。這也就理解了分散式和集群的概念。

mysql 主從

mysql master伺服器會把sql操作日誌寫入到bin.log 日誌裡 slave伺服器會去讀master的bin.log 日誌,然後執行sql語句。

主從有以下幾個問題。

1.master伺服器能寫又能讀,slave卻只能寫。

slave讀取的資料還沒寫入,這樣該怎麼解決呢?

1.假如緩存,從快取讀取。
2.強制從master讀取。
3.使用pxc集群,任何一個節點都是可讀可寫的,讀寫強一致性。

laravel如何解決資料不一致

在config/database.php mysql設定區塊中將sticky設為true

sticky 是一個可選值,它可用於立即讀取取在目前請求週期內已寫入資料庫的記錄。若 sticky 選項啟用,且目前請求週期內執行過 “寫入” 操作,那麼任何 “讀取” 操作都會使用 “寫入” 連線。這樣可確保同一個請求週期內寫入的資料可以立即讀取到,從而避免主從延遲導致資料不一致的問題。不過是否啟用它,取決於應用程式的需求。

如果我們的程式碼怎麼同步到多台伺服器上呢?

laravel為我們提供了擴充包laravel/envoy,它為定義遠端伺服器的日常任務,提供了一套簡潔、輕量的語法。 Blade 風格語法即可實現部署任務的設定、Artisan 指令的執行等。

composer global require laravel/envoy

Envoy 任務都應在專案根目錄下的 Envoy.blade.php 中定義。寫入一下內容

@servers(['web-1' => '192.168.1.1', 'web-2' => '192.168.1.2'])

@task('deploy', ['on' => ['web-1', 'web-2']])
    cd site
    git pull origin {{ $branch }}
    composer update
    php artisan migrate
@endtask

以上程式碼意思就是在命令列envoy run deploy時候,我們會ssh到會web-1,web-2 執行

    cd site
    git pull origin {{ $branch }}
    php artisan migrate

當然這個前提是我們已經加入了ssh到遠端的伺服器上。

更多Laravel相關技術文章,請造訪Laravel教學專欄進行學習!

以上是負載平衡,分散式,叢集的理解,多台伺服器程式碼如何同步的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
為什麼Laravel如此受歡迎?為什麼Laravel如此受歡迎?Apr 02, 2025 pm 02:16 PM

Laravel受歡迎的原因包括其簡化開發過程、提供愉快的開發環境和豐富的功能。 1)它吸收了RubyonRails的設計理念,結合PHP的靈活性。 2)提供瞭如EloquentORM、Blade模板引擎等工具,提高開發效率。 3)其MVC架構和依賴注入機制使代碼更加模塊化和可測試。 4)提供了強大的調試工具和性能優化方法,如緩存系統和最佳實踐。

django或laravel哪個更好?django或laravel哪個更好?Mar 28, 2025 am 10:41 AM

Django和Laravel都是全棧框架,Django適合Python開發者和復雜業務邏輯,Laravel適合PHP開發者和優雅語法。 1.Django基於Python,遵循“電池齊全”哲學,適合快速開發和高並發。 2.Laravel基於PHP,強調開發者體驗,適合小型到中型項目。

哪個是更好的PHP或Laravel?哪個是更好的PHP或Laravel?Mar 27, 2025 pm 05:31 PM

PHP和Laravel不是直接可比的,因為Laravel是基於PHP的框架。 1.PHP適合小型項目或快速原型開發,因其簡單直接。 2.Laravel適合大型項目或高效開發,因其提供豐富功能和工具,但學習曲線較陡,性能可能不如純PHP。

Laravel是前端還是後端?Laravel是前端還是後端?Mar 27, 2025 pm 05:31 PM

laravelisabackendframeworkbuiltonphp,設計ForweBapplicationDevelopment.itfocusessonserver-sideLogic,databasemagemention和Applicationstructure和CanBeintegratedWithFrontendTechnologiesLikeLikeVue.jsorreActeReacterVue.jsorreActforforfull-stackDevefloct。

如何在Laravel中創建和使用自定義刀片指令?如何在Laravel中創建和使用自定義刀片指令?Mar 17, 2025 pm 02:50 PM

本文討論了Laravel中的創建和使用自定義刀片指令以增強模板。它涵蓋了定義指令,在模板中使用它們,並在大型項目中管理它們,強調了改進的代碼可重複性和R等好處

如何使用Laravel的組件來創建可重複使用的UI元素?如何使用Laravel的組件來創建可重複使用的UI元素?Mar 17, 2025 pm 02:47 PM

本文討論了使用組件在Laravel中創建和自定義可重複使用的UI元素,從而為組織提供最佳實踐並建議增強包裝。

如何使用Laravel的路由功能來創建SEO友好的URL?如何使用Laravel的路由功能來創建SEO友好的URL?Mar 17, 2025 pm 02:43 PM

文章討論了使用Laravel的路由來創建SEO友好的URL,涵蓋最佳實踐,規範的URL和SEO優化工具。WordCount:159

如何使用Laravel的工匠控制台自動執行常見任務?如何使用Laravel的工匠控制台自動執行常見任務?Mar 17, 2025 pm 02:39 PM

Laravel的工匠控制台可以自動化任務,例如生成代碼,運行遷移和調度。關鍵命令包括:​​控制器,遷移和DB:種子。可以為特定需求創建自定義命令,增強工作流效率。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
3 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用