


Dengan perkembangan pesat Internet, kedudukan masa nyata telah menjadi salah satu fungsi yang diperlukan untuk banyak laman web, terutamanya yang mempunyai trafik yang sangat tinggi. Contohnya, senarai masa nyata seperti berita hangat, buku terlaris dan produk popular ialah perkara yang sering dilihat orang di pelbagai tapak web. Dalam artikel ini, kami akan memperkenalkan cara menggunakan PHP untuk melaksanakan fungsi pemeringkatan masa nyata yang mudah dan meneroka cara meningkatkan prestasinya.
1. Pengenalan fungsi
Senarai masa nyata ialah fungsi yang digunakan untuk memaparkan senarai paling popular atau paling banyak ditonton pada masa ini. Dalam artikel ini, kami akan melaksanakan kedudukan masa nyata berdasarkan kiraan lawatan. Setiap kali pengguna melawat halaman atau melakukan operasi tertentu, kami akan meningkatkan kiraan halaman atau operasi sebanyak 1 dan memaparkannya pada senarai masa nyata mengikut urutan dari tinggi ke rendah.
2. Konfigurasi persekitaran
Untuk merealisasikan fungsi ranking masa nyata, kami memerlukan persekitaran berjalan PHP. Kami boleh menggunakan mana-mana pelayan web yang menyokong PHP untuk mengkonfigurasi persekitaran. Contohnya, Apache, Nginx, dll. Pada masa yang sama, kami juga memerlukan pangkalan data MySQL untuk menyimpan kiraan akses dan maklumat halaman.
3. Langkah-langkah pelaksanaan
1 Cipta pangkalan data
Kita perlu membuat pangkalan data dan menambah jadual untuk menyimpan maklumat halaman dan kiraan akses. Kita boleh menggunakan pernyataan SQL berikut untuk mencipta pangkalan data sampel:
CREATE DATABASE counter; USE counter; CREATE TABLE pages ( id INT(11) NOT NULL AUTO_INCREMENT, name VARCHAR(255) NOT NULL, PRIMARY KEY (id) ); CREATE TABLE visits ( id INT(11) NOT NULL AUTO_INCREMENT, page_id INT(11) NOT NULL, count INT(11) NOT NULL DEFAULT 1, created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP, PRIMARY KEY (id), FOREIGN KEY (page_id) REFERENCES pages(id) ON DELETE CASCADE ON UPDATE CASCADE );
Kod di atas akan mencipta pangkalan data bernama "counter", mengandungi dua jadual: "halaman" dan "lawatan".
Antaranya, jadual "halaman" digunakan untuk menyimpan maklumat halaman, termasuk ID unik dan nama setiap halaman
Jadual "lawatan" digunakan untuk menyimpan kiraan lawatan setiap halaman, termasuk kiraan lawatan setiap halaman ID unik, ID halaman, kiraan dan masa lawatan.
2. Tulis kod PHP
Seterusnya, kami akan menulis kod PHP untuk melengkapkan fungsi ranking masa nyata. Kami akan menggunakan PDO untuk mengakses pangkalan data.
//Tentukan konfigurasi pangkalan data
$host = 'localhost';
$dbname = 'counter';
$user = 'root' ;
$pass = '';
//Buat sambungan pangkalan data
cuba {
$dbh = new PDO("mysql:host=$host;dbname=$dbname", $user, $pass);
} tangkap (PDOException $e) {
echo "Error!: " . $e->getMessage() . "<br>"; die();
}
//Dapatkan ID dan nama halaman
$pageId = $_GET['page_id'];
$pageName = $_GET['page_name'];
//Soal ID halaman berdasarkan nama halaman
$stmt = $dbh->prepare("SELECT id FROM page WHERE name = ?");
$stmt->execute(array($pageName ));
$row = $stmt->fetch(PDO::FETCH_ASSOC);
jika ($row) {
//页面存在,获取页面ID $pageId = $row['id'];
} lain {
//页面不存在,插入新记录并获取新的页面ID $stmt = $dbh->prepare("INSERT INTO pages (name) VALUES (?)"); $stmt->execute(array($pageName)); $pageId = $dbh->lastInsertId();
}
//Kemas kini kiraan lawatan
$stmt = $dbh->prepare("MASUKKAN KE DALAM lawatan (page_id) NILAI (?) PADA DUPLICATE KEY UPDATE count = count + 1");
$stmt->execute(array($pageId));
//Dapatkan senarai masa nyata
$limit = 10; //Dapatkan 10 teratas
$stmt = $dbh-> ;prepare("SELECT pages.name, SUM(visits.count) SEBAGAI kiraan DARIPADA halaman SERTAI lawatan DI pages.id = visits.page_id KUMPULAN MENGIKUT pages.name ORDER OLEH kiraan DESC LIMIT {$limit}") ;
$ stmt->execute();
$rows = $stmt->fetchAll(PDO::FETCH_ASSOC);
//Output senarai masa nyata
foreach ( $rows as $row) {
echo "{$row['name']}: {$row['count']}<br>";
}
?>
Kod PHP di atas melaksanakan operasi berikut:
1) Pertanyaan nama halaman input dan pertanyaan berdasarkan nama ID Halaman. Jika halaman itu tidak wujud, masukkan rekod baharu dan dapatkan ID halaman baharu.
2) Kemas kini kiraan akses. Jika rekod sudah wujud, nilai kiraan dikemas kini jika rekod tidak wujud, rekod baharu akan dimasukkan.
3) Soal kiraan akses semua halaman berdasarkan jadual kiraan akses dan jadual halaman, dan susunkannya dari tinggi ke rendah mengikut nilai kiraan.
4) Keluarkan 10 halaman pertama dan kiraan akses yang sepadan.
4. Pengoptimuman prestasi
Walaupun kod di atas melaksanakan fungsi kedudukan masa nyata asas, ia mungkin menghadapi masalah prestasi dalam keadaan beban tinggi. Berikut ialah beberapa petua pengoptimuman yang boleh anda gunakan untuk meningkatkan prestasi:
1) Gunakan caching
Anda boleh menggunakan caching untuk mengoptimumkan pertanyaan. Sebagai contoh, hasil pertanyaan boleh dicache dalam memori menggunakan perkhidmatan caching seperti Redis atau Memcached.
2) Gunakan tugas berjadual
Anda boleh menggunakan tugas berjadual untuk menjana kedudukan masa nyata pada selang masa yang tetap dan bukannya menjananya secara dinamik semasa setiap lawatan. Sebagai contoh, kedudukan masa nyata boleh dijana setiap minit atau jam, dan hasilnya boleh dicache dan diambil terus daripada cache apabila diakses.
3) Optimumkan pertanyaan SQL
boleh mengoptimumkan pernyataan pertanyaan SQL, seperti menggunakan indeks, mengelakkan penggunaan subkueri, menggunakan kumpulan sambungan, dsb. Di samping itu, anda juga boleh menggunakan pemecahan pangkalan data dan pemecahan jadual untuk menyuraikan data ke dalam berbilang jadual untuk mengelakkan masalah prestasi yang disebabkan oleh terlalu banyak data dalam satu jadual.
Ringkasnya, senarai masa nyata ialah fungsi penting, tetapi isu prestasi perlu dipertimbangkan semasa melaksanakannya, dan penyelesaian teknikal perlu dipilih secara fleksibel mengikut situasi sebenar.
Atas ialah kandungan terperinci Bagaimana untuk melaksanakan fungsi ranking masa nyata yang mudah dalam PHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Artikel ini membandingkan model pangkalan data asid dan asas, memperincikan ciri -ciri mereka dan kes penggunaan yang sesuai. Asid mengutamakan integriti data dan konsistensi, sesuai untuk aplikasi kewangan dan e-dagang, sementara asas memberi tumpuan kepada ketersediaan dan

