SlideShare a Scribd company logo
Full Text Search Engine
What is Sphinx?
Sphinx is a standalone software package provides fast and relevant full-

text search functionality to client applications. It was specially designed to
integrate well with SQL databases storing the data, and to be easily
accessed by scripting languages. However, Sphinx does not depend on
nor require any specific database to function.

On a live database of nearly 300,000 rows of five indexed columns, where
each column contains about 15 words, Sphinx can yield a result for an
"any of these words" search in 1/100th of a second (on a 2-GHz AMD
Opteron processor with 1 GB of RAM running Debian Linux® Sarge).
Key features of Sphinx
 It can index any data you can represent as a string.
 It can index the same data in different ways. With multiple indexes, each








tuned for a specific purpose, you can choose the most appropriate index
to optimize search results.
It can associate attributes with each piece of indexed data. You can then
use one or more of the attributes to further filter search results.
It supports morphology, so a search for the word "cats" also finds the
root word "cat."
You can distribute a Sphinx index among many machines, providing
failover.
It can create indexes of word prefixes of arbitrary length and indexes of
infix substrings of varying lengths. For instance, a part number may be
10 characters wide. The prefix index would match against all possible
substrings anchored at the start of the string. The infix index would
match substrings anywhere within the string.
You can run it as a storage engine within MySQL V5.
Sphinx has three components: an index generator, a search engine, and a
command-line search utility:
 The index generator is called indexer. It queries your database, indexes

each column in each row of the result, and ties each index entry to the row's
primary key.
 The search engine is a daemon called searchd. The daemon receives

search terms and other parameters, scours one or more indices, and returns
a result. If a match is made, searchd returns an array of primary keys. Given
those keys, an application can run a query against the associated database
to find the complete records that comprise the match. Searchd
communicates to applications through a socket connection on port 3312.
 The handy search utility lets you conduct searches from the command line

without writing code. If searchd returns a match, search queries the
database and displays the rows in the match set. The search utility is useful
for debugging your Sphinx configuration and performing impromptu
searches.
The indexer will query the database based on the config parameter
sql_query
E.G. of use

source src1
{
sql_query

=
SELECT
id, group_id, UNIX_TIMESTAMP(date_added) AS date_added,
title, content 
FROM documents

sql_query_info

= SELECT * FROM documents WHERE id=$id

}
index test1

{
source
path

= @CONFDIR@/data/test1

charset_type
}

= src1
= utf-8
indexer
{
mem_limit

= 246M

}

searchd
{
listen
listen

= 9306:mysql41

log

= @CONFDIR@/log/searchd.log

query_log

= @CONFDIR@/log/query.log

pid_file

= @CONFDIR@/log/searchd.pid

max_matches

= 1000

binlog_path
}

= 9312

= @CONFDIR@/data
How we utilise Sphinx Search
Sphinx
Index‟s all
product

User search‟s
term (bra)

Results
gathered from
Sphinx

Results saved
to MySQL
database

2ND User
search’s
term (bra)

Result are
gather MySQL
database
How we should utilise Sphinx
User
search

Sphinx
generates
results e.g.
product
ID‟s

Results are
displayed
to User

Query
MySQL
database
by ID‟s
On Agent Provocateur we currently we store our result from Sphinx to the
following table which I presume is same with all our clients.
MySQL Tables
 search_refine_result
 search_results

Sphinx search‟s term‟s based on specific set of fields on the products,
rangesty, ranges, styles, sizes, colours, and menu tables which is
defined by the index query on the Sphinx configuration file.
Configuration directory : (client_dir)/scripts/search/sphinx.conf
API usage e.g.

<?php
include sphinxapi.php;
$sphinx = new sphinxClient();
$sphinx->Query(„@prodgroup “GRP101”‟);
Get‟s all product in the product under the product groupid 101
Is a Search engine necessary?
Website implementing search capabilities with high traffic volumes a
search engine is diffidently necessary, some searches may be more

