Skip to content

Commit

Permalink
feat(knn_config): support knn config in 2.x indices (#118)
Browse files Browse the repository at this point in the history
Signed-off-by: Michael Carroll <[email protected]>
  • Loading branch information
mcarroll1 authored Nov 15, 2023
1 parent 7128bed commit 3a47818
Show file tree
Hide file tree
Showing 4 changed files with 78 additions and 1 deletion.
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,7 @@ Examples of resources can be found in the examples directory.
./script/install-tools
export OSS_IMAGE="opensearchproject/opensearch:2"
docker-compose up -d
docker-compose ps -a
docker-compose ps -a # Checks that the process is running
export OPENSEARCH_URL=http://admin:admin@localhost:9200
export TF_LOG=INFO
TF_ACC=1 go test ./... -v -parallel 20 -cover -short
Expand Down
2 changes: 2 additions & 0 deletions docs/resources/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -63,6 +63,8 @@ EOF
- `gc_deletes` (String) The length of time that a deleted document's version number remains available for further versioned operations.
- `highlight_max_analyzed_offset` (String) The maximum number of characters that will be analyzed for a highlight request. A stringified number.
- `include_type_name` (String) A string that indicates if and what we should pass to include_type_name parameter. Set to `"false"` when trying to create an index on a v6 cluster without a doc type or set to `"true"` when trying to create an index on a v7 cluster with a doc type. Since mapping updates are not currently supported, this applies only on index create.
- `index_knn` (Boolean) Indicates whether the index should build native library indices for the knn_vector fields. If set to false, the knn_vector fields will be stored in doc values, but Approximate k-NN search functionality will be disabled.
- `index_knn_algo_param_ef_search` (String) The size of the dynamic list used during k-NN searches. Higher values lead to more accurate but slower searches. Only available for `nmslib` implementation.
- `index_similarity_default` (String) A JSON string describing the default index similarity config.
- `indexing_slowlog_level` (String) Set which logging level to use for the search slow log, can be: `warn`, `info`, `debug`, `trace`
- `indexing_slowlog_source` (String) Set the number of characters of the `_source` to include in the slowlog lines, `false` or `0` will skip logging the source entirely and setting it to `true` will log the entire source regardless of size. The original `_source` is reformatted by default to make sure that it fits on a single log line.
Expand Down
23 changes: 23 additions & 0 deletions provider/resource_opensearch_index.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ import (
"encoding/json"
"fmt"
"log"
"strconv"
"strings"

"github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema"
Expand All @@ -23,6 +24,7 @@ var (
"shard.check_on_startup",
"sort.field",
"sort.order",
"index.knn",
"index.similarity.default",
}
dynamicsSettingsKeys = []string{
Expand Down Expand Up @@ -66,6 +68,7 @@ var (
"indexing.slowlog.threshold.index.trace",
"indexing.slowlog.level",
"indexing.slowlog.source",
"index.knn.algo_param.ef_search",
}
settingsKeys = append(staticSettingsKeys, dynamicsSettingsKeys...)
)
Expand Down Expand Up @@ -140,6 +143,12 @@ var (
ForceNew: true,
Optional: true,
},
"index_knn": {
Type: schema.TypeBool,
Description: "Indicates whether the index should build native library indices for the knn_vector fields. If set to false, the knn_vector fields will be stored in doc values, but Approximate k-NN search functionality will be disabled.",
Optional: true,
ForceNew: true,
},
"index_similarity_default": {
Type: schema.TypeString,
Description: "A JSON string describing the default index similarity config.",
Expand Down Expand Up @@ -349,6 +358,11 @@ var (
Description: "Set the number of characters of the `_source` to include in the slowlog lines, `false` or `0` will skip logging the source entirely and setting it to `true` will log the entire source regardless of size. The original `_source` is reformatted by default to make sure that it fits on a single log line.",
Optional: true,
},
"index_knn_algo_param_ef_search": {
Type: schema.TypeString,
Description: "The size of the dynamic list used during k-NN searches. Higher values lead to more accurate but slower searches. Only available for nmslib.",
Optional: true,
},
// Other attributes
"mappings": {
Type: schema.TypeString,
Expand Down Expand Up @@ -573,6 +587,15 @@ func indexResourceDataFromSettings(settings map[string]interface{}, d *schema.Re
}

schemaName := strings.Replace(key, ".", "_", -1)

if configSchema[schemaName].Type == schema.TypeBool {
str := value.(string)
parsed, err := strconv.ParseBool(str)
if err == nil {
value = parsed
}
}

err := d.Set(schemaName, value)
if err != nil {
log.Printf("[ERROR] indexResourceDataFromSettings: %+v", err)
Expand Down
52 changes: 52 additions & 0 deletions provider/resource_opensearch_index_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -161,6 +161,26 @@ resource "opensearch_index" "test_similarity_config" {
})
}
`

testAccOpensearchIndexWithKNNConfig = `
resource "opensearch_index" "test_knn_config" {
name = "terraform-test-update-knn-module"
number_of_shards = 1
number_of_replicas = 1
index_knn = true
}
`

testAccOpensearchIndexWithKNNAlgoParamEfSearchConfig = `
resource "opensearch_index" "test_knn_algo_param_ef_search_config" {
name = "terraform-test-update-knn-algo-param-ef-search-module"
number_of_shards = 1
number_of_replicas = 1
index_knn = true
index_knn_algo_param_ef_search = 600
}
`

testAccOpensearchIndexRolloverAliasOpendistro = `
resource opensearch_ism_policy "test" {
policy_id = "test"
Expand Down Expand Up @@ -463,6 +483,38 @@ func TestAccOpensearchIndex_similarityConfig(t *testing.T) {
})
}

func TestAccOpensearchIndex_knnConfig(t *testing.T) {
resource.Test(t, resource.TestCase{
PreCheck: func() { testAccPreCheck(t) },
Providers: testAccProviders,
CheckDestroy: checkOpensearchIndexDestroy,
Steps: []resource.TestStep{
{
Config: testAccOpensearchIndexWithKNNConfig,
Check: resource.ComposeTestCheckFunc(
checkOpensearchIndexExists("opensearch_index.test_knn_config"),
),
},
},
})
}

func TestAccOpensearchIndex_knnAlgoParamEFSearchConfig(t *testing.T) {
resource.Test(t, resource.TestCase{
PreCheck: func() { testAccPreCheck(t) },
Providers: testAccProviders,
CheckDestroy: checkOpensearchIndexDestroy,
Steps: []resource.TestStep{
{
Config: testAccOpensearchIndexWithKNNAlgoParamEfSearchConfig,
Check: resource.ComposeTestCheckFunc(
checkOpensearchIndexExists("opensearch_index.test_knn_algo_param_ef_search_config"),
),
},
},
})
}

func TestAccOpensearchIndex_doctype(t *testing.T) {
provider := Provider()
diags := provider.Configure(context.Background(), &terraform.ResourceConfig{})
Expand Down

0 comments on commit 3a47818

Please sign in to comment.