終于有 Go 版的 Elasticsearch 了
本文轉載自微信公眾號「polarisxu」,作者站長polaris 。轉載本文請聯系polarisxu公眾號。
大家好,我是 polarisxu。
企業內部搭建搜索引擎常用 Solr、Elasticsearch,它們都是使用 Java 實現的,底層依賴 Lucene,Java 相對來說占用較多內存。而今天要介紹的這個項目,目標就是作為 ES 的替代者,一個輕量級搜索引擎:Zinc。
項目地址:https://github.com/prabhatsharma/zinc,該項目開源十來天,目前 Star 數 3.4k+。
Zinc 是一個全文索引的搜索引擎。它是 Elasticsearch 的輕量級替代品,可以在不到 100 MB 的 RAM 中運行。它使用 bluge 作為底層索引庫。
而且,Zinc 使用 Vue 打造了一個比 Elasticsearch 更簡單、更易于操作的界面。
zinc
如果你只是使用 API 獲取數據并使用 kibana 進行搜索(Kibana 不支持 Zinc。Zinc 提供了自己的 UI),那么它是 Elasticsearch 的直接替代品。
Zinc 主要有如下特性:
- 提供全文索引功能
- 單個二進制文件即可安裝、運行,支持多平臺。這得益于 Go 語言
- 用 Vue 編寫的用于查詢數據的 Web UI
- 與 Elasticsearch 兼容的數據獲取 API(單記錄和批量 API)
- 開箱即用的身份驗證
- Schema less - 無需預先定義 schema,同一索引中的不同文檔可以有不同的字段
不過,目前 Zinc 還處于 alpha 階段,而且缺少集群,可用性也沒得到很好的驗證。
關于如何安裝使用,項目首頁有說明,支持普通安裝(可以直接下載編譯好的二進制文件),也支持 Docker 和 K8S 安裝使用。
我根據說明,在本地搭建后,根據提供的示例數據構建索引:
- $ FIRST_ADMIN_USER=admin FIRST_ADMIN_PASSWORD=Complexpass#123 ./zinc
- {"level":"debug","time":"2021-12-12T22:53:51+08:00","message":"Loading indexes..."}
- {"level":"debug","time":"2021-12-12T22:53:51+08:00","message":"Loading system indexes..."}
- {"level":"debug","time":"2021-12-12T22:53:51+08:00","message":"Index loaded: _users"}
- {"level":"debug","time":"2021-12-12T22:53:51+08:00","message":"Index loaded: _index_mapping"}
- {"level":"debug","time":"2021-12-12T22:53:51+08:00","message":"Error loading .env file"}
- [GIN-debug] [WARNING] Running in "debug" mode. Switch to "release" mode in production.
- - using env: export GIN_MODE=release
- - using code: gin.SetMode(gin.ReleaseMode)
- [GIN-debug] GET /healthz --> github.com/prabhatsharma/zinc/pkg/meta/v1.GetHealthz (3 handlers)
- [GIN-debug] GET / --> github.com/prabhatsharma/zinc/pkg/meta/v1.GUI (3 handlers)
- [GIN-debug] GET /ui/*filepath --> github.com/gin-gonic/gin.(*RouterGroup).createStaticHandler.func1 (3 handlers)
- [GIN-debug] HEAD /ui/*filepath --> github.com/gin-gonic/gin.(*RouterGroup).createStaticHandler.func1 (3 handlers)
- [GIN-debug] POST /api/login --> github.com/prabhatsharma/zinc/pkg/handlers.ValidateCredentials (3 handlers)
- [GIN-debug] PUT /api/user --> github.com/prabhatsharma/zinc/pkg/handlers.CreateUpdateUser (4 handlers)
- [GIN-debug] DELETE /api/user/:userID --> github.com/prabhatsharma/zinc/pkg/handlers.DeleteUser (4 handlers)
- [GIN-debug] GET /api/users --> github.com/prabhatsharma/zinc/pkg/handlers.GetUsers (4 handlers)
- [GIN-debug] PUT /api/index --> github.com/prabhatsharma/zinc/pkg/handlers.CreateIndex (4 handlers)
- [GIN-debug] GET /api/index --> github.com/prabhatsharma/zinc/pkg/handlers.ListIndexes (4 handlers)
- [GIN-debug] PUT /api/:target/document --> github.com/prabhatsharma/zinc/pkg/handlers.UpdateDocument (4 handlers)
- [GIN-debug] POST /api/:target/_search --> github.com/prabhatsharma/zinc/pkg/handlers.SearchIndex (4 handlers)
- [GIN-debug] PUT /es/:target/_doc/:id --> github.com/prabhatsharma/zinc/pkg/handlers.UpdateDocument (4 handlers)
- [GIN-debug] DELETE /es/:target/_doc/:id --> github.com/prabhatsharma/zinc/pkg/handlers.DeleteDocument (4 handlers)
- [GIN-debug] POST /es/:target/_doc --> github.com/prabhatsharma/zinc/pkg/handlers.UpdateDocument (4 handlers)
- [GIN-debug] PUT /es/:target/_create/:id --> github.com/prabhatsharma/zinc/pkg/handlers.UpdateDocument (4 handlers)
- [GIN-debug] POST /es/:target/_create/:id --> github.com/prabhatsharma/zinc/pkg/handlers.UpdateDocument (4 handlers)
- [GIN-debug] POST /es/:target/_update/:id --> github.com/prabhatsharma/zinc/pkg/handlers.UpdateDocument (4 handlers)
- [GIN-debug] POST /es/_bulk --> github.com/prabhatsharma/zinc/pkg/handlers.BulkHandler (4 handlers)
- [GIN-debug] POST /es/:target/_bulk --> github.com/prabhatsharma/zinc/pkg/handlers.BulkHandler (4 handlers)
- [GIN-debug] Listening and serving HTTP on :4080
訪問 https://localhost:4080 即可看到上面的界面。
目前 Go 語言中文網的搜索使用的是 Solr,抽空嘗試驗證 Zinc,如果穩定、成熟,考慮遷移到 Zinc。