」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 如何將美麗搜尋與 WikiJS 結合使用

如何將美麗搜尋與 WikiJS 結合使用

發佈於2024-09-02
瀏覽:519

How to use Meilisearch with WikiJS

總長DR

醬:https://github.com/mbround18/wikijs-module-meilisearch

軟體

什麼是美麗搜索

Meilisearch 是一個為速度和簡單性而建立的開源搜尋引擎。它用 Rust 編寫,旨在以最少的配置提供快速、相關的搜尋結果。 Meilisearch 擅長全文搜索,並且針對效能進行了最佳化,即使對於大型資料集也是如此。它支援開箱即用的功能,例如拼字錯誤容忍和可自訂的相關性排名。

美麗搜尋連結

什麼是 WikiJS

Wiki.js 是一款現代化的開源 wiki 軟體,為管理和分享內容提供了強大且靈活的平台。它基於 Node.js 構建,設計輕量、快速且易於使用,具有時尚直覺的介面,適合所有技能水平的用戶使用。

連結至 Wikijs

如何整合兩者

先決條件

  • 美麗搜尋運行實例
  • 運行 wikijs 實例

如果你沒有這些,你可以使用這個docker compose。

使用 docker 撰寫

  1. 將 docker compose 下載到目錄中。
  2. 建立一個名為pkg的資料夾
  3. 建立一個名為 tmp 的資料夾
  4. 建立一個名為config的資料夾。
  5. 在設定資料夾中,對於此演示,下載此配置
  6. 運行 docker compose up 以使其根據需要產生檔案。

安裝模組

  1. 導航到 github.com/mbround18/wikijs-module-meilisearch 上整合它們的模組
  2. 導覽至發布標籤
  3. 在最新版本上下載Meilisearch.zip 檔案。
  4. 將 zip 解壓縮到 wikijs 伺服器上的 /wiki/server/modules/search/meilisearch。如果您使用 compose,請 docker compose down 並將 zip 檔案解壓縮到您的 ./pkg 資料夾中。
  5. 重新啟動您的 wikijs 伺服器。

設定模組。

建議在生產實例中,讓 meilisearch 產生一個新密鑰供您的應用程式使用。您可以透過以下curl命令來執行此操作:

curl --request POST \
  --url http://localhost:7700/keys \
  --header 'Authorization: Bearer demo' \
  --header 'Content-Type: application/json' \
  --data '{
    "description": "Wikijs Integration",
    "actions": ["*"],
    "indexes": ["wiki_index"],
    "expiresAt": "2042-04-02T00:42:42Z"
}'

將“demo”一詞更改為您的主密鑰。如果您正在使用 docker compose,那麼這將僅適用於演示。除非您在撰寫文件中更改了它。然後使用您為 $MEILI_MASTER_KEY 設定的內容。

  1. 登入您的 wikijs 實例,對於撰寫演示,您可能必須建立初始登入。只要記住在初始設定畫面上將 url 設定為 http://localhost:3000。
  2. 導航至管理儀表板。
  3. 點選搜尋引擎
  4. 啟用美麗搜尋
  5. 根據需要調整 API 金鑰和主機。
  6. 點擊“應用”,如果沒有收到綠色提示訊息,只需再次點擊“應用”即可。發生這種情況的原因是創建索引時 Meil​​​​isearch 中的任務停滯。

現在它的設定是什麼?

現在您可以開始使用美麗搜尋來搜尋您的維基了!如果您有現有內容,您可以點擊“重建”,它會將您的所有內容新增至 meilisearch! :)

當您正常使用 wikijs 時,它會在 Meil​​search 中建立、更新和刪除文檔,作為正常頁面渲染的一部分。

如果您想查看這方面的即時範例,在我的《龍與地下城》維基上,我們已經整合了此功能。觸手可及的角色數據或場景數據的瞬間回憶起來真是太神奇了。

關於實施的注意事項,目前建議與 who 行相符。將來,我會重寫該段落以截斷並提供更小的建議。

版本聲明 本文轉載於:https://dev.to/mbround18/how-to-use-meilisearch-with-wikijs-5g3b?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 在 React 中建立無限滾動元件
    在 React 中建立無限滾動元件
    介绍 我们在应用程序和网页中看到无限滚动,尤其是希望我们滚动的社交媒体。虽然无意识地滚动不好,但构建自己的无限滚动是很棒的。作为开发人员,我们应该尝试重新创建我们在网上冲浪时看到的组件。它可以挑战您在实现某些组件时了解更多信息并跳出框框进行思考。 此外,如果您希望在应用程序中实现无...
    程式設計 發佈於2024-11-06
  • 在 React 中建立響應式會議圖塊的動態網格系統
    在 React 中建立響應式會議圖塊的動態網格系統
    In the era of remote work and virtual meetings, creating a responsive and dynamic grid system for displaying participant video tiles is crucial. Inspi...
    程式設計 發佈於2024-11-06
  • 使用 Spring Boot 和 Spring Cloud 開發微服務
    使用 Spring Boot 和 Spring Cloud 開發微服務
    微服務架構已成為建構可擴展和模組化系統的流行解決方案。透過微服務,您可以將單一應用程式分解為更小的、獨立的和專業的服務,這使得系統的維護和發展變得更加容易。在這篇文章中,我們將探討如何使用 Spring Boot 和 Spring Cloud 來創造健壯且有效率的微服務。 微服務簡介 微服務背後的...
    程式設計 發佈於2024-11-06
  • 克服 PHP DOM XML 解析中的挑戰:問題與解決方案
    克服 PHP DOM XML 解析中的挑戰:問題與解決方案
    簡化PHP DOM XML 解析:揭開要點當您瀏覽PHP DOM 函數的複雜性時,可能會出現某些障礙。為了解決這些挑戰,讓我們開始了解 DOM 的複雜性,並找出常見問題的解決方案。 問題1:使用xml:id 馴服ID當使用ID 來防止樹中出現重複頁面時,PHP 的DOM 遇到了一個難題:getEle...
    程式設計 發佈於2024-11-06
  • 密碼重設功能:使用 OTP 重設密碼
    密碼重設功能:使用 OTP 重設密碼
    後端 2. 重設密碼 轉向下一個 API。 PUT 上 /api/reset-password, req -> otp, email, 新密碼, res -> nocontent // controllers/passwordReset.go func Reset...
    程式設計 發佈於2024-11-06
  • 如何從全域站點套件繼承 Virtualenv 中的特定套件?
    如何從全域站點套件繼承 Virtualenv 中的特定套件?
    從全域網站套件繼承Virtualenv 中的特定套件為了增強虛擬環境(virtualenv) 的功能,您可能會想要從全域網站繼承特定套件網站套件目錄。這種方法允許您選擇性地將重要的程式庫合併到您的 virtualenv 中,而無需直接安裝它們。 繼承方法要實現這種繼承,請使用以下命令建立新的virt...
    程式設計 發佈於2024-11-06
  • 如何解決 EF6 中的“找不到 'MySql.Data.MySqlClient\'\”錯誤?
    如何解決 EF6 中的“找不到 'MySql.Data.MySqlClient\'\”錯誤?
    MySQL 實體框架的提供者註冊使用MySQL 和實體框架時,您可能會遇到錯誤「找不到Entity Framework提供者” 'MySql.Data.MySqlClient' ADO.NET 提供者。 「儘管安裝了最新的MySQL 連接器,您可能仍然會遇到此問題。出現此問題的原因是...
    程式設計 發佈於2024-11-06
  • 如何利用PHP防止郵件傳輸中的惡意輸入?
    如何利用PHP防止郵件傳輸中的惡意輸入?
    保護電子郵件傳輸的使用者輸入在PHP 中,必須在發送電子郵件之前清理使用者輸入,以防止惡意或有害內容外洩你的系統。考慮下面的簡單 PHP 郵件腳本的程式碼片段:<?php $to = "[email protected]"; $name = $_POST['name']; ...
    程式設計 發佈於2024-11-06
  • 應用程式頁面開發
    應用程式頁面開發
    Если посмотреть на исходный проект, то можно увидеть, что нам необходимо создать одну главную страницу. Результаты поиска авиабилетов, отелей и туров ...
    程式設計 發佈於2024-11-06
  • Java 應用程式中的「No X11 DISPLAY Variable」錯誤:如何為 GUI 功能設定 DISPLAY 變數?
    Java 應用程式中的「No X11 DISPLAY Variable」錯誤:如何為 GUI 功能設定 DISPLAY 變數?
    Java 應用程式中的「No X11 DISPLAY Variable」錯誤Java 應用程式依賴X Window 系統(X11) 來實作圖形使用者介面( GUI)功能。 「未設定 X11 DISPLAY 變數」錯誤表示應用程式無法存取 X11 顯示環境。 要解決此問題,請設定 X11 DISPLA...
    程式設計 發佈於2024-11-06
  • 破解 HashMap 的基礎知識:Java 開發人員的關鍵概念
    破解 HashMap 的基礎知識:Java 開發人員的關鍵概念
    介紹 了解 HashMap 類對於開發人員至關重要,無論是在實際應用程式還是面試中。在這篇文章中,我們將探討如何在 HashMap 中插入、更新和管理鍵值對。這些知識也將為我們的下一篇文章奠定基礎,我們將深入研究 HashSet 並了解這兩個集合之間的關係。 什麼...
    程式設計 發佈於2024-11-06
  • 如何在 .htaccess 中啟用 PHP 錯誤顯示和日誌記錄?
    如何在 .htaccess 中啟用 PHP 錯誤顯示和日誌記錄?
    透過 .htaccess 解決 PHP 錯誤顯示問題測試網站並遇到問題時,錯誤顯示至關重要。但是,此顯示有時可能會被停用。對於僅有權存取 .htaccess 檔案並希望啟用錯誤顯示的用戶,此問題提供了全面的解決方案。 此問題解決了 .htaccess 檔案是唯一可存取資源的情況。它建議添加三個 PH...
    程式設計 發佈於2024-11-06
  • 精選的最佳 React 管理儀表板模板
    精選的最佳 React 管理儀表板模板
    Hi there ?. I'm Syakir, a Front-end engineer. In this page, i curated premium react admin templates from various vendors with top features and design ...
    程式設計 發佈於2024-11-06
  • Gosync.Pool 及其背後的機制
    Gosync.Pool 及其背後的機制
    这是帖子的摘录;完整的帖子可以在这里找到:https://victoriametrics.com/blog/go-sync-pool/ 这篇文章是关于 Go 中处理并发的系列文章的一部分: Gosync.Mutex:正常和饥饿模式 Gosync.WaitGroup 和对齐问题 Gosync.Poo...
    程式設計 發佈於2024-11-06
  • 如何在 PHP 中包含 CSS:詳細指南
    如何在 PHP 中包含 CSS:詳細指南
    在PHP 中包含CSS 檔案:綜合指南在進行Web 開發時,將CSS 樣式合併至PHP 程式碼中對於管理至關重要您的頁面的呈現。然而,眾所周知,使用 HTML 程式碼包含 CSS 檔案是標準方法。在本文中,我們將深入研究基於 PHP 的解決方案,幫助您了解如何將 CSS 檔案直接匯入 PHP 程式碼...
    程式設計 發佈於2024-11-06

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3