Artikel ini membincangkan mendapatkan muat naik fail PHP untuk mengelakkan kelemahan seperti suntikan kod. Ia memberi tumpuan kepada pengesahan jenis fail, penyimpanan selamat, dan pengendalian ralat untuk meningkatkan keselamatan aplikasi.

Artikel membincangkan amalan terbaik untuk pengesahan input PHP untuk meningkatkan keselamatan, memberi tumpuan kepada teknik seperti menggunakan fungsi terbina dalam, pendekatan putih, dan pengesahan sisi pelayan.

Artikel ini membincangkan strategi untuk melaksanakan kadar API yang mengehadkan PHP, termasuk algoritma seperti baldi token dan baldi bocor, dan menggunakan perpustakaan seperti simfoni/kadar-limiter. Ia juga meliputi pemantauan, had kadar penyesuaian secara dinamik, dan tangan

Artikel ini membincangkan manfaat menggunakan password_hash dan password_verify dalam php untuk mendapatkan kata laluan. Hujah utama ialah fungsi ini meningkatkan perlindungan kata laluan melalui penjanaan garam automatik, algoritma hashing yang kuat, dan secur

Artikel ini membincangkan kelemahan OWASP 10 dalam strategi PHP dan mitigasi. Isu -isu utama termasuk suntikan, pengesahan yang rosak, dan XSS, dengan alat yang disyorkan untuk memantau dan mendapatkan aplikasi PHP.

Artikel ini membincangkan strategi untuk mencegah serangan XSS di PHP, memberi tumpuan kepada sanitisasi input, pengekodan output, dan menggunakan perpustakaan dan kerangka kerja yang meningkatkan keselamatan.

Artikel ini membincangkan penggunaan antara muka dan kelas abstrak dalam PHP, memberi tumpuan kepada masa untuk menggunakan setiap. Antara muka menentukan kontrak tanpa pelaksanaan, sesuai untuk kelas yang tidak berkaitan dan warisan berganda. Kelas Abstrak Memberi Funct Biasa


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

Dreamweaver Mac版
Alat pembangunan web visual

ZendStudio 13.5.1 Mac
Persekitaran pembangunan bersepadu PHP yang berkuasa

Penyesuai Pelayan SAP NetWeaver untuk Eclipse
Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.

DVWA
Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini