Ich habe eine Datenbank und eine Tabelle mit ca. 200 MB Daten. (Produktbeschreibungen und viele Werte) Ich brauche diese Werte, um einige Detail-Seiten anzuzeigen. Also plane ich, ein kleines Cache-System zu verwenden, um die Dinge zu beschleunigen. Ich denke, Serialisierung ist der bessere Weg, um mit PHP zu gehen.PHP SQL-Cache mit Serialisierung, Optimierung?
Jetzt frage ich mich, wie Sie meine Daten am besten speichern, um die beste Geschwindigkeit zu erhalten. Jedes Produkt als eine Datei, eine Datei mit allen Produkten oder Chunks (sagen wir 100 Produkte pro Datei)?
Ich möchte wie diese Informationen die in einem Objekt speichern, serialisiert sie und speichern:
class saveObj
{
$sql = "SELECT * FROM products LIMIT 0,100"
$time;
$data;
};
Dateiname: sql_products_0_100.data
Wird mein Plan effizient sein oder weiß jemand einen Weg optimieren?
(würde ich alle Datendateien einmal pro Tag erstellen)
Ich dachte über Memcached nach, aber memcached scheint ein Problem mit der Shopping-Software zu haben (Prestashop) Unter Verwendung von Dateien hätte ich auch die Möglichkeit, Daten mit einigen Python-Skripten zu ändern. Produktdaten müssen einmal am Tag "aktualisiert" werden und das müssen alle Produktseiten zum Crawlen sein (Google-Händler, andere Suchseiten). –
Wenn bei memcached die Werte im Speicher gespeichert werden, kann dies nicht zu Problemen führen, wenn zu viele Werte gespeichert werden? –
Nein, Memcached ist in Ordnung. Zum Beispiel, wenn Sie einen Server mit 8 GB RAM haben. Sie können dann 7 GB Memcache zum Speichern von Objekten zuweisen. Dies sollte reichlich für Ihre Zwecke sein. Wenn das nicht genug ist, können Sie dem Pool weitere Computer hinzufügen. Wenn Sie jedoch nur einen Server ausführen, sehen Sie sich APC an, da dies ideal für das Caching einzelner Server ist. – F21