操做系統:ubuntu 14.04 64位
數據庫:mysql
安裝環境:
sudo apt-get install gcc g++ automake libtool mysql-client libmysqlclient-dev libxml2-dev libexpat1-dev mysql-server-5.6html
安裝升級autoconfmysql
由於coreseek須要autoconf 2.65以上版本,因此須要升級autoconf,否則會報錯sql
./bootstrap: 25: ./bootstrap: autoheader: not found數據庫
tar -zxvf autoconf-2.69.tar.gz
cd autoconf-2.69
./configure
make
sudo make install
下載coreseekbootstrap
新版本的coreseek將詞典和sphinx源程序放在了一個包中,所以只須要下載coreseek包就能夠了,這裏我用的是coreseek 4.1版本ubuntu
wget http://www.coreseek.cn/uploads/csft/4.0/coreseek-4.1-beta.tar.gz
或者bash
wget http://files.opstool.com/man/coreseek-4.1-beta.tar.gz
安裝mmseg(coreseek所使用的詞典)
apt install automake網絡
cd mmseg-3.2.14
./bootstrap
./configure --prefix=/usr/local/mmseg3
make
sudo make install
cd ..app
遇到的問題:
error: cannot find input file: src/Makefile.in
或者遇到其餘相似error錯誤時...less
解決方案:
依次執行下面的命令,我運行'aclocal'時又出現了錯誤,解決方案請看下文描述
sudo apt install libtool
aclocal
libtoolize --force
automake --add-missing
autoconf
autoheader
make clean
安裝coreseek(sphinx)
ubuntu 16.04及以上版本須要打補丁,不然下面編譯的時候會沒有configure文件。補丁解決方案以下:
在 csft-4.1/buildconf.sh 文件中,查找
&& aclocal 後加上
&& automake --add-missing 在 csft-4.1/configure.ac 文件中,查找:
AM_INIT_AUTOMAKE([-Wall -Werror foreign])
改成:
AM_INIT_AUTOMAKE([-Wall foreign])
查找:
AC_PROG_RANLIB
後面加上
AM_PROG_AR
在 csft-4.1/src/sphinxexpr.cpp 文件中, 替換全部:
T val = ExprEval ( this->m_pArg, tMatch );
成爲:
T val = this->ExprEval ( this->m_pArg, tMatch );
安裝libmysqlclient15-dev,不然會報找不到mysql
sudo apt-get install libmysqlclient15-dev
安裝coreseek
cd csft-4.1
sh buildconf.sh #輸出的warning信息能夠忽略,若是出現error則須要解決
./configure --prefix=/usr/local/coreseek --without-unixodbc --with-mmseg --with-mmseg-includes=/usr/local/mmseg3/include/mmseg/ --with-mmseg-libs=/usr/local/mmseg3/lib/ --with-mysql
make
sudo make install
cd ..
測試mmseg分詞及coreseek搜索
cd testpack
cat var/test/test.xml #此時應該正確顯示中文
/usr/local/mmseg3/bin/mmseg -d /usr/local/mmseg3/etc var/test/test.xml
/usr/local/coreseek/bin/indexer -c etc/csft.conf --all
/usr/local/coreseek/bin/search -c etc/csft.conf 網絡搜索
此時正確的應該返回
words:
1.網絡: 1 documents, 1 hits
2.搜索: 2 documents, 5 hits
配置coreseek
建立配置文件 /usr/local/coreseek/etc/sphinx.conf,內容示例以下:
source app_source
{
type = mysql
sql_host = localhost # mysql的host
sql_user = user # mysql的帳號
sql_pass = password # mysql的密碼
sql_db = test # mysql的db
sql_port = 3306 # optional, default is 3306
sql_query_pre = SET NAMES utf8
sql_query_pre = SET SESSION query_cache_type=OFF
sql_query = SELECT id, text FROM words WHERE 1; # 須要搜索的數據表內容,此替換爲本身的sql語句
}
index app
{
source = app_source # 跟上面定義的app_source對應
path = /usr/local/coreseek/var/log/app_source
docinfo = extern
mlock = 0
morphology = none
exceptions = /usr/local/coreseek/var/log/exceptions.txt
min_word_len = 1
charset_type = zh_cn.utf-8
charset_dictpath= /usr/local/mmseg3/etc
html_strip = 0
}
indexer
{
mem_limit = 512M
}
searchd
{
listen = 9312
log = /usr/local/coreseek/var/log/searchd.log
query_log = /usr/local/coreseek/var/log/query.log
read_timeout = 5
client_timeout = 300
max_children = 30
pid_file = /usr/local/coreseek/var/log/searchd.pid
max_matches = 1000
seamless_rotate = 1
preopen_indexes = 0
unlink_old = 1
mva_updates_pool = 1M
max_packet_size = 8M
max_filters = 256
max_filter_values = 4096
}
啓動和管理coreseek
生成索引
sudo /usr/local/coreseek/bin/indexer --config /usr/local/coreseek/etc/sphinx.conf --all
從新生成索引
sudo /usr/local/coreseek/bin/indexer --config /usr/local/coreseek/etc/sphinx.conf --all --rotate
啓動守護進程,啓動後就不須要關閉
sudo /usr/local/coreseek/bin/searchd --config /usr/local/coreseek/etc/sphinx.conf
關閉守護進程
sudo /usr/local/coreseek/bin/searchd --stop
加入開機啓動
打開 /etc/rc.local ,添加啓動代碼
/usr/local/coreseek/bin/searchd --config /usr/local/coreseek/etc/sphinx.conf
定時更新索引
加入計劃任務,半小時重建一次索引。
crontab -e
加入下面這句代碼
/30 * * * /bin/bash /usr/local/coreseek/bin/indexer --config /usr/local/coreseek/etc/sphinx.conf --all --rotate