Sådan installeres Sphinx-søgemaskinen på CentOS 7

Sphinx er en gratis og open source fuldtekstsøgemaskine, som kan integreres i forskellige webapplikationer for at give hurtige søgeresultater af høj kvalitet.

Denne artikel viser dig, hvordan du konfigurerer en Sphinx-søgemaskine til at indeksere og søge i et eksempel på en MariaDB-database på en Vultr CentOS 7-serverinstans. Det vil give dig nogle foreløbige ideer til, hvordan du kan bruge Sphinx i dit projekt.

Forudsætninger

  • Implementer en ny CentOS 7-serverinstans fra Vultr-kontrolpanelet.
  • Brug en ikke-root sudo-bruger til at logge ind fra din SSH-terminal. Se, hvordan du opretter en sudo-bruger i denne artikel .

Trin 1: Opdater dit system

sudo yum update -y && sudo reboot

Når systemets genstart er færdig, skal du bruge den samme sudo-bruger til at logge på igen.

Trin 2: Installer og konfigurer MariaDB

Sphinx kan bruges til at søge i forskellige datakilder, såsom SQL-databaser, almindelige tekstfiler, HTML-filer osv. Lad os her se på, hvordan man bruger Sphinx til at udføre søgninger på en MariaDB-database.

Installer MariaDB ved hjælp af YUM:

sudo yum install mariadb mariadb-server

Start MariaDB-tjenesten:

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

Af sikkerhedsmæssige årsager skal du udføre den sikre MySQL-installation:

sudo /usr/bin/mysql_secure_installation

Afslut denne procedure i overensstemmelse med følgende instruktioner:

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

Når den sikre MySQL-installation er færdig, skal du indstille en ny adgangskode til MySQL-brugerens "root". I denne tutorial vil jeg henvise til det som "dit kodeord".

Trin 3: Installer den nyeste Sphinx

For at installere den nyeste version af Sphinx skal du downloade den korrekte rpm-pakke fra Sphinx' officielle hjemmeside:

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

Trin 4: Opret en database til test

Brug følgende MySQL-kommandoer til at oprette en database med navnet "test":

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

Når du bliver bedt om at angive en adgangskode, skal du indtaste den, du har angivet tidligere, og derefter trykke på Enter.

Importer nu testdata fra en Sphinx eksempel sql-fil:

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

Indtast igen den samme adgangskode og tryk derefter på Enter for at afslutte importen.

Trin 5: Konfigurer Sphinx

Åbn Sphinx-konfigurationsfilen /etc/sphinx/sphinx.conf:

sudo vi /etc/sphinx/sphinx.conf

For nu behøver du kun at konfigurere MySQL-brugernavnet sql_userog adgangskoden sql_pass, som ville være:

sql_user                = root
sql_pass                = yourpassword

Gem og luk:

:wq

Trin 6: Start indekseringsprogrammet og søg efter dæmoner

Både indexer og searchd er vigtige komponenter i Sphinx. Indexer er ansvarlig for at indsamle data fra datakilden, og searchd er den del af søgemaskinen, som faktisk håndterer søgninger.

Sørg for at køre følgende kommandoer ordentligt, ellers vil du støde på fejl.

sudo indexer --all
sudo searchd

For at opdatere indeksstatus regelmæssigt skal du oprette et cron-job:

sudo crontab -e

Indtast følgende post:

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

Gem og luk:

:wq

Dette cron-job vil opdatere indeksstatus hver time.

Trin 7: Test din Sphinx-søgemaskine

Du kan bruge et foruddefineret python-script til at teste din opsætning af Sphinx:

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

Denne kommando vil søge efter "dette er mit testdokument" i eksemplet på MySQL-databasen og derefter vise dig søgeresultatet.

Det afslutter denne tutorial. Sphinx inkluderer også en søge-API, som kan bruges fra dine egne PHP-, Perl-, Python-, Ruby- eller Java-projekter. Mere information er tilgængelig på Sphinx officielle hjemmeside.

Efterlad en kommentar

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

Kunstig intelligens er ikke i fremtiden, det er her lige i nuet I denne blog Læs, hvordan kunstig intelligens-applikationer har påvirket forskellige sektorer.

DDOS-angreb: et kort overblik

DDOS-angreb: et kort overblik

Er du også et offer for DDOS-angreb og forvirret over forebyggelsesmetoderne? Læs denne artikel for at løse dine spørgsmål.

Har du nogensinde spekuleret på, hvordan tjener hackere penge?

Har du nogensinde spekuleret på, hvordan tjener hackere penge?

Du har måske hørt, at hackere tjener mange penge, men har du nogensinde spekuleret på, hvordan tjener de den slags penge? lad os diskutere.

Revolutionære opfindelser fra Google, der vil gøre dit liv lettere.

Revolutionære opfindelser fra Google, der vil gøre dit liv lettere.

Vil du se revolutionerende opfindelser fra Google, og hvordan disse opfindelser ændrede livet for ethvert menneske i dag? Læs derefter til bloggen for at se opfindelser fra Google.

Fredag ​​Essential: Hvad skete der med AI-drevne biler?

Fredag ​​Essential: Hvad skete der med AI-drevne biler?

Konceptet med selvkørende biler til at køre på vejene ved hjælp af kunstig intelligens er en drøm, vi har haft i et stykke tid nu. Men på trods af flere løfter er de ingen steder at se. Læs denne blog for at lære mere...

Teknologisk singularitet: En fjern fremtid for menneskelig civilisation?

Teknologisk singularitet: En fjern fremtid for menneskelig civilisation?

Efterhånden som videnskaben udvikler sig i et hurtigt tempo og overtager en stor del af vores indsats, stiger risikoen for at udsætte os selv for en uforklarlig Singularitet. Læs, hvad singularitet kunne betyde for os.

Funktioner af Big Data Reference Architecture Layers

Funktioner af Big Data Reference Architecture Layers

Læs bloggen for at kende forskellige lag i Big Data-arkitekturen og deres funktionaliteter på den enkleste måde.

Udvikling af datalagring – Infografik

Udvikling af datalagring – Infografik

Opbevaringsmetoderne for dataene har været under udvikling, kan være siden fødslen af ​​dataene. Denne blog dækker udviklingen af ​​datalagring på basis af en infografik.

6 fantastiske fordele ved at have smarte hjemmeenheder i vores liv

6 fantastiske fordele ved at have smarte hjemmeenheder i vores liv

I denne digitalt drevne verden er smarte hjemmeenheder blevet en afgørende del af livet. Her er et par fantastiske fordele ved smarte hjemmeenheder om, hvordan de gør vores liv værd at leve og enklere.

macOS Catalina 10.15.4-tillægsopdatering forårsager flere problemer end at løse

macOS Catalina 10.15.4-tillægsopdatering forårsager flere problemer end at løse

For nylig udgav Apple macOS Catalina 10.15.4 en supplerende opdatering for at løse problemer, men det ser ud til, at opdateringen forårsager flere problemer, hvilket fører til mursten af ​​mac-maskiner. Læs denne artikel for at lære mere