von Michael Stucki, 02.12.2008

Schneller finden dank Volltext-Index: Indexed Search wird aufgebohrt

Aus dem
t3n Magazin Nr. 14

Jetzt kaufen

Tuning per TypoScript

Es gibt viele Möglichkeiten, um die Suchgeschwindigkeit zu verbessern. Dabei werden oft mit sehr wenig Aufwand sehr gute Verbesserungen erzielt:

  • Suchen nur nach ganzen Wörtern statt Teilwörtern: findet beispielsweise „Geburt“, aber nicht „Geburtstag“
  • Ignorieren von vererbten Zugriffsberechtigungen: findet Inhalte auf zugriffgeschützter Seite A, aber nicht auf deren Unterseite B
  • Deaktiveren der exakten Ergebniszählung: Diese Einstellung ist standardmäßig bereits aktiv. Führt bei der Zählung der gesamten Ergebnisse keine vollständige Prüfung von doppelten und überflüssigen Einträgen durch. Dadurch kann die Anzeige der Anzahl an Suchergebnissen auf jeder Ergebnisseite variieren.

Das folgende Listing fasst die benötigten TypoScript-Anpassungen zusammen:

TYPOSCRIPT - SETUP

plugin.tx_indexedsearch {
    # Suche standardmäßig nur ganze Wörter
    _DEFAULT_PI_VARS.type = 0

    # Ignoriere vererbte Seiteneigenschaften (Zugriff, etc.)
    search.skipExtendToSubpagesChecking = 1

    # Deaktiviere exakte Ergebniszählung
    search.exactCount = 0
}

Listing 1

Das Ergebnis ist je nachdem mehr oder weniger zufriedenstellend, denn all diese Anpassungen sind mit Kompromissen verbunden: Entweder es werden nur noch ganze Wörter gefunden oder Seiten aus dem geschützten Bereich werden nicht mehr berücksichtigt.

Fulltext Index

Darum bietet sich eine weitere sehr effiziente Anpassung an, die sich dadurch auszeichnet, dass sie eine bisher ungenutzte Funktion des MySQL-Datenbanksystems nutzt: Volltext-Indexe [2]. Volltext-Indexe sind MySQL-interne Indextabellen, die speziell für die Indexierung von großen Textfeldern ausgelegt sind. Dadurch wird ein großer Teil der Suchabfrage abgenommen und durch MySQL-interne Bordmittel [3] [4] ersetzt. Durch den entstandenen Geschwindigkeitsgewinn dauert die Suche je nach Umfang der Website nur noch circa die Hälfte der ursprünglichen Zeit.

Seite:  1 2 3 4

Empfohlene Artikel