Як встановити пошукову систему 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.

Залишити коментар

Повстання машин: застосування ШІ в реальному світі

Повстання машин: застосування ШІ в реальному світі

Штучний інтелект не в майбутньому, він тут прямо в сьогоденні У цьому блозі Прочитайте, як програми штучного інтелекту вплинули на різні сектори.

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. Прочитайте цю статтю, щоб дізнатися більше