Skip to content
This repository has been archived by the owner on Jun 6, 2024. It is now read-only.

Commit

Permalink
Merge branch 'main' of https://github.com/o19s/opensearch-ubi into do…
Browse files Browse the repository at this point in the history
…cumentation/query-examples
  • Loading branch information
RasonJ committed Mar 13, 2024
2 parents 2b7551b + 961fcb8 commit 32f8748
Show file tree
Hide file tree
Showing 39 changed files with 1,286 additions and 874 deletions.
24 changes: 24 additions & 0 deletions .github/ISSUE_TEMPLATE/BUG_TEMPLATE.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
---
name: Bug report
about: Create a report to help us improve
title: '[BUG]'
labels: 'bug, untriaged'
assignees: ''
---
### What is the bug?
_A clear and concise description of the bug._

### How can one reproduce the bug?
_Steps to reproduce the behavior._

### What is the expected behavior?
_A clear and concise description of what you expected to happen._

### What is your host/environment?
_Operating system, version._

### Do you have any screenshots?
_If applicable, add screenshots to help explain your problem._

### Do you have any additional context?
_Add any other context about the problem._
18 changes: 18 additions & 0 deletions .github/ISSUE_TEMPLATE/FEATURE_REQUEST_TEMPLATE.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
---
name: Feature request
about: Request a feature in this project
title: '[FEATURE]'
labels: 'enhancement, untriaged'
assignees: ''
---
### Is your feature request related to a problem?
_A clear and concise description of what the problem is, e.g. I'm always frustrated when [...]._

### What solution would you like?
_A clear and concise description of what you want to happen._

### What alternatives have you considered?
_A clear and concise description of any alternative solutions or features you've considered._

### Do you have any additional context?
_Add any other context or screenshots about the feature request here._
40 changes: 40 additions & 0 deletions .github/ISSUE_TEMPLATE/PROPOSAL_TEMPLATE.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
---
name: Proposal
about: Suggest an idea for a specific feature you wish to propose to the community for comment
title: '[PROPOSAL]'
labels: proposal
assignees: ''
---
## What/Why
### What are you proposing?
_In a few sentences, describe the feature and its core capabilities._

### What users have asked for this feature?
_Highlight any research, proposals, requests or anecdotes that signal this is the right thing to build. Include links to GitHub Issues, Forums, Stack Overflow, Twitter, Etc_

### What problems are you trying to solve?
_Summarize the core use cases and user problems and needs you are trying to solve. Describe the most important user needs, pain points and jobs as expressed by the user asks above. Template: When \<a situation arises> , a \<type of user> wants to \<do something>, so they can \<expected outcome>. (Example: When **searching by postal code**, **a buyer** wants to **be required to enter a valid code** so they **don’t waste time searching for a clearly invalid postal code.**)_

### What is the developer experience going to be?
_Does this have a REST API? If so, please describe the API and any impact it may have to existing APIs. In a brief summary (not a spec), highlight what new REST APIs or changes to REST APIs are planned. as well as any other API, CLI or Configuration changes that are planned as part of this feature._

#### Are there any security considerations?
_Describe if the feature has any security considerations or impact. What is the security model of the new APIs? Features should be integrated into the OpenSearch security suite and so if they are not, we should highlight the reasons here._

#### Are there any breaking changes to the API
_If this feature will require breaking changes to any APIs, ouline what those are and why they are needed. What is the path to minimizing impact? (example, add new API and deprecate the old one)_

### What is the user experience going to be?
_Describe the feature requirements and or user stories. You may include low-fidelity sketches, wireframes, APIs stubs, or other examples of how a user would use the feature via CLI, OpenSearch Dashboards, REST API, etc. Using a bulleted list or simple diagrams to outline features is okay. If this is net new functionality, call this out as well._

#### Are there breaking changes to the User Experience?
_Will this change the existing user experience? Will this be a breaking change from a user flow or user experience perspective?_

### Why should it be built? Any reason not to?
_Describe the value that this feature will bring to the OpenSearch community, as well as what impact it has if it isn't built, or new risks if it is. Highlight opportunities for additional research._

### What will it take to execute?
_Describe what it will take to build this feature. Are there any assumptions you may be making that could limit scope or add limitations? Are there performance, cost, or technical constraints that may impact the user experience? Does this feature depend on other feature work? What additional risks are there?_

### Any remaining open questions?
_What are known enhancements to this feature? Any enhancements that may be out of scope but that we will want to track long term? List any other open questions that may need to be answered before proceeding with an implementation._
43 changes: 43 additions & 0 deletions .github/workflows/release.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
name: Tag and publish a release

on:
push:
tags:
- 'v*.*.*'
branches: [ test-release ]

jobs:
release:
runs-on: ubuntu-latest
permissions:
contents: write
steps:
- uses: actions/checkout@v2
- name: Set release version Name
run: echo "RELEASE_VERSION=${GITHUB_REF#refs/*/}" >> $GITHUB_ENV
- name: Set up JDK 17.0
uses: actions/setup-java@v1
with:
java-version: 17.0
- name: Grant execute permission for gradlew
run: chmod +x gradlew
- name: Build with Gradle
run: ./gradlew -Dtests.security.manager=false build
- name: Rename build assets
run: cp ./build/distributions/opensearch-ubi-*.zip ./opensearch-ubi-plugin-${{ env.RELEASE_VERSION }}.zip
- name: Create Release
id: create_release
uses: ncipollo/release-action@v1
with:
artifacts: "./opensearch-ubi-plugin-${{ env.RELEASE_VERSION }}.zip"
token: ${{ secrets.GITHUB_TOKEN }}
tag: "release-${{ env.RELEASE_VERSION }}"
- name: Upload Release Asset
id: upload-release-asset
uses: softprops/action-gh-release@v1
with:
token: ${{ secrets.GITHUB_TOKEN }}
tag_name: "release-${{ env.RELEASE_VERSION }}"
#upload_url: ${{ steps.create_release.outputs.upload_url }}
files: ./opensearch-ubi-plugin-${{ env.RELEASE_VERSION }}.zip
name: ${{ env.RELEASE_VERSION }}
20 changes: 16 additions & 4 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -18,10 +18,10 @@ Start the containers:

`docker compose up`

Initialize the `awesome` UBL store:
Initialize the `awesome` UBI store:

```
curl -X PUT http://localhost:9200/_plugins/ubi/awesome
curl -X PUT "http://localhost:9200/_plugins/ubi/awesome?index=ecommerce&id_field=name"
```

Send an event to the `awesome` store:
Expand All @@ -40,10 +40,16 @@ curl -s http://localhost:9200/.awesome_events/_search | jq
curl -s http://localhost:9200/.awesome_events/_search -H 'Content-Type: application/json' -d '{"query": {"term": {"type": "instant-search"}}}' | jq
```

Do a search of the `ecommerce` index:

```
curl -s http://localhost:9200/ecommerce/_search -H "X-ubi-store: awesome" | jq
```

Get queries:

```
curl -s http://localhost:9200/.awesome_queries/_search -H "X-ubi-store: awesome" | jq
curl -s http://localhost:9200/.awesome_queries/_search | jq
```

Delete the store:
Expand All @@ -52,6 +58,12 @@ Delete the store:
curl -X DELETE http://localhost:9200/_plugins/ubi/awesome
```

Get the stores:

```
curl http://localhost:9200/_plugins/ubi
```

## Load Test