specialized than the database can perform, or a search may be so
complicated that the required SQL JOINs are simply too slow to keep up
with a high volume of search queries.
Our usage of Sphinx is very limited due to the search result being restored
back into the MySQL database. Sphinx is more than capable enough to
manage all search queries. It‟s certainly necessary to incorporate a search
engine on our clients website however we will need to implement the
search engine in a more flexible and expandable way easily deployable to
new and old clients.

More Related Content

PPTX
Recovered file 1
Uthara Iyer
 
PDF
WT - Web & Working of Search Engine
vinay arora
 
PPTX
working of search engine & SEO
Deepak Singh
 
PPT
3 google hacking
Syahmi Afiq Nizam
 
PPTX
Data science chapter-7,8,9
varshakumar21
 
PPTX
Rozalia alik math3 (latest)
Rozalia Alik
 
DOC
FII News
Florin Floria
 
PPTX
Introduction to google hacking database
imthebeginner
 
Recovered file 1
Uthara Iyer
 
WT - Web & Working of Search Engine
vinay arora
 
working of search engine & SEO
Deepak Singh
 
3 google hacking
Syahmi Afiq Nizam
 
Data science chapter-7,8,9
varshakumar21
 
Rozalia alik math3 (latest)
Rozalia Alik
 
FII News
Florin Floria
 
Introduction to google hacking database
imthebeginner
 

Similar to Sphinx2 (20)

PPTX
Sphinx
shinsantiger
 
PPT
Using Thinking Sphinx with rails
Rishav Dixit
 
PPT
SphinxSE with MySQL
Ritesh Puthran
 
PDF
Elasticsearch and Spark
Audible, Inc.
 
PPT
Lucene basics
Nitin Pande
 
PDF
Elasticsearch
Shagun Rathore
 
PPT
Advanced full text searching techniques using Lucene
Asad Abbas
 
PDF
Elasticsearch, a distributed search engine with real-time analytics
Tiziano Fagni
 
PPTX
Getting started with Elasticsearch in .net
Ismaeel Enjreny
 
PPTX
Getting Started With Elasticsearch In .NET
Ahmed Abd Ellatif
 
PPTX
About elasticsearch
Minsoo Jun
 
PDF
Mongo db a deep dive of mongodb indexes
Rajesh Kumar
 
DOCX
Seminar report(rohitsahu cs 17 vth sem)
ROHIT SAHU
 
PPT
Lucene and MySQL
farhan "Frank"​ mashraqi
 
ODP
Elasticsearch for beginners
Neil Baker
 
PDF
Splunk Components
NikhilSharma142682
 
PPTX
Apache lucene
Dr. Abhiram Gandhe
 
PDF
Using Sphinx for Search in PHP
Mike Lively
 
DOCX
Page 18Goal Implement a complete search engine. Milestones.docx
smile790243
 
PPTX
Query Optimization in MongoDB
Hamoon Mohammadian Pour
 
Sphinx
shinsantiger
 
Using Thinking Sphinx with rails
Rishav Dixit
 
SphinxSE with MySQL
Ritesh Puthran
 
Elasticsearch and Spark
Audible, Inc.
 
Lucene basics
Nitin Pande
 
Elasticsearch
Shagun Rathore
 
Advanced full text searching techniques using Lucene
Asad Abbas
 
Elasticsearch, a distributed search engine with real-time analytics
Tiziano Fagni
 
Getting started with Elasticsearch in .net
Ismaeel Enjreny
 
Getting Started With Elasticsearch In .NET
Ahmed Abd Ellatif
 
About elasticsearch
Minsoo Jun
 
Mongo db a deep dive of mongodb indexes
Rajesh Kumar
 
Seminar report(rohitsahu cs 17 vth sem)
ROHIT SAHU
 
Lucene and MySQL
farhan "Frank"​ mashraqi
 
Elasticsearch for beginners
Neil Baker
 
Splunk Components
NikhilSharma142682
 
Apache lucene
Dr. Abhiram Gandhe
 
Using Sphinx for Search in PHP
Mike Lively
 
Page 18Goal Implement a complete search engine. Milestones.docx
smile790243
 
Query Optimization in MongoDB
Hamoon Mohammadian Pour
 
