Rumah >pembangunan bahagian belakang >tutorial php >Menggunakan Redis untuk melaksanakan strategi pengehadan semasa dalam PHP

Menggunakan Redis untuk melaksanakan strategi pengehadan semasa dalam PHP

WBOY
WBOYasal
2023-05-16 08:01:501551semak imbas

Dengan perkembangan Internet, bilangan permintaan untuk banyak tapak web atau aplikasi semakin meningkat dari hari ke hari, yang membawa cabaran hebat kepada pengurusan sumber bahagian pelayan. Dalam kes ini, strategi mengehadkan semasa menjadi penyelesaian penting. Artikel ini akan membincangkan cara menggunakan Redis untuk melaksanakan strategi pengehadan semasa dalam aplikasi PHP.

1. Pengenalan kepada Redis

Redis ialah pangkalan data sumber terbuka moden yang menggunakan memori untuk menyimpan data, menjadikan membaca dan menulis sangat pantas. Redis menyokong pelbagai jenis data, termasuk rentetan, cincang, senarai, set dan set tersusun. Selain itu, Redis juga menyediakan fungsi lanjutan seperti penerbitan dan langganan, transaksi, dsb.

2. Pengenalan kepada strategi pengehadan semasa

Strategi pengehadan semasa merujuk kepada mengehadkan kekerapan permintaan aplikasi atau tapak web untuk melindungi sumber bahagian pelayan dan mengelakkan penggunaan berlebihan. Contohnya, untuk sesetengah perkhidmatan API yang memerlukan pembayaran, pentadbir tapak web dan aplikasi mungkin mengehadkan permintaan daripada pengguna yang tidak berbayar untuk mengelakkan penyalahgunaan sumber dan penurunan hasil. Untuk contoh lain, untuk sesetengah operasi yang memerlukan pengesahan log masuk, pentadbir mungkin menyekat permintaan yang menyalahi undang-undang untuk menghalang serangan kekerasan.

3. Kaedah menggunakan Redis untuk melaksanakan strategi pengehadan semasa

Redis menyediakan algoritma yang dipanggil "Token Bucket" untuk melaksanakan strategi pengehadan semasa. Dalam algoritma ini, permintaan dianggap sebagai token dan pelayan menyimpan token ini dalam baldi (dirujuk sebagai struktur data Redis ZSET). Setiap token membawa cap masa yang menunjukkan bila token dijana. Apabila permintaan tiba, ia cuba mendapatkan token, dan jika pemerolehan berjaya, pelaksanaan boleh diteruskan ke bawah. Jika pemerolehan gagal, permintaan itu dianggap sebagai pendikit.

Berikut ialah cara melaksanakan algoritma baldi token menggunakan Redis dalam aplikasi PHP:

1 Cipta objek klien Redis:

// Cipta klien Redis
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);

2. Tetapkan kapasiti maksimum baldi:

// Tetapkan kapasiti maksimum baldi token
$kapasiti_bucket = 1000;

3. Tetapkan kadar penjanaan token:

// Tetapkan kadar penjanaan token
$ token_rate = 100.0;

4. Tambah token:

// Tambah token
fungsi add_token($redis, $token_rate, $bucket_capacity) {

$current_time = microtime(true);
$tokens = $redis->zrevrangebyscore('tokens', '+inf', $current_time);
$tokens_count = count($tokens);

// 计算当前桶内的令牌数
$current_capacity = $bucket_capacity - $tokens_count;

// 计算新令牌的数量
$new_tokens_count = ($token_rate / $bucket_capacity) * $current_capacity;
$new_tokens_count = min($new_tokens_count, $bucket_capacity - $tokens_count);

// 添加新令牌
if ($new_tokens_count > 0) {
    $multi_exec = $redis->multi();
    for ($i = 0; $i < $new_tokens_count; $i++) {
        $multi_exec->zadd('tokens', $current_time + ($i / $token_rate), $current_time + ($i / $token_rate));
    }
    $multi_exec->exec();
}

}

5. Token semak:

// Token semak
token semak fungsi($redis, $kapasiti_timba) {

$current_time = microtime(true);
$tokens = $redis->zrevrangebyscore('tokens', '+inf', $current_time);
$tokens_count = count($tokens);

// 计算当前桶内的令牌数
$current_capacity = $bucket_capacity - $tokens_count;

// 如果桶是满的,则限流
if ($current_capacity <= 0) {
    return false;
}

// 如果桶是空的,则添加新令牌
if ($tokens_count == 0) {
    add_token($redis, $token_rate, $bucket_capacity);
}

// 获取第一个令牌
$token_time = reset($tokens);

// 如果获取令牌的时间早于当前时间,则限流
if ($token_time < $current_time) {
    return false;
}

// 删除此令牌
$redis->zremrangebyscore('tokens', '-inf', $token_time);

return true;

}

4. Kesimpulan

Melalui pengenalan artikel ini, kami dapati bahawa strategi pengehadan semasa boleh dilaksanakan dengan mudah menggunakan algoritma baldi token yang disediakan oleh Redis. Ia menghalang serangan kekerasan dan penyalahgunaan sumber serta penting untuk melindungi keselamatan dan kestabilan tapak web dan aplikasi. Secara umum, kita boleh menggunakan kaedah di atas untuk melaksanakan strategi pengehadan semasa dalam aplikasi PHP, dengan itu mengekalkan pengurusan sumber bahagian pelayan dengan berkesan.

Atas ialah kandungan terperinci Menggunakan Redis untuk melaksanakan strategi pengehadan semasa dalam PHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn