Как да инсталирате търсачката Sphinx на CentOS 7

Sphinx е безплатна търсачка за пълен текст с отворен код, която може да бъде интегрирана в различни уеб приложения, за да осигури бързи и висококачествени резултати от търсенето.

Тази статия ще ви покаже как да настроите търсачка на Sphinx за индексиране и търсене в примерна база данни на MariaDB на сървърен екземпляр Vultr CentOS 7. Ще ви даде някои предварителни идеи как да използвате Sphinx във вашия проект.

Предпоставки

  • Разположете нов екземпляр на сървъра CentOS 7 от контролния панел на Vultr.
  • Използвайте sudo потребител без root права, за да влезете от вашия SSH терминал. Вижте как да създадете sudo потребител в тази статия .

Стъпка 1: Актуализирайте системата си

sudo yum update -y && sudo reboot

След като рестартирането на системата приключи, използвайте същия потребител на sudo, за да влезете отново.

Стъпка 2: Инсталирайте и конфигурирайте MariaDB

Sphinx може да се използва за търсене в различни източници на данни, като SQL бази данни, обикновени текстови файлове, HTML файлове и т.н. Тук нека да разгледаме как да използваме Sphinx за извършване на търсения в база данни на MariaDB.

Инсталирайте MariaDB с помощта на YUM:

sudo yum install mariadb mariadb-server

Стартирайте услугата MariaDB:

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

От съображения за сигурност извършете сигурната инсталация на MySQL:

sudo /usr/bin/mysql_secure_installation

Завършете тази процедура в съответствие със следните инструкции:

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

След като защитената инсталация на MySQL приключи, ще трябва да зададете нова парола за потребителя на MySQL "root". В този урок ще го наричам "вашата парола".

Стъпка 3: Инсталирайте най-новата версия на Sphinx

За да инсталирате най-новата версия на Sphinx, трябва да изтеглите правилния пакет rpm от официалния уебсайт на Sphinx:

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

Стъпка 4: Създайте база данни за тестване

Използвайте следните команди на MySQL, за да създадете база данни с име "test":

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

Когато бъдете помолени да предоставите парола, въведете тази, която сте задали по-рано и след това натиснете Enter.

Сега импортирайте тестови данни от примерен sql файл на Sphinx:

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

Отново въведете същата парола и след това натиснете Enter, за да завършите импортирането.

Стъпка 5: Конфигурирайте Sphinx

Отворете конфигурационния файл на Sphinx /etc/sphinx/sphinx.conf:

sudo vi /etc/sphinx/sphinx.conf

Засега трябва само да настроите потребителското име sql_userи паролата на MySQL sql_pass, които биха били:

sql_user                = root
sql_pass                = yourpassword

Запазете и излезте:

:wq

Стъпка 6: Стартирайте демони за индексиране и searchd

И indexer, и searchd са важни компоненти на Sphinx. Индексаторът отговаря за събирането на данни от източника на данни, а searchd е частта от търсачката, която всъщност обработва търсенията.

Уверете се, че изпълнявате следните команди подредено, или ще срещнете грешки.

sudo indexer --all
sudo searchd

За да актуализирате редовно състоянието на индекса, създайте задание за cron:

sudo crontab -e

Въведете следния запис:

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

Запазете и излезте:

:wq

Тази задача на cron ще актуализира състоянието на индекса на всеки час.

Стъпка 7: Тествайте вашата търсачка Sphinx

Можете да използвате предварително дефиниран скрипт на python, за да тествате вашата настройка на Sphinx:

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

Тази команда ще търси "това е моят тестов документ" в примерната база данни на MySQL и след това ще ви покаже резултата от търсенето.

Това завършва този урок. Sphinx също така включва API за търсене, който може да се използва от вашите собствени PHP, Perl, Python, Ruby или Java проекти. Повече информация можете да намерите на официалния уебсайт на Sphinx.

Оставете коментар

Възходът на машините: Реални приложения на AI

Възходът на машините: Реални приложения на AI

Изкуственият интелект не е в бъдещето, тук е точно в настоящето. В този блог Прочетете как приложенията за изкуствен интелект са повлияли на различни сектори.

DDOS атаки: кратък преглед

DDOS атаки: кратък преглед

Вие също сте жертва на DDOS атаки и сте объркани относно методите за превенция? Прочетете тази статия, за да разрешите вашите запитвания.

Чудили ли сте се как хакерите печелят пари?

Чудили ли сте се как хакерите печелят пари?

Може би сте чували, че хакерите печелят много пари, но чудили ли сте се някога как печелят такива пари? нека обсъдим.

Революционни изобретения на Google, които ще улеснят живота ви.

Революционни изобретения на Google, които ще улеснят живота ви.

Искате ли да видите революционни изобретения на Google и как тези изобретения промениха живота на всяко човешко същество днес? След това прочетете в блога, за да видите изобретенията на Google.

Friday Essential: Какво се случи с колите, задвижвани от изкуствен интелект?

Friday Essential: Какво се случи с колите, задвижвани от изкуствен интелект?

Концепцията за самоуправляващи се автомобили да тръгват по пътищата с помощта на изкуствен интелект е мечта, която имаме от известно време. Но въпреки няколкото обещания, те не се виждат никъде. Прочетете този блог, за да научите повече…

Технологична сингулярност: далечно бъдеще на човешката цивилизация?

Технологична сингулярност: далечно бъдеще на човешката цивилизация?

Тъй като науката се развива с бързи темпове, поемайки много от нашите усилия, рискът да се подложим на необяснима сингулярност също нараства. Прочетете какво може да означава сингулярността за нас.

Функционалности на референтните архитектурни слоеве за големи данни

Функционалности на референтните архитектурни слоеве за големи данни

Прочетете блога, за да разберете различни слоеве в архитектурата на големи данни и техните функционалности по най-простия начин.

Еволюция на съхранението на данни – инфографика

Еволюция на съхранението на данни – инфографика

Методите за съхранение на данните може да се развиват от раждането на данните. Този блог обхваща развитието на съхранението на данни на базата на инфографика.

6 невероятни предимства от наличието на интелигентни домашни устройства в живота ни

6 невероятни предимства от наличието на интелигентни домашни устройства в живота ни

В този дигитално задвижван свят устройствата за интелигентен дом се превърнаха в решаваща част от живота. Ето няколко невероятни предимства на интелигентните домашни устройства за това как те правят живота ни струващ и по-опростен.

Актуализацията на допълнението на macOS Catalina 10.15.4 причинява повече проблеми, отколкото решава

Актуализацията на допълнението на macOS Catalina 10.15.4 причинява повече проблеми, отколкото решава

Наскоро Apple пусна macOS Catalina 10.15.4 допълнителна актуализация за отстраняване на проблеми, но изглежда, че актуализацията причинява повече проблеми, водещи до блокиране на mac машини. Прочетете тази статия, за да научите повече