The `load-test` directory contains a basic load testing example. The purpose of the files under `load-test` are to provide a means of testing the plugin's ability to receive and store a large number of events over time. To use the load test, first start OpenSearch on `localhost:9200`, and then:
Expand All @@ -74,4 +86,4 @@ POST /_plugins/ubi/mystore
Found 8 indexed
```

This shows 8 total requests made by locust, and 8 events are in the index. The idea being we can assert that the number of events sent matches the events stored in the index.
This shows 8 total requests made by locust, and 8 events are in the index. The idea being we can assert that the number of events sent matches the events stored in the index.
6 changes: 3 additions & 3 deletions build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -7,12 +7,12 @@ apply plugin: 'maven-publish'
opensearchplugin {
name 'opensearch-ubi'
description 'OpenSearch User Behavior Insights Plugin'
classname 'org.opensearch.ubi.UserBehaviorInsightsPlugin'
classname 'com.o19s.ubi.UserBehaviorInsightsPlugin'
licenseFile rootProject.file('LICENSE.txt')
noticeFile rootProject.file('NOTICE.txt')
}

group = 'org.opensearch'
group = 'com.o19s'
version = "${ubiVersion}-os${opensearchVersion}"

// disabling some unnecessary validations for this plugin
Expand Down Expand Up @@ -61,7 +61,7 @@ publishing {
pom {
name = "opensearch-ubi"
description = "Provides User Behavior Insights for OpenSearch"
groupId = "org.opensearch"
groupId = "com.o19s"
licenses {
license {
name = "The Apache License, Version 2.0"
Expand Down
4 changes: 2 additions & 2 deletions documentation.md
Original file line number Diff line number Diff line change
Expand Up @@ -16,8 +16,8 @@ index is used to store events, and the other index is for storing queries.

#### OpenSearch Data Mappings

* The current event mappings file can be found [here](https://github.com/o19s/opensearch-ubi/blob/main/src/main/resources/org/opensearch/ubi/backends/events-mapping.json).
* The current query mappings file can be found [here](https://github.com/o19s/opensearch-ubi/blob/main/src/main/resources/org/opensearch/ubi/backends/queries-mapping.json).
* The current event mappings file can be found [here](https://github.com/o19s/opensearch-ubi/blob/main/src/main/resources/events-mapping.json).
* The current query mappings file can be found [here](https://github.com/o19s/opensearch-ubi/blob/main/src/main/resources/queries-mapping.json).

Schema for events:

Expand Down
17 changes: 17 additions & 0 deletions index-chorus-data.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
#!/bin/bash -e

CHORUS_HOME=${1:-`realpath ../chorus-opensearch-edition`}
echo "Using CHORUS_HOME = ${CHORUS_HOME}"

TEMP_FILE=`mktemp`
head -n 50 ${CHORUS_HOME}/transformed_data.json > ${TEMP_FILE}

echo "Deleting index"
curl -s -X DELETE "localhost:9200/ecommerce"

echo "Creating index"
curl -s -X PUT "localhost:9200/ecommerce" -H "Content-Type: application/json" --data-binary @${CHORUS_HOME}/opensearch/schema.json
curl -s -X PUT "localhost:9200/ecommerce/_settings" -H "Content-Type: application/json" -d '{"index.mapping.total_fields.limit": 20000}'

echo "Indexing data"
curl -s -X POST "localhost:9200/ecommerce/_bulk?pretty" -H "Content-Type: application/json" --data-binary @${TEMP_FILE}
9 changes: 9 additions & 0 deletions load-test/load-test.py
Original file line number Diff line number Diff line change
Expand Up @@ -22,3 +22,12 @@ def event_task(self):
}

self.client.post("/_plugins/ubi/mystore", headers=headers, json=data)

@task
def queries_task(self):
headers = {
"Content-Type": "application/json",
"X-ubi-store": "mystore"
}

self.client.get("/ecommerce/_search", headers=headers)
21 changes: 14 additions & 7 deletions load-test/run.sh
Original file line number Diff line number Diff line change
@@ -1,17 +1,24 @@
#!/bin/bash -e

# Delete the store if it exists.
curl -X DELETE http://localhost:9200/_plugins/ubi/mystore
curl -X DELETE "http://localhost:9200/_plugins/ubi/mystore"

# Create the store
curl -X PUT http://localhost:9200/_plugins/ubi/mystore
# Create the store.
curl -X PUT "http://localhost:9200/_plugins/ubi/mystore?index=ecommerce"

# Insert events
locust -f load-test.py --headless -u 1 -r 1 --run-time 10s --host http://localhost:9200
# Index subset of Chorus data.
../index-chorus-data.sh `realpath ../../chorus-opensearch-edition`

# Insert events and queries.
locust -f load-test.py --headless -u 50 -r 10 --run-time 300s --host http://localhost:9200

# Let events index.
sleep 2
sleep 30

# Get count of indexed events.
EVENTS=`curl -s http://localhost:9200/.mystore_events/_count | jq .count`
echo "Found $EVENTS indexed"
echo "Found $EVENTS events"

# Get count of indexed queries.
QUERIES=`curl -s http://localhost:9200/.mystore_queries/_count | jq .count`
echo "Found $QUERIES queries"
Loading

0 comments on commit 32f8748

Please sign in to comment.