Ad

Recently uploaded (20)

PDF
Security features in Dell, HP, and Lenovo PC systems: A research-based compar...
Principled Technologies
 
PPTX
Agile Chennai 18-19 July 2025 Ideathon | AI Powered Microfinance Literacy Gui...
AgileNetwork
 
PPTX
AI in Daily Life: How Artificial Intelligence Helps Us Every Day
vanshrpatil7
 
PDF
Get More from Fiori Automation - What’s New, What Works, and What’s Next.pdf
Precisely
 
PDF
Data_Analytics_vs_Data_Science_vs_BI_by_CA_Suvidha_Chaplot.pdf
CA Suvidha Chaplot
 
PDF
Doc9.....................................
SofiaCollazos
 
PDF
MASTERDECK GRAPHSUMMIT SYDNEY (Public).pdf
Neo4j
 
PDF
CIFDAQ's Market Wrap : Bears Back in Control?
CIFDAQ
 
PDF
Responsible AI and AI Ethics - By Sylvester Ebhonu
Sylvester Ebhonu
 
PDF
Software Development Methodologies in 2025
KodekX
 
PPTX
cloud computing vai.pptx for the project
vaibhavdobariyal79
 
PDF
Make GenAI investments go further with the Dell AI Factory
Principled Technologies
 
PDF
Accelerating Oracle Database 23ai Troubleshooting with Oracle AHF Fleet Insig...
Sandesh Rao
 
PDF
Research-Fundamentals-and-Topic-Development.pdf
ayesha butalia
 
PDF
The Future of Artificial Intelligence (AI)
Mukul
 
PDF
Google I/O Extended 2025 Baku - all ppts
HusseinMalikMammadli
 
PDF
Peak of Data & AI Encore - Real-Time Insights & Scalable Editing with ArcGIS
Safe Software
 
PDF
How Open Source Changed My Career by abdelrahman ismail
a0m0rajab1
 
PPTX
AI and Robotics for Human Well-being.pptx
JAYMIN SUTHAR
 
PDF
The Future of Mobile Is Context-Aware—Are You Ready?
iProgrammer Solutions Private Limited
 
Security features in Dell, HP, and Lenovo PC systems: A research-based compar...
Principled Technologies
 
Agile Chennai 18-19 July 2025 Ideathon | AI Powered Microfinance Literacy Gui...
AgileNetwork
 
AI in Daily Life: How Artificial Intelligence Helps Us Every Day
vanshrpatil7
 
Get More from Fiori Automation - What’s New, What Works, and What’s Next.pdf
Precisely
 
Data_Analytics_vs_Data_Science_vs_BI_by_CA_Suvidha_Chaplot.pdf
CA Suvidha Chaplot
 
Doc9.....................................
SofiaCollazos
 
MASTERDECK GRAPHSUMMIT SYDNEY (Public).pdf
Neo4j
 
CIFDAQ's Market Wrap : Bears Back in Control?
CIFDAQ
 
Responsible AI and AI Ethics - By Sylvester Ebhonu
Sylvester Ebhonu
 
Software Development Methodologies in 2025
KodekX
 
cloud computing vai.pptx for the project
vaibhavdobariyal79
 
Make GenAI investments go further with the Dell AI Factory
Principled Technologies
 
Accelerating Oracle Database 23ai Troubleshooting with Oracle AHF Fleet Insig...
Sandesh Rao
 
Research-Fundamentals-and-Topic-Development.pdf
ayesha butalia
 
The Future of Artificial Intelligence (AI)
Mukul
 
Google I/O Extended 2025 Baku - all ppts
HusseinMalikMammadli
 
Peak of Data & AI Encore - Real-Time Insights & Scalable Editing with ArcGIS
Safe Software
 
How Open Source Changed My Career by abdelrahman ismail
a0m0rajab1
 
AI and Robotics for Human Well-being.pptx
JAYMIN SUTHAR
 
The Future of Mobile Is Context-Aware—Are You Ready?
iProgrammer Solutions Private Limited
 
Ad

