像陌陌这样的产品,后台如何设计缓存??具体的问题大神请点击里面,标题一下说不清楚
我们最近在做一款跟陌陌类似的软件。由于数据库已经跟不上形势了,所以不得不加缓存。但是这里就出现一个疑惑了。
对于一般的APP来说,每一个人所看见的内容是一样的,这样将这些数据直接放到缓存里面就好了。但是比如陌陌。附近的人,每一个人所看见的附近的人是不一样的。每一个人所看见的数据都不一样,该如何加载缓存?还是管你一不一样,只要用户要看见,就把数据加载到缓存里面吗?总的就是说,像陌陌这样附近的人,如果是你来设计缓存策略,你该如何设计?????????
回复内容:
我们最近在做一款跟陌陌类似的软件。由于数据库已经跟不上形势了,所以不得不加缓存。但是这里就出现一个疑惑了。
对于一般的APP来说,每一个人所看见的内容是一样的,这样将这些数据直接放到缓存里面就好了。但是比如陌陌。附近的人,每一个人所看见的附近的人是不一样的。每一个人所看见的数据都不一样,该如何加载缓存?还是管你一不一样,只要用户要看见,就把数据加载到缓存里面吗?总的就是说,像陌陌这样附近的人,如果是你来设计缓存策略,你该如何设计?????????
先说说你理解的“缓存”到底是什么吧。
如果你觉得缓存是一个神奇的能加快程序运行的东西,那么我得给你提个醒,这个“神奇”是有成本的,而且你不一定付得起。
一般来说,当你决定使用缓存的时候,有几个点是你必须先考虑的.
1)数据对时效性不敏感.
2)性能瓶颈在于数据库的io上面
3)中间数据,并非最终数据
严格意义上说,附近的人本身对时效性是不敏感的.而且这些数据应该是属于中间数据,并非最终应该入库的.即使有一定的丢失,或者显示为空,应该也能接受是么?
在不考虑成本的情况下,可以直接丢缓存.但是对于缓存的利用率,以及命中率情况,就要以实际情况的调用情况来看.
如果本身附近的人,点击量本身就很小的情况下,是有可能不做缓存的.
缓存设计还得以你具体的业务情况来做考量.

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

AI Hentai Generator
Menjana ai hentai secara percuma.

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



Mod Redis cluster menyebarkan contoh Redis ke pelbagai pelayan melalui sharding, meningkatkan skalabilitas dan ketersediaan. Langkah -langkah pembinaan adalah seperti berikut: Buat contoh Redis ganjil dengan pelabuhan yang berbeza; Buat 3 contoh sentinel, memantau contoh redis dan failover; Konfigurasi fail konfigurasi sentinel, tambahkan pemantauan maklumat contoh dan tetapan failover; Konfigurasi fail konfigurasi contoh Redis, aktifkan mod kluster dan tentukan laluan fail maklumat kluster; Buat fail nodes.conf, yang mengandungi maklumat setiap contoh Redis; Mulakan kluster, laksanakan perintah Buat untuk membuat kluster dan tentukan bilangan replika; Log masuk ke kluster untuk melaksanakan perintah maklumat kluster untuk mengesahkan status kluster; buat

PHP dan Python masing -masing mempunyai kelebihan sendiri, dan pilihannya harus berdasarkan keperluan projek. 1.Php sesuai untuk pembangunan web, dengan sintaks mudah dan kecekapan pelaksanaan yang tinggi. 2. Python sesuai untuk sains data dan pembelajaran mesin, dengan sintaks ringkas dan perpustakaan yang kaya.

Redis menggunakan jadual hash untuk menyimpan data dan menyokong struktur data seperti rentetan, senarai, jadual hash, koleksi dan koleksi yang diperintahkan. Redis berterusan data melalui snapshots (RDB) dan menambah mekanisme tulis sahaja (AOF). Redis menggunakan replikasi master-hamba untuk meningkatkan ketersediaan data. Redis menggunakan gelung acara tunggal untuk mengendalikan sambungan dan arahan untuk memastikan atom dan konsistensi data. Redis menetapkan masa tamat tempoh untuk kunci dan menggunakan mekanisme memadam malas untuk memadamkan kunci tamat tempoh.

Masa depan PHP akan dicapai dengan menyesuaikan diri dengan trend teknologi baru dan memperkenalkan ciri -ciri inovatif: 1) menyesuaikan diri dengan pengkomputeran awan, kontena dan seni bina microservice, menyokong Docker dan Kubernetes; 2) memperkenalkan pengkompil JIT dan jenis penghitungan untuk meningkatkan prestasi dan kecekapan pemprosesan data; 3) Berterusan mengoptimumkan prestasi dan mempromosikan amalan terbaik.

PHP tidak mati, tetapi sentiasa menyesuaikan diri dan berkembang. 1) PHP telah menjalani beberapa lelaran versi sejak tahun 1994 untuk menyesuaikan diri dengan trend teknologi baru. 2) Ia kini digunakan secara meluas dalam e-dagang, sistem pengurusan kandungan dan bidang lain. 3) Php8 memperkenalkan pengkompil JIT dan fungsi lain untuk meningkatkan prestasi dan pemodenan. 4) Gunakan OPCACHE dan ikut piawaian PSR-12 untuk mengoptimumkan prestasi dan kualiti kod.

Langkah-langkah untuk menyelesaikan masalah yang tidak dapat dijumpai oleh Redis-Server: periksa pemasangan untuk memastikan Redis dipasang dengan betul; Tetapkan pembolehubah persekitaran redis_host dan redis_port; Mulakan Redis Server Redis-server; Semak sama ada pelayan sedang menjalankan ping redis-cli.

Untuk melihat semua kunci di Redis, terdapat tiga cara: Gunakan perintah kunci untuk mengembalikan semua kunci yang sepadan dengan corak yang ditentukan; Gunakan perintah imbasan untuk melangkah ke atas kunci dan kembalikan satu set kunci; Gunakan arahan maklumat untuk mendapatkan jumlah kunci.

Alat dan kerangka yang perlu dikuasai dalam pembangunan H5 termasuk Vue.js, React dan Webpack. 1.vue.js sesuai untuk membina antara muka pengguna dan menyokong pembangunan komponen. 2. Leact mengoptimumkan rendering halaman melalui DOM maya, sesuai untuk aplikasi yang kompleks. 3.WebPack digunakan untuk pembungkusan modul dan mengoptimumkan beban sumber.
