Hoe de Sphinx-zoekmachine op CentOS 7 te installeren

Sphinx is een gratis en open source full-text zoekmachine die in verschillende webapplicaties kan worden geïntegreerd om snelle zoekresultaten van hoge kwaliteit te bieden.

Dit artikel laat zien hoe u een Sphinx-zoekmachine instelt om een ​​voorbeeld van een MariaDB-database te indexeren en te doorzoeken op een Vultr CentOS 7-serverinstantie. Het zal u enkele voorlopige ideeën geven over hoe u Sphinx in uw project kunt gebruiken.

Vereisten

  • Implementeer een nieuwe CentOS 7-serverinstantie via het Vultr-configuratiescherm.
  • Gebruik een niet-root sudo-gebruiker om in te loggen vanaf uw SSH-terminal. Lees in dit artikel hoe je een sudo-gebruiker kunt maken .

Stap 1: werk uw systeem bij

sudo yum update -y && sudo reboot

Nadat het systeem opnieuw is opgestart, gebruikt u dezelfde sudo-gebruiker om opnieuw in te loggen.

Stap 2: Installeer en configureer MariaDB

Sphinx kan worden gebruikt om verschillende gegevensbronnen te doorzoeken, zoals SQL-databases, platte tekstbestanden, HTML-bestanden, enz. Laten we eens kijken hoe u Sphinx kunt gebruiken om zoekopdrachten uit te voeren op een MariaDB-database.

Installeer MariaDB met YUM:

sudo yum install mariadb mariadb-server

Start de MariaDB-service:

sudo systemctl start mariadb.service
sudo systemctl enable mariadb.service

Voer om veiligheidsredenen de veilige MySQL-installatie uit:

sudo /usr/bin/mysql_secure_installation

Beëindig deze procedure volgens de volgende instructies:

Enter current password for root (enter for none): Press Enter
Set root password? [Y/n]: Input Y, then press Enter
New password: Input a new password for root, press Enter
Re-enter new password: Input the same password again, then press Enter
Remove anonymous users? [Y/n]: Input Y, then press Enter
Disallow root login remotely? [Y/n]: Input Y, then press Enter
Remove test database and access to it? [Y/n]: Input Y, then press Enter
Reload privilege tables now? [Y/n]: Input Y, then press Enter

Nadat de veilige MySQL-installatie is voltooid, moet u een nieuw wachtwoord instellen voor de MySQL-gebruiker "root". In deze zelfstudie zal ik ernaar verwijzen als "uw wachtwoord".

Stap 3: Installeer de nieuwste Sphinx

Om de nieuwste versie van Sphinx te installeren, moet je het juiste rpm-pakket downloaden van de officiële Sphinx-website:

cd ~
wget http://sphinxsearch.com/files/sphinx-2.2.10-1.rhel7.x86_64.rpm
sudo yum install sphinx-2.2.10-1.rhel7.x86_64.rpm

Stap 4: Maak een database om te testen

Gebruik de volgende MySQL-opdrachten om een ​​database met de naam "test" te maken:

mysql -u root -p -e "CREATE DATABASE test"

Wanneer u wordt gevraagd om een ​​wachtwoord op te geven, voert u het wachtwoord in dat u eerder hebt ingesteld en drukt u vervolgens op Enter.

Importeer nu testgegevens uit een Sphinx-voorbeeld sql-bestand:

mysql -u root -p test < /usr/share/doc/sphinx-2.2.10/example.sql

Voer nogmaals hetzelfde wachtwoord in en druk vervolgens op Enter om het importeren te voltooien.

Stap 5: Sphinx configureren

Open het Sphinx-configuratiebestand /etc/sphinx/sphinx.conf:

sudo vi /etc/sphinx/sphinx.conf

Voorlopig hoeft u alleen de MySQL-gebruikersnaam sql_useren het wachtwoord in te stellen sql_pass, wat zou zijn:

sql_user                = root
sql_pass                = yourpassword

Opslaan en afsluiten:

:wq

Stap 6: Start de indexer en zoek daemons

Zowel indexer als searchd zijn belangrijke componenten van Sphinx. Indexer is verantwoordelijk voor het verzamelen van gegevens uit de gegevensbron en searchd is het deel van de zoekmachine dat zoekopdrachten daadwerkelijk afhandelt.

Zorg ervoor dat u de volgende opdrachten ordelijk uitvoert, anders zult u fouten tegenkomen.