Sphinx2

  • 2. What is Sphinx? Sphinx is a standalone software package provides fast and relevant full- text search functionality to client applications. It was specially designed to integrate well with SQL databases storing the data, and to be easily accessed by scripting languages. However, Sphinx does not depend on nor require any specific database to function. On a live database of nearly 300,000 rows of five indexed columns, where each column contains about 15 words, Sphinx can yield a result for an "any of these words" search in 1/100th of a second (on a 2-GHz AMD Opteron processor with 1 GB of RAM running Debian Linux® Sarge).
  • 3. Key features of Sphinx  It can index any data you can represent as a string.  It can index the same data in different ways. With multiple indexes, each      tuned for a specific purpose, you can choose the most appropriate index to optimize search results. It can associate attributes with each piece of indexed data. You can then use one or more of the attributes to further filter search results. It supports morphology, so a search for the word "cats" also finds the root word "cat." You can distribute a Sphinx index among many machines, providing failover. It can create indexes of word prefixes of arbitrary length and indexes of infix substrings of varying lengths. For instance, a part number may be 10 characters wide. The prefix index would match against all possible substrings anchored at the start of the string. The infix index would match substrings anywhere within the string. You can run it as a storage engine within MySQL V5.
  • 4. Sphinx has three components: an index generator, a search engine, and a command-line search utility:  The index generator is called indexer. It queries your database, indexes each column in each row of the result, and ties each index entry to the row's primary key.  The search engine is a daemon called searchd. The daemon receives search terms and other parameters, scours one or more indices, and returns a result. If a match is made, searchd returns an array of primary keys. Given those keys, an application can run a query against the associated database to find the complete records that comprise the match. Searchd communicates to applications through a socket connection on port 3312.  The handy search utility lets you conduct searches from the command line without writing code. If searchd returns a match, search queries the database and displays the rows in the match set. The search utility is useful for debugging your Sphinx configuration and performing impromptu searches.
  • 5. The indexer will query the database based on the config parameter sql_query E.G. of use source src1 { sql_query = SELECT id, group_id, UNIX_TIMESTAMP(date_added) AS date_added, title, content FROM documents sql_query_info = SELECT * FROM documents WHERE id=$id } index test1 { source path = @CONFDIR@/data/test1 charset_type } = src1 = utf-8
  • 6. indexer { mem_limit = 246M } searchd { listen listen = 9306:mysql41 log = @CONFDIR@/log/searchd.log query_log = @CONFDIR@/log/query.log pid_file = @CONFDIR@/log/searchd.pid max_matches = 1000 binlog_path } = 9312 = @CONFDIR@/data
  • 7. How we utilise Sphinx Search Sphinx Index‟s all product User search‟s term (bra) Results gathered from Sphinx Results saved to MySQL database 2ND User search’s term (bra) Result are gather MySQL database
  • 8. How we should utilise Sphinx User search Sphinx generates results e.g. product ID‟s Results are displayed to User Query MySQL database by ID‟s
  • 9. On Agent Provocateur we currently we store our result from Sphinx to the following table which I presume is same with all our clients. MySQL Tables  search_refine_result  search_results Sphinx search‟s term‟s based on specific set of fields on the products, rangesty, ranges, styles, sizes, colours, and menu tables which is defined by the index query on the Sphinx configuration file. Configuration directory : (client_dir)/scripts/search/sphinx.conf
  • 10. API usage e.g. <?php include sphinxapi.php; $sphinx = new sphinxClient(); $sphinx->Query(„@prodgroup “GRP101”‟); Get‟s all product in the product under the product groupid 101
  • 11. Is a Search engine necessary? Website implementing search capabilities with high traffic volumes a search engine is diffidently necessary, some searches may be more specialized than the database can perform, or a search may be so complicated that the required SQL JOINs are simply too slow to keep up with a high volume of search queries. Our usage of Sphinx is very limited due to the search result being restored back into the MySQL database. Sphinx is more than capable enough to manage all search queries. It‟s certainly necessary to incorporate a search engine on our clients website however we will need to implement the search engine in a more flexible and expandable way easily deployable to new and old clients.