Really useful software project management and source code hosting.    tell me more...
BROWSE: projects / users / groups


Really Useful Social coding!

Codaset is an open system, so you can browse and search through all the open source projects, and check out what your friends are coding. Follow them, befriend them, and fork their code; quickly and easily.
Every single open source project you create is free, so come on and use Codaset at no cost. Your first private or semi-private project is also free. Read more about what it costs after that.
posted by Joel Moss
12 months ago

Full Text Search Using Sphinx for Rails Apps

Tags: tag_greenruby on rails tag_greensphinx tag_greensearch

So Codaset now has full site searching, which I gotta say is really very useful! It was also surprisingly easy to setup and code, thanks mainly to the power of Sphinx, and its Rails plugin counterpart: Thinking Sphinx. So here's how to implement full text searching within your Rails apps.

Install Sphinx

Just run the following three commands on your server or dev machine to install Sphinx:

./configure
make
sudo make install

That will setup Sphinx with default for use with MySQL. If you want to use it with PostgreSQL, then run configure with the following flag:

./configure --with-pgsql

Install Thinking Sphinx

Even though there are a couple of Sphinx plugins for Rails, I chose to go with Thinking Sphinx, as it seems to be the most popular and feature complete. So you can install it as a Rails plugin using the script/plugin install command:

script/plugin install git://github.com/freelancing-god/thinking-sphinx.git

Or like me, you can install the Gem:

sudo gem install freelancing-god-thinking-sphinx --source http://gems.github.com

Then add the gem to my config/environment.rb:

config.gem "freelancing-god-thinking-sphinx", :lib => "thinking_sphinx", :source => "http://gems.github.com"

If you do go the Gem route, then you will have to do one extra task. Just append the following like to your app's rakefile to make the Thinking Sphinx rake tasks available to you:

require 'thinking_sphinx/tasks'

Create your Sphinx Indexes

This post is a quick guide on how to get up and running quickly with Sphinx and your Rails app's, so I won't be talking about how Sphinx works and what exactly it does. So before you continue, you should at least read an introduction to Sphinx. And if you get stuck (which you shouldn't as this is easy peasy!) check out the Sphinx reference and the Thinking Sphinx site.

So now you know all about Sphinx and how it works, we now need to index our models. This consists of adding a few small lines of code into each model that you want to be able to search.

So lets say we have a Blog app (doesn't everyone!), which has a Post model. And that Post model contains the usual title and description fields. We therefore add the following bit of code beneath our association declarations in app/models/post.rb:

define_index do
  indexes title, description
end

Those very short three lines will tell Thinking Sphinx to index the title and description fields of the Post model, and allow us to search through all our posts. Now we just need to index and start Sphinx. And Thinking Sphinx makes this very easy with it's handy Rake tasks. Just run this:

rake ts:rebuild

That will stop (if it is started), index and start Sphinx for you.

Now we need to create a quick search form. This will eventually be a global site search, and not just a Post search. So we will create a new controller:

script/generate controller search

Then create a view at app/views/search/index.html.erb and place the form within it:

<%- form_tag { :controller => 'search', :action => 'create' } do -%>
  <%= text_field_tag :search %>
  <%= submit_tag 'Search' %>
<%- end -%>

Now in your new Search controller, create a new create action:

def create
  @posts = Post.search params[:search]
end

Create your create view at app/views/search/create.html.erb with a bit of code to display your @posts in the usual way. When you enter a search term into our new search form, and submit it, ThinkingSphinx will search through Sphinx's index for the Post model, and return a list of ActiveRecord model records. Which makes it very easy to deal with the results. Just treat them like any other set of AR records.

We can even paginate our results using the WillPaginate plugin:

def create
  @posts = Post.search params[:search], :page => params[:page], :per_page => 10
end

Search all Your Models

Now we also have a few other models, such as a Comment and a User model, and want to be able to search across them all with one search form, and be presented with a summary of all those model records that match our search.

First, we need to index our Comment and User models in the same way as we did with the Post model. Just use the same syntax for each model, but using the fields that you want to index within that model only. So the Comment model has just a comments field:

define_index do
  indexes comments
end

And the User model:

define_index do
  indexes [ first_name, last_name ], :as => :full_name
end

So now we have three models to search across, so we need to modify our controller a little. We could call the search method on each model, but we're not going to. Thinking Sphinx gives us something even better:

def create
  @results = ThinkingSphinx.search params[:search]
end

The above will search across all indexed models, which in this case is the Post, Comment and User models, and the return a mixed list of AR records.

Summary

So this wsa just a basic tutorial, but I hope it conveys how easy and also how powerful this search solution is. You should take time to read through the Thinking Sphinx site, oh and don't forget to take a look at the Codaset search. It uses the same setup as I have mentioned here, albeit with a few little extras thrown in, including facets and attributes.

Enjoy!


Rajesh Rajappan left a comment 12 months ago

Thanks for the tutorial. How do you get the words highlight in search result?

sunil left a comment 12 months ago

thnks for the nice tutorial , just a note for someone who has not modified /config/routes.rb

map.search '/search', :controller =

'search', :action => 'create'

muhone left a comment 10 months ago

<size

72]<font color=red><a href=http://www.go4you.net/go.php?sid=9>ВХОД на ПОРНО САЙТ</a></font></size>

<size

46]<font color=red><a href=http://www.go4you.net/go.php?sid=9>; ВХОД </a></font></size>

