Setting Up a Text Embedding Provider

7.4 U70+ Beta Feature

A text embedding provider has two jobs:

  1. At index time, use the specified model to create a text embedding representation of a text sample extracted from the index document’s fields.
  2. At search time, use the specified model to create a text embedding representation of the search phrase typed into the search bar.

The model you use is paramount: your vectorized data is only as good as the model you choose.

The model you choose also performs the similarity search of the search phrase’s text embedding and the document’s text embedding. Models are housed in Hugging Face for the Hugging Face embedding services and txtai. OpenAI also has pre-trained models you can choose from if you’re using OpenAI as the embedding provider.

Text Embedding ProviderSuitable for Production?
Hugging Face Inference API
Hugging Face Inference Endpoints
Liferay DXP 2024.Q4+/Portal 7.4 GA129+
OpenAI
txtai

Configure and Run txtai

Note

The txtai configuration here is intended for demonstration. Please read the txtai documentation to learn more.

Set up txtai to access its APIs. To run txtai in a docker container, see the txtai documentation or follow these basic steps for Linux:

  1. Create a txtai folder and cd into it.

  2. From the txtai folder, download the Dockerfile with

    curl https://raw.githubusercontent.com/neuml/txtai/master/docker/api/Dockerfile -O
    
  3. Create a config.yml file in the txtai folder and give it these minimal contents:

    path: /tmp/index
    
    writable: False
    
    embeddings:
         path: sentence-transformers/msmarco-distilbert-base-dot-prod-v3
    
    Important

    The model you chose is entered in the embeddings path.

  4. From the txtai folder, run

    docker build -t txtai-api .
    
  5. Start the container:

    docker run -p 8000:8000 --rm -it txtai-api
    

    Depending on the size of the models, it can take several minutes for the service to initialize.

  6. In Liferay, open the Global Menu (Global Menu) → Control PanelInstance Settings. In the Search category, click Semantic Search.

    • Set Text Embeddings Enabled to true.
    • Select txtai as the text embedding provider.
    • Enter the ip:port as the Host Address. If following the test setup and running a local Liferay instance, use localhost:8000.
    • If you followed the above test setup, leave the default values in Basic Auth Username and Basic Auth Password.
    • Leave the default value (768) in Embedding Vector Dimensions.
    Important

    The Embedding Vector Dimensions must match that of the configured model. The model is specified in txtai using the config.yml file. See the model’s documentation to configure the proper number of dimensions.

Before saving the configuration, click Test Configuration to ensure that Liferay can connect with the txtai server and that the settings are correct.

This example setup is intended for demonstration. See the txtai documentation to find the setup that meets your need (e.g., running a GPU container for increased performance).

Using the Hugging Face Inference API

Important

The Hugging Face Inference API is suitable for testing and development. To use Hugging Face as the text embedding provider for production, use the Hugging Face Inference Endpoints provider.

To use the Hugging Face Inference API, first create a Hugging Face account.

Once you have an account,

  1. Go to your Hugging Face account settings and copy your access token.

  2. In Liferay, open the Global Menu (Global Menu) → Control PanelInstance Settings. In the Search category, click Semantic Search.

    Select Hugging Face Inference API as the text embedding provider and enter the access token you copied.

  3. Choose one of the models from the list at https://huggingface.co/models?pipeline_tag=feature-extraction.

  4. Enter the model name as the title of the model.

  5. Enter the proper number of Embedding Vector Dimensions to match the model you chose.

    Important

    The Embedding Vector Dimensions must match that of the configured model.

  6. Configure the other Hugging Face settings as desired:

    Model Timeout: Set the time (in seconds) to wait for the model to be loaded before timing out. You can pin Hugging Face models in memory to avoid repeated time-consuming loading of models.

Before saving the configuration, click the Test Configuration button to ensure that Liferay can connect with the Hugging Face Inference API and that the settings are correct.

Using the Hugging Face Inference Endpoints

The Hugging Face Inference Endpoints service is an enterprise-grade, paid text embedding service from Hugging Face. When testing and developing your semantic search solution, you can use the Inference API.

Most of the setup is completed in Hugging Face. After setting up the Inference API,

  1. Go to your Hugging Face account settings and copy your access token.

  2. In Liferay, open the Global Menu (Global Menu) → Control PanelInstance Settings. In the Search category, click Semantic Search.

    Select Hugging Face Inference Endpoints as the text embedding provider and enter the access token you copied.

  3. Enter the host address.

  4. Enter the proper number of Embedding Vector Dimensions to match the model you chose.

    Important

    The Embedding Vector Dimensions must match that of the configured model.

Before saving the configuration, click the Test Configuration button to ensure that Liferay can connect with the Hugging Face Inference Endpoint and that the settings are correct.

Using OpenAI

Liferay DXP 2024.Q4+/Portal 7.4 GA129+

You can configure OpenAI as a text embedding provider for Semantic Search. Its embedding models can be used with Semantic Search once you have an API key.

After configuring OpenAI and retrieving the API key,

  1. In Liferay, open the Global Menu (Global Menu) → Control PanelInstance Settings. In the Search category, click Semantic Search.

  2. Select OpenAI as the text embedding provider.

  3. The fields required for OpenAI appear. Fill out the configuration form.

API Key: Get this from OpenAI.

Dimensions: the number of dimensions of the resulting output. The chosen model defines whether you need this and the acceptable values. This is a request-time instruction to OpenAI to reduce dimensionality of the model’s output. If you pass this property to a model not supporting it, a warning appears: This model does not support specifying dimensions. Refer to the OpenAI model to know what dimensions to set.

Model: Choose a model from OpenAI.

User: Enter a unique user identifier so that OpenAI can monitor requests for abuse. See OpenAI’s documentation for information.

Enter the proper number of Embedding Vector Dimensions to match the model you chose.

Embedding Vector Dimensions

Embedding vector dimensions are model-specific settings. See the embedding model’s documentation for valid dimensions. Choose a model with dimensions that work with your search engine:

Search EngineMaximum Dimensions
Elasticsearch 8.10 and lower2048
Elasticsearch 8.11 and higher4096
OpenSearch 2.12 and higher4096

Capabilities

Product

Education

Contact Us

Connect

Powered by Liferay
© 2024 Liferay Inc. All Rights Reserved • Privacy Policy