负载均衡,分布式,集群的理解,多台服务器代码如何同步
下面一次解释下这些名词的概念
集群
我们的项目如果跑在一台机器上,如果这台机器出现故障的话,或者用户请求量比较高,一台机器支撑不住的话。我们的网站可能就访问不了。那怎么解决呢?就需要使用多台机器,部署一样的程序,让几个机器同时的运行我们的网站。那怎么怎么分发请求的我们的所有机器上。所以负载均衡的概念就出现了。
负载均衡
负载均衡是指基于反向代理能将现在所有的请求根据指定的策略算法,分发到不同的服务器上。常用实现负载均衡的可以用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教程栏目进行学习!
Atas ialah kandungan terperinci 负载均衡,分布式,集群的理解,多台服务器代码如何同步. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Dalam bidang komputer moden, protokol TCP/IP adalah asas untuk komunikasi rangkaian. Sebagai sistem pengendalian sumber terbuka, Linux telah menjadi sistem pengendalian pilihan yang digunakan oleh banyak perniagaan dan organisasi. Walau bagaimanapun, apabila aplikasi dan perkhidmatan rangkaian menjadi komponen perniagaan yang semakin kritikal, pentadbir selalunya perlu mengoptimumkan prestasi rangkaian untuk memastikan pemindahan data yang pantas dan boleh dipercayai. Artikel ini akan memperkenalkan cara untuk meningkatkan kelajuan penghantaran rangkaian sistem Linux dengan mengoptimumkan prestasi TCP/IP dan prestasi rangkaian sistem Linux. Artikel ini akan membincangkan a

Pengesanan kegagalan dinamik dan strategi pelarasan berat beban dalam penyelesaian pengimbangan beban Nginx memerlukan contoh kod khusus Pengenalan Dalam persekitaran rangkaian konkurensi tinggi, pengimbangan beban ialah penyelesaian biasa yang boleh meningkatkan ketersediaan dan prestasi tapak web dengan berkesan. Nginx ialah pelayan web sumber terbuka, berprestasi tinggi yang menyediakan keupayaan pengimbangan beban yang berkuasa. Artikel ini akan memperkenalkan dua ciri penting dalam pengimbangan beban Nginx, pengesanan kegagalan dinamik dan strategi pelarasan berat beban, dan menyediakan contoh kod khusus. 1. Pengesanan kegagalan dinamik Pengesanan kegagalan dinamik

Penyelesaian Ketersediaan Tinggi dan Pemulihan Bencana bagi Penyelesaian Pengimbangan Beban Nginx Dengan perkembangan pesat Internet, ketersediaan perkhidmatan Web yang tinggi telah menjadi keperluan utama. Untuk mencapai ketersediaan tinggi dan toleransi bencana, Nginx sentiasa menjadi salah satu pengimbang beban yang paling biasa digunakan dan boleh dipercayai. Dalam artikel ini, kami akan memperkenalkan ketersediaan tinggi Nginx dan penyelesaian pemulihan bencana dan memberikan contoh kod khusus. Ketersediaan Nginx yang tinggi terutamanya dicapai melalui penggunaan berbilang pelayan. Sebagai pengimbang beban, Nginx boleh mengedarkan trafik ke beberapa pelayan bahagian belakang

Strategi pengimbangan beban adalah penting dalam rangka kerja Java untuk pengedaran permintaan yang cekap. Bergantung pada situasi konkurensi, strategi berbeza mempunyai prestasi berbeza: Kaedah pengundian: prestasi stabil di bawah konkurensi rendah. Kaedah undian berwajaran: Prestasi adalah serupa dengan kaedah pengundian di bawah konkurensi rendah. Bilangan kaedah sambungan paling sedikit: prestasi terbaik di bawah keselarasan tinggi. Kaedah rawak: mudah tetapi prestasi lemah. Hashing Konsisten: Mengimbangi beban pelayan. Digabungkan dengan kes praktikal, artikel ini menerangkan cara memilih strategi yang sesuai berdasarkan data prestasi untuk meningkatkan prestasi aplikasi dengan ketara.

Cara menggunakan Redis untuk mencapai penyegerakan data teragih Dengan perkembangan teknologi Internet dan senario aplikasi yang semakin kompleks, konsep sistem teragih semakin diterima pakai secara meluas. Dalam sistem teragih, penyegerakan data merupakan isu penting. Sebagai pangkalan data dalam memori berprestasi tinggi, Redis bukan sahaja boleh digunakan untuk menyimpan data, tetapi juga boleh digunakan untuk mencapai penyegerakan data teragih. Untuk penyegerakan data teragih, biasanya terdapat dua mod biasa: mod terbitkan/langgan (Terbitkan/Langgan) dan replikasi induk-hamba (Master-slave).

Cara Redis melaksanakan pengurusan sesi teragih memerlukan contoh kod khusus Pengurusan sesi teragih adalah salah satu topik hangat di Internet hari ini Dalam menghadapi kesesuaian yang tinggi dan volum data yang besar, kaedah pengurusan sesi tradisional secara beransur-ansur menjadi tidak mencukupi. Sebagai pangkalan data nilai kunci berprestasi tinggi, Redis menyediakan penyelesaian pengurusan sesi teragih. Artikel ini akan memperkenalkan cara menggunakan Redis untuk melaksanakan pengurusan sesi teragih dan memberikan contoh kod khusus. 1. Pengenalan kepada Redis sebagai storan sesi teragih Kaedah pengurusan sesi tradisional adalah untuk menyimpan maklumat sesi

Cara menggunakan Workerman untuk membina sistem pengimbangan beban dengan ketersediaan tinggi memerlukan contoh kod khusus Dalam bidang teknologi moden, dengan perkembangan pesat Internet, semakin banyak laman web dan aplikasi perlu mengendalikan sejumlah besar permintaan serentak. Untuk mencapai ketersediaan tinggi dan prestasi tinggi, sistem pengimbangan beban telah menjadi salah satu komponen penting. Artikel ini akan memperkenalkan cara menggunakan rangka kerja sumber terbuka PHP Workerman untuk membina sistem pengimbangan beban dengan ketersediaan tinggi dan menyediakan contoh kod khusus. 1. Pengenalan kepada Workerman Worke

MongoDB ialah pangkalan data NoSQL sumber terbuka dengan prestasi tinggi, berskala dan fleksibiliti. Dalam sistem teragih, penjadualan tugas dan pelaksanaan adalah isu utama Dengan menggunakan ciri-ciri MongoDB, penjadualan tugasan dan penyelesaian pelaksanaan boleh direalisasikan. 1. Analisis Keperluan untuk Penjadualan Tugasan Teragih Dalam sistem teragih, penjadualan tugas ialah proses memperuntukkan tugas kepada nod yang berbeza untuk dilaksanakan. Keperluan penjadualan tugas biasa termasuk: 1. Pengagihan permintaan tugas: Hantar permintaan tugas ke nod pelaksanaan yang tersedia.