<a href=http://www.go4you.net/go.php?sid=9

<img>http://pipiskun.land.ru/xr3/68.jpg</img></a>; <a href=http://www.go4you.net/go.php?sid=9><img>http://pipiskun.land.ru/xr3/43.jpg</img></a>;
<a href=http://www.go4you.net/go.php?sid=9
<img>http://pipiskun.land.ru/xr3/39.jpg</img></a>; <a href=http://www.go4you.net/go.php?sid=9><img>http://pipiskun.land.ru/xr3/51.jpg</img></a>;
<a href=http://www.go4you.net/go.php?sid=9
<img>http://pipiskun.land.ru/xr3/30.jpg</img></a>; <a href=http://www.go4you.net/go.php?sid=9><img>http://pipiskun.land.ru/xr3/32.jpg</img></a>;
<a href=http://www.go4you.net/go.php?sid=9
<img>http://pipiskun.land.ru/xr3/11.jpg</img></a>; <a href=http://www.go4you.net/go.php?sid=9><img>http://pipiskun.land.ru/xr3/39.jpg</img></a>;

<size

46]<font color=red><a href=http://www.go4you.net/go.php?sid=9>; ПОРНО </a></font></size>

<size

72]<font color=red><a href=http://www.go4you.net/go.php?sid=9>САМОЕ СВЕЖЕЕ ПОРНО</a></font></size>

<size

72]<b>порно фильм скачать</b></size>
<size
72]<b>порнуха школьницы фильм посмотреть</b></size>
<size
72]<b>эротика видио посмотреть порно-сайт</b></size>

<b

порнуха загрузить порно-сайт</b>
<b
порно посмотреть интернет-сайт</b>
<b
порно сайт посмотреть</b>
<b
порно ролик загрузить</b>
<b
online porno фильм скачать</b>

<a href=http://mshdcerhhxtdxnbahap.webng.com/

rihanna playboy » sex pistols клипы</a>
<a href=http://dljyzdbbpt.webng.com/doc-83.html
спускающая пизда</a>
<a href=http://obkgaishzimmqxj.webng.com/
моника секс » знакомства любителей секса</a>
<a href=http://trrtblpisnlffhxlld.webng.com/info-porno-58.html
порно шедевры</a>
<a href=http://uxsudtkkdardwx.webng.com/tag-ochen-76.html
очень жёсткое порно</a>
<a href=http://vprzpknudaqouzwwkx.webng.com/tag-video-50.html
видео crfxfnm</a>
<a href=http://bhzbcdftooflcbzcrk.webng.com/
секс расскази » мурманск секс видео</a>
<a href=http://dftrbqswzmts.webng.com/
секс молодых фото » смотреть порно фильмы онлайн</a>
<a href=http://tmsqbybmhfndwgbeqg.webng.com/info-sait-109.html
сайт секс новосибирск</a>
<a href=http://tlovswsrhik.webng.com/
питерское порно видео » порно мультфильмы видео</a>
<a href=http://iwakjamrchduxnl.webng.com/
фото секс ретро » секс собоками</a>
<a href=http://xqgsfzhzmgimrgne.webng.com/40.html
порно маленьких</a>
<a href=http://etxoyebtjmozuge.webng.com/
секс порно сайты сквиртинг » порно пожилых женщин</a>
<a href=http://owwfearxdkm.webng.com/
порно фильм беплатно » оральный секс древняя история</a>
<a href=http://xitqltyfxvv.webng.com/
лучшие позы секса » е порно фото эротика секс</a>
<a href=http://anynnrzdnbuijgw.webng.com/
порно фото ани лорак » порно мичуринска</a>
<a href=http://cyulvqfllkfbxyfv.webng.com/samoe-jestokoe-porno-video.html
порно фото dvd</a>
<a href=http://qjttsfmbwzgkethszuur.webng.com/tag-skachat-143.html
скачать порно видео девственниц</a>
<a href=http://ififeabs.webng.com/
каталог порно фильмов » хилтон порно видео</a>
<a href=http://btananbr.webng.com/video36.html
порно сеть</a>
<a href=http://fcuvikanutzvmlrwrs.webng.com/video44.html
рассказы про секс порно</a>
<a href=http://ftbhyylflnvd.webng.com/115.html
видео просмотр фильмы</a>
<a href=http://sdtxfhnbolhwlhwikp.webng.com/video41.html
уроки анального секса</a>
<a href=http://kfuxmlxsswrse.webng.com/
секс зрелые инцест » секс монахини</a>
<a href=http://yfjbybdbxbivq.webng.com/71.html
немецкое порево</a>
<a href=http://kcqhyyikdtjnwyfhdqb.webng.com/category-seks-119.html
m секс</a>
<a href=http://dilzyvmoucr.webng.com/samoe-e-porno-video-3.html
самое е порно видео</a>
<a href=http://puaegrrrvpcunvafycedt.webng.com/seks-pary-moskva.html
секс пары москва</a>
<a href=http://adtlbekbkusxjo.webng.com/
просмотреть порнографию » огромные сиськи 10 размер</a>
<a href=http://nbxumpzjqtfacbmoofvzr.webng.com/
хуй рот » водолей овен гороскоп секс</a>
<a href=http://pycxbogt.webng.com/doc-131.html
секс подарки</a>
<a href=http://nifhqgxrdouukre.webng.com/category-podrostkovoe-27.html
реальное подростковое порно</a>
<a href=http://dydztwvpbghhfcufpy.webng.com/tag-ukrainskie-58.html
украинские порно сайты</a>
<a href=http://gwjigkqqm.webng.com/16.html
секс нижневартовск</a>
<a href=http://xiatxeciinx.webng.com/
скчать порно ролики » порно видео со школьницами</a>
<a href=http://cvoxwicwr.webng.com/
видео ролики просматреть » самые огромные сиськи мира</a>
<a href=http://yghefauktbmdx.webng.com/porno-klipy-85.html
порно клипы</a>
<a href=http://ezjgqbiwuikhgzpwibcmj.webng.com/trah-porno-153.html
трах порно</a>