sudo indexer --all
sudo searchd

Maak een cron-taak om de indexstatus regelmatig bij te werken:

sudo crontab -e

Voer het volgende item in:

0 * * * * /usr/bin/indexer --rotate --config /etc/sphinx/sphinx.conf --all

Opslaan en afsluiten:

:wq

Deze cron-taak zal de indexstatus elk uur bijwerken.

Stap 7: Test uw Sphinx-zoekmachine

U kunt een vooraf gedefinieerd pythonscript gebruiken om uw opstelling van Sphinx te testen:

python /usr/share/sphinx/api/test.py this is my test document

Deze opdracht zoekt "dit is mijn testdocument" in de voorbeeld-MySQL-database en toont u vervolgens het zoekresultaat.

Hiermee is deze tutorial afgesloten. Sphinx bevat ook een zoek-API, die kan worden gebruikt vanuit uw eigen PHP-, Perl-, Python-, Ruby- of Java-projecten. Meer informatie is beschikbaar op de officiële Sphinx-website.



Leave a Comment

Kan AI vechten met toenemend aantal ransomware-aanvallen?

Kan AI vechten met toenemend aantal ransomware-aanvallen?

Ransomware-aanvallen nemen toe, maar kan AI helpen het nieuwste computervirus het hoofd te bieden? Is AI het antwoord? Lees hier weten is AI boezem of vloek

ReactOS: is dit de toekomst van Windows?

ReactOS: is dit de toekomst van Windows?

ReactOS, een open source en gratis besturingssysteem is hier met de nieuwste versie. Kan het voldoen aan de behoeften van moderne Windows-gebruikers en Microsoft uitschakelen? Laten we meer te weten komen over deze oude stijl, maar een nieuwere OS-ervaring.

Blijf verbonden via WhatsApp Desktop-app 24 * 7

Blijf verbonden via WhatsApp Desktop-app 24 * 7

WhatsApp heeft eindelijk de Desktop-app voor Mac- en Windows-gebruikers gelanceerd. Nu heb je eenvoudig toegang tot WhatsApp vanuit Windows of Mac. Beschikbaar voor Windows 8+ en Mac OS 10.9+

Hoe AI procesautomatisering naar een hoger niveau kan tillen?

Hoe AI procesautomatisering naar een hoger niveau kan tillen?

Lees dit om te weten hoe kunstmatige intelligentie populair wordt onder de kleinschalige bedrijven en hoe het de kansen vergroot om ze te laten groeien en hun concurrenten voorsprong te geven.

macOS Catalina 10.15.4 Supplement Update veroorzaakt meer problemen dan het oplost

macOS Catalina 10.15.4 Supplement Update veroorzaakt meer problemen dan het oplost

Onlangs heeft Apple macOS Catalina 10.15.4 uitgebracht, een aanvullende update om problemen op te lossen, maar het lijkt erop dat de update meer problemen veroorzaakt die ertoe leiden dat mac-machines worden gemetseld. Lees dit artikel voor meer informatie

13 Commerciële data-extractietools voor big data

13 Commerciële data-extractietools voor big data

13 Commerciële data-extractietools voor big data

Wat is een logboekbestandssysteem en hoe werkt het?

Wat is een logboekbestandssysteem en hoe werkt het?

Onze computer slaat alle gegevens op een georganiseerde manier op, het zogenaamde Journaling-bestandssysteem. Het is een efficiënte methode waarmee de computer bestanden kan zoeken en weergeven zodra u op zoeken drukt.https://wethegeek.com/?p=94116&preview=true

Technologische singulariteit: een verre toekomst van de menselijke beschaving?

Technologische singulariteit: een verre toekomst van de menselijke beschaving?

Naarmate de wetenschap zich snel ontwikkelt en veel van onze inspanningen overneemt, nemen ook de risico's toe om onszelf te onderwerpen aan een onverklaarbare singulariteit. Lees, wat singulariteit voor ons kan betekenen.

Een inzicht in 26 Big Data-analysetechnieken: deel 1

Een inzicht in 26 Big Data-analysetechnieken: deel 1

Een inzicht in 26 Big Data-analysetechnieken: deel 1

De impact van kunstmatige intelligentie in de gezondheidszorg 2021

De impact van kunstmatige intelligentie in de gezondheidszorg 2021

AI in de zorg heeft de afgelopen decennia grote sprongen gemaakt. De toekomst van AI in de gezondheidszorg groeit dus nog steeds met de dag.