v0.25 版本的新特性
本月发布的版本对 API 密钥管理和异步任务进行了重大更改。
在本文中,我们将了解 v0.25 引入的一些主要和重大更改。您还可以阅读 GitHub 上的完整更改日志。
重大更改
API 密钥管理
从本版本开始,开发人员现在可以创建具有特定权限和过期日期的 API 密钥,从而精确控制哪些用户/应用程序可以访问哪些索引和端点。
作为此功能的一部分,private
和 public
密钥已弃用,并替换为两个具有类似权限的默认 API 密钥:Default Admin API Key
和 Default Search API Key
。
X-MEILI-API-KEY: <apiKey>
标头被 Authorization: Bearer <apiKey>
标头替换。
假设您正在创建医疗行业的应用程序。以下是如何创建仅有权访问 patient_medical_records
索引上的搜索端点的 API 密钥
curl -X POST 'https://127.0.0.1:7700/keys/' -H 'Content-Type: application/json' -H 'Authorization: Bearer [your_master_key]' --data-binary '{ "description": "Search patient records key", "actions": [ "search" ], "indexes": ["patient_medical_records"], "expiresAt": "2023-01-01T00:00:00Z" }'
响应:201 已创建
{ "description": "Search patient records key", "key": "d0552b41536279a0ad88bd595327b96f01176a60c2243e906c52ac02375f9bc4", "actions": [ "search" ], "indexes": [ "patient_medical_records" ], "expiresAt": "2023-01-01T00:00:00Z", "createdAt": "2022-01-01T10:00:00Z", "updatedAt": "2022-01-01T10:00:00Z" }
然后,用户可以提供此密钥以在 patient_medical_records
索引上进行搜索请求
curl -X POST 'https://127.0.0.1:7700/indexes/patient_medical_records/search' -H 'Content-Type: application/json' -H 'Authorization: Bearer d0552b41536279a0ad88bd595327b96f01176a60c2243e906c52ac02375f9bc4' --data-binary '{ "q": "trypophobia" }'
有关更多信息,请阅读我们关于保护 Meilisearch 实例的新指南。
异步操作
在 v0.25 中,我们从头开始重新设计了 Meilisearch 的异步操作,用新的 tasks
API 替换了 updates
API。
在相关的更改中,创建、更新和删除索引现在都是异步操作。此修复消除了发生竞争条件的可能性。
在 v0.25 之前,任何异步处理的请求(例如,添加文档)都会返回一个 updateId
以跟踪操作的状态
{ "updateId": 1 }
在 v0.25 之后,异步操作现在将返回 task 对象的摘要版本
{ "uid": 1, "indexUid": "patient_medical_records", "status": "enqueued", "type": "documentAddition", "enqueuedAt": "2021-08-10T14:29:17.000000Z", }
您可以使用 /tasks
路由获取完整的 task 对象以及操作的当前状态。
curl -X GET 'https://127.0.0.1:7700/tasks/1'
响应:200 确定
{ "uid": 1, "indexUid": "patient_medical_records", "status": "succeeded", "type": "documentAddition", "details": { "receivedDocuments": 1, "indexedDocuments": 1 }, "duration": "PT1S", "enqueuedAt": "2021-08-10T14:29:17.000000Z", "startedAt": "2021-08-10T14:29:18.000000Z", "finishedAt": "2021-08-10T14:29:19.000000Z" }
此处任务已成功。任务的其他可能状态包括 enqueued
、processing
或 failed
。
当任务失败时,Meilisearch 会返回一个 error
对象作为响应的一部分
{ "uid": 2, "indexUid": "patient_medical_records", "status": "failed", "type": "documentAddition", "details": { "receivedDocuments": 1, "indexedDocuments": 0 }, "error": { "message": "Document does not have a `:primaryKey` attribute: `:documentRepresentation`.", "code": "internal", "type": "missing_document_id", "link": "https://docs.meilisearch.com/errors#missing-document-id", }, "duration": "PT1S", "enqueuedAt": "2021-08-11T14:29:17.000000Z", "startedAt": "2021-08-11T14:29:18.000000Z", "finishedAt": "2021-08-11T14:29:19.000000Z" }
有关更多信息,请查看异步操作文章或tasks API 参考。
其他更改
- 跨版本兼容性:Meilisearch v0.25 及后续版本与 v0.22 之前创建的转储不兼容。
要将 pre-v0.22 的转储迁移到 v0.25 Meilisearch,首先将您的转储加载到 v0.24.0,使用 v0.24.0 创建一个转储,然后将此转储导入 v0.25.0。 - 我们添加了几个新的错误消息,其中大多数与管理 API 密钥有关。
matches
现在突出显示字符串和数值。- 我们添加了一些新的遥测指标。
贡献者
非常感谢我们所有的贡献者!没有你们的帮助,这个项目不可能走得很远。
感谢 @Mcdostone 和 @Thearas 对 Meilisearch 的帮助,以及感谢 @datamaker 和 @Samyak2 对我们的 Tokenizer 库的帮助。
如果您想了解我们此处未提及的更新的更多详细信息,请查看我们的发布更改日志。