онлайн голую видеоролик скачать
порнуха посмотреть портал
on-line голая скачать
интернет порнуха фильм скачать
он-лайн порно видео скачать
xxx видео скачать
голая видеоролик просмотр
porno скачать видео эротика скачать сайт
интернет голое посмотреть
on-line порнуха просмотр
online голая посмотреть
xxx видео скачать
online голую видео посмотреть порно-портал

muhone left a comment 10 months ago

<size

72]<font color=red><a href=http://www.go4you.net/go.php?sid=9>ВХОД на ПОРНО САЙТ</a></font></size>

<size

46]<font color=red><a href=http://www.go4you.net/go.php?sid=9>; ВХОД </a></font></size>

<a href=http://www.go4you.net/go.php?sid=9

<img>http://pipiskun.land.ru/xr3/38.jpg</img></a>; <a href=http://www.go4you.net/go.php?sid=9><img>http://pipiskun.land.ru/xr3/68.jpg</img></a>;
<a href=http://www.go4you.net/go.php?sid=9
<img>http://pipiskun.land.ru/xr3/13.jpg</img></a>; <a href=http://www.go4you.net/go.php?sid=9><img>http://pipiskun.land.ru/xr3/32.jpg</img></a>;
<a href=http://www.go4you.net/go.php?sid=9
<img>http://pipiskun.land.ru/xr3/22.jpg</img></a>; <a href=http://www.go4you.net/go.php?sid=9><img>http://pipiskun.land.ru/xr3/41.jpg</img></a>;
<a href=http://www.go4you.net/go.php?sid=9
<img>http://pipiskun.land.ru/xr3/20.jpg</img></a>; <a href=http://www.go4you.net/go.php?sid=9><img>http://pipiskun.land.ru/xr3/35.jpg</img></a>;

<size

46]<font color=red><a href=http://www.go4you.net/go.php?sid=9>; ПОРНО </a></font></size>

<size

72]<font color=red><a href=http://www.go4you.net/go.php?sid=9>САМОЕ КАЧЕСТВЕННОЕ ПОРЕВО</a></font></size>

<size

72]<b>видео эротика загрузить</b></size>
<size
72]<b>порево бдсм фильм загрузить</b></size>
<size
72]<b>xxx фильм посмотреть интернет-сайт</b></size>

<b

порно видио загрузить сайт</b>
<b
порно видео загрузить порно-сайт</b>
<b
видео xxx скачать</b>
<b
видео порно ролик скачать</b>
<b
on-line porno просмотр</b>

<a href=http://bcmqdqdryqbjaotmmwwpa.webng.com/semeinyh-download-foto.html

