Documentation ¶
Overview ¶
Package riot is riot engine
Package riot full text search engine
Index ¶
- Constants
- func GetVersion() string
- func Try(fun func(), handler func(interface{}))
- type Engine
- func (engine *Engine) CheckMem()
- func (engine *Engine) Close()
- func (engine *Engine) FlushIndex()
- func (engine *Engine) ForSplitData(splData []string, num int) (Map, int)
- func (engine *Engine) GetAllDocIds() []uint64
- func (engine *Engine) GetAllIds() []uint64
- func (engine *Engine) IndexDoc(docId uint64, data types.DocIndexData, forceUpdate ...bool)
- func (engine *Engine) Indexer(options types.EngineOpts)
- func (engine *Engine) Init(options types.EngineOpts)
- func (engine *Engine) InitStorage()
- func (engine *Engine) NumDocsIndexed() uint64
- func (engine *Engine) NumDocsRemoved() uint64
- func (engine *Engine) NumTokenIndexAdded() uint64
- func (engine *Engine) PinYin(hans string) []string
- func (engine *Engine) Rank(request types.SearchReq, RankOpts types.RankOpts, tokens []string, ...) (output types.SearchResp)
- func (engine *Engine) Ranker(options types.EngineOpts)
- func (engine *Engine) Ranks(request types.SearchReq, RankOpts types.RankOpts, tokens []string, ...) (output types.SearchResp)
- func (engine *Engine) RemoveDoc(docId uint64, forceUpdate ...bool)
- func (engine *Engine) Search(request types.SearchReq) (output types.SearchResp)
- func (engine *Engine) Segment(content string) (keywords []string)
- func (engine *Engine) Storage()
- func (engine *Engine) Tokens(request types.SearchReq) (tokens []string)
- type Map
- type StopTokens
Constants ¶
const ( // NumNanosecondsInAMillisecond nano-seconds in a milli-second num NumNanosecondsInAMillisecond = 1000000 // StorageFilePrefix persistent storage file prefix StorageFilePrefix = "riot" )
Variables ¶
This section is empty.
Functions ¶
Types ¶
type Engine ¶
type Engine struct {
// contains filtered or unexported fields
}
Engine initialize the engine
func (*Engine) CheckMem ¶
func (engine *Engine) CheckMem()
CheckMem check the memory when the memory is larger than 99.99% using the storage
func (*Engine) FlushIndex ¶
func (engine *Engine) FlushIndex()
FlushIndex block wait until all indexes are added 阻塞等待直到所有索引添加完毕
func (*Engine) ForSplitData ¶
ForSplitData for split seg data, segspl
func (*Engine) GetAllDocIds ¶
GetAllDocIds get all the DocId from the storage database and return 从数据库遍历所有的 DocId, 并返回
func (*Engine) GetAllIds ¶
GetAllIds get all the DocId from the storage database and return 从数据库遍历所有的 DocId, 并返回
func (*Engine) IndexDoc ¶
func (engine *Engine) IndexDoc(docId uint64, data types.DocIndexData, forceUpdate ...bool)
IndexDoc add the document to the index 将文档加入索引
输入参数:
docId 标识文档编号,必须唯一,docId == 0 表示非法文档(用于强制刷新索引),[1, +oo) 表示合法文档 data 见 DocIndexData 注释 forceUpdate 是否强制刷新 cache,如果设为 true,则尽快添加到索引,否则等待 cache 满之后一次全量添加
注意:
- 这个函数是线程安全的,请尽可能并发调用以提高索引速度
- 这个函数调用是非同步的,也就是说在函数返回时有可能文档还没有加入索引中,因此 如果立刻调用Search可能无法查询到这个文档。强制刷新索引请调用FlushIndex函数。
func (*Engine) Indexer ¶
func (engine *Engine) Indexer(options types.EngineOpts)
Indexer initialize the indexer channel
func (*Engine) Init ¶
func (engine *Engine) Init(options types.EngineOpts)
Init initialize the engine
func (*Engine) InitStorage ¶
func (engine *Engine) InitStorage()
InitStorage initialize the persistent storage channel
func (*Engine) NumDocsIndexed ¶
NumDocsIndexed documents indexed number
func (*Engine) NumDocsRemoved ¶
NumDocsRemoved documents removed number
func (*Engine) NumTokenIndexAdded ¶
NumTokenIndexAdded added token index number
func (*Engine) Rank ¶
func (engine *Engine) Rank(request types.SearchReq, RankOpts types.RankOpts, tokens []string, rankerReturnChan chan rankerReturnReq) (output types.SearchResp)
Rank rank docs by types.ScoredIDs
func (*Engine) Ranker ¶
func (engine *Engine) Ranker(options types.EngineOpts)
Ranker initialize the ranker channel
func (*Engine) Ranks ¶
func (engine *Engine) Ranks(request types.SearchReq, RankOpts types.RankOpts, tokens []string, rankerReturnChan chan rankerReturnReq) (output types.SearchResp)
Ranks rank docs by types.ScoredDocs
func (*Engine) RemoveDoc ¶
RemoveDoc remove the document from the index 将文档从索引中删除
输入参数:
docId 标识文档编号,必须唯一,docId == 0 表示非法文档(用于强制刷新索引),[1, +oo) 表示合法文档 forceUpdate 是否强制刷新 cache,如果设为 true,则尽快删除索引,否则等待 cache 满之后一次全量删除
注意:
- 这个函数是线程安全的,请尽可能并发调用以提高索引速度
- 这个函数调用是非同步的,也就是说在函数返回时有可能文档还没有加入索引中,因此 如果立刻调用 Search 可能无法查询到这个文档。强制刷新索引请调用 FlushIndex 函数。
func (*Engine) Search ¶
func (engine *Engine) Search(request types.SearchReq) (output types.SearchResp)
Search find the document that satisfies the search criteria. This function is thread safe 查找满足搜索条件的文档,此函数线程安全
type StopTokens ¶
type StopTokens struct {
// contains filtered or unexported fields
}
StopTokens stop tokens map
func (*StopTokens) Init ¶
func (st *StopTokens) Init(stopTokenFile string)
Init 从 stopTokenFile 中读入停用词,一个词一行 文档索引建立时会跳过这些停用词
func (*StopTokens) IsStopToken ¶
func (st *StopTokens) IsStopToken(token string) bool
IsStopToken to determine whether to stop token
Source Files ¶
Directories ¶
Path | Synopsis |
---|---|
Package core is riot core
|
Package core is riot core |
Package engine is riot engine
|
Package engine is riot engine |
examples
|
|
benchmark
riot 性能测试
|
riot 性能测试 |
codelab
一个微博搜索的例子。
|
一个微博搜索的例子。 |
pinyin_weibo
一个微博 pinyin 搜索的例子。
|
一个微博 pinyin 搜索的例子。 |
Package net is riot net
|
Package net is riot net |
grpc/riot-pb
Package doc is a generated protocol buffer package.
|
Package doc is a generated protocol buffer package. |
Package types is riot types
|
Package types is riot types |