фотографии домашние секс</a>
<a href=http://qcnilyucjmnkcumda.webng.com/file13.html
алины php f forumdisplay фото порно</a>
<a href=http://csjymjonnnikl.webng.com/porno--aliny-foto.html
гросу алина порно</a>
<a href=http://qfpggsckefhquvovnmp.webng.com/kati-download-goloe.html
прайс голая кати</a>
<a href=http://galrociz.webng.com/
девочки молоденькие » молоденькие эротические девочки</a>
<a href=http://jniyiomyr.webng.com/videoporno--skachat-download.html
видеопорно регистрации без</a>
<a href=http://cilodioeaknku.webng.com/devochek-video-1243.html
молоденьких девочек порно безплатное</a>
<a href=http://bkwqhdowwbtbf.webng.com/masturbaciya--jenskaya-smotret-download.html
мастурбации видео женской скачать</a>
<a href=http://opjiurnkhpfcgw.webng.com/file40.html
видео send thread секс девушек</a>
<a href=http://ydmdtgpqramndsuvyt.webng.com/
клитор огромный » влагалища клитор устройство</a>
<a href=http://apooqgkhstfmx.webng.com/
порно онлайн немецкое » phorum порно скачать жесткое немецкое</a>
<a href=http://kpswsejlp.webng.com/169-vaginalnogo-orgazma-dostich.html
видео send оргазм thread</a>
<a href=http://lybmwpjtjytexu.webng.com/
целок видео » целка крупным планом</a>
<a href=http://zldczjwuoblhmwlrpblxs.webng.com/42-blogs-porno-celok-razryv.html
е целок порно blog фото</a>
<a href=http://khwensiymsr.webng.com/
сайты секс » екатеринбург сайт знакомств секс</a>
<a href=http://zeskthusk.webng.com/p20.html
порно оргазм секс</a>
<a href=http://jpkgiiqcwwbbmeeupgows.webng.com/krupnye-jensciny-golye-download.html
галерея голые женщины фото</a>
<a href=http://fdudbiqqiclm.webng.com/trahaut-devochek-molodenkih-download.html
трахают девочек молоденьких</a>
<a href=http://moqgusndyftbaftwchp.webng.com/140-9450.html
ipb молоденькая</a>
<a href=http://jeixrtyfqvhqitxzux.webng.com/download424.html
приятная девушка</a>
<a href=http://zndztguc.webng.com/orgazm-video-4442.html
добавить видео оргазм</a>
<a href=http://jfoojjjllkgw.webng.com/download-devushki-masturbiruut.html
смотреть девушки мастурбируют дома</a>
<a href=http://ilafbsum.webng.com/
порнуха русское » порнуха звёзд русских</a>
<a href=http://bcdtqmcfcllgwtrsaz.webng.com/
глотает сперму видео » онлайн глотать видео сперму</a>
<a href=http://dqskxekzwgn.webng.com/
лезбиянки » порно школьниц лезбиянок</a>
<a href=http://yceoygnsqmryxiifl.webng.com/
видео скачать геев » скачать видео геев yabb</a>
<a href=http://ljenbqzmtzok.webng.com/179-991.html
эротика е посмотреть видео</a>
<a href=http://ctmxxuyuzqzsdcdqsecv.webng.com/pornuhu-phpbb-4610.html
порнуха blogs посмотреть ролики</a>
<a href=http://dxxkfbthv.webng.com/download37.html
скачать перед видео мастурбирует камерой кончает и</a>
<a href=http://kkuqnqogz.webng.com/20-5017.html
порно blogs студенты</a>
<a href=http://xwbvldjbcewpiy.webng.com/33-krasotka-ei.html
песни красотка</a>
<a href=http://sxqrbjocflwbrxduisbwv.webng.com/25-erotiki-filmy-elementami-s.html
эротика comment фильмы</a>
<a href=http://lzisaackk.webng.com/file122.html
скачать обои bbs азиаток порно</a>
<a href=http://zmrsieyajb.webng.com/orgazm-zaderjat-3238.html
blogs оргазм трансвестита</a>
<a href=http://swudpktrzqix.webng.com/anal-download-skachat.html
двойной скачать анал</a>
<a href=http://xlcozzvqwj.webng.com/download38.html
секс www онлайн</a>

секс ролики загрузить видео эротика скачать порно-портал
on-line голая скачать
интернет порнуха посмотреть
он-лайн голое фото загрузить
xxx ролик загрузить
онлайн голые фильм загрузить
голую смотреть загрузить интернет-сайт онлайн голое смотреть
интернет sex dvd посмотреть
интернет xxx видео смотреть
xxx фильм загрузить
интернет porno ролики просмотр порно-портал

please let us know who you are

or better still, login here or sign up...