Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Move lantern_extras to lantern repo #339

Merged
merged 281 commits into from
Oct 9, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
281 commits
Select commit Hold shift + click to select a range
d44c0d5
Add lantern-cli daemon mode (#24)
var77 Oct 30, 2023
d505ca7
Add docker publish action for CLI (#28)
var77 Nov 1, 2023
91b1e17
Add tests for lantern_embeddings and lantern_embeddings core (#27)
var77 Nov 1, 2023
c78a27b
Better handling for sql query formatting (#29)
var77 Nov 3, 2023
62ff52a
Varik/skip column creation (#30)
var77 Nov 4, 2023
5a20fd7
Varik/fix client identifier names (#31)
var77 Nov 8, 2023
51e4af5
Fix typo in trigger name (#32)
var77 Nov 8, 2023
dd32004
Fix notification channel for client (#33)
var77 Nov 8, 2023
613b103
Add dst_column to trigger and function names (#34)
var77 Nov 21, 2023
279f72a
Explicitly specify ort version (#36)
var77 Nov 21, 2023
fd804df
Create lock table in lantern schema hash trigger names (#37)
var77 Nov 21, 2023
018f804
Create client function and trigger names with job_id instead of hash …
var77 Nov 22, 2023
2e9573c
Collect update jobs non-blocking (#39)
var77 Nov 23, 2023
ef4e299
Add progress and usage tracking (#40)
var77 Nov 23, 2023
e13d286
Add model speed measurement script (#41)
var77 Nov 24, 2023
7d53268
Fix data_producer deadlock, remove unwraps (#42)
var77 Nov 25, 2023
4e86a66
Add db connect timeout (#43)
var77 Nov 25, 2023
8b0858e
Index autotune and import (#44)
var77 Dec 4, 2023
084b28e
Optimize batch size for models (#46)
var77 Dec 5, 2023
d82daa0
Check memory usage to avoid OOM Errors (#45)
var77 Dec 6, 2023
9d334e3
Index Autotune Improvements (#47)
var77 Dec 11, 2023
5098036
Remove index file after import (#48)
var77 Dec 14, 2023
03acdfc
Add external index functions to SQL and make index creation in one tr…
var77 Dec 18, 2023
55d3bea
Take relation instead of index id, encapsulate reindex function in sc…
var77 Dec 19, 2023
eb8bb10
Gracefully exit ongoing embedding job if the job is canceled from db …
var77 Dec 19, 2023
629adfd
Add checks for downloading images (#52)
var77 Dec 20, 2023
e10373d
Autotune bugfix and reduce memory consumption for index creation (#53)
var77 Dec 21, 2023
b9de6da
External index jobs (#54)
var77 Dec 25, 2023
21a0e29
Added CI tests (#55)
var77 Dec 26, 2023
c6c2ca5
Fix sample size to take from test table count (#56)
var77 Dec 27, 2023
0580f78
Optimize memory usage for index creation (#57)
var77 Jan 1, 2024
5b13ce5
Change chunk size when copying file to postgres to boost performance …
var77 Jan 2, 2024
d9c14f6
Update batch size for jina models (#59)
var77 Jan 4, 2024
754021e
External index wait for lock (#60)
var77 Jan 4, 2024
69db0ce
Add token count to speed tests (#61)
var77 Jan 5, 2024
62beecd
Save index file in postgres data dir (#62)
var77 Jan 6, 2024
b8e081e
Autotune schema refactor (#63)
var77 Jan 8, 2024
0bcb18b
Dynamic input batching for jinaai models (#64)
var77 Jan 9, 2024
fa8dceb
Commit transaction on local datase connection when creating external …
var77 Jan 9, 2024
3b0b4a0
Add runtime mechanism in embeddings core, refactor code (#66)
var77 Jan 16, 2024
8f59dc9
Limit test concurrency to 1 in CI (#67)
var77 Jan 16, 2024
243acf2
Rename models and update tests (#68)
var77 Jan 16, 2024
d47b26a
Fix external index metric and add retry policy to HTTP runtime (#69)
var77 Jan 17, 2024
e7934a4
Add ARM runner on CI (#71)
var77 Jan 29, 2024
c8adb7f
Handle null values in index creation (#74)
var77 Jan 30, 2024
326a244
usearch new interface (#70)
var77 Feb 7, 2024
4c2c0c6
Add update support for embedding jobs on daemon
var77 Jan 30, 2024
fe6386b
Lantern embeddings: use ctid as pk and delete row lock after job is c…
var77 Feb 6, 2024
7422c5d
Lantern autotune: use ctid as pk, remove pk arg and update README
var77 Feb 6, 2024
b8b8b58
Lantern embeddings: fix row unlock functionality and add test
var77 Feb 6, 2024
abc5b0a
Set client triggers before job start, add tests, fix progress bug
var77 Feb 8, 2024
b267d89
Upgrade pgrx to 0.11.3, add pg16 support, rename src to lib in packag…
var77 Feb 8, 2024
9927c66
Lantern embeddings: Add input token count and track in usage
var77 Feb 8, 2024
9fc1067
Lantern embeddings: Add new openai models
var77 Feb 8, 2024
d506866
Update lanter version on ci, fix tests
var77 Feb 9, 2024
8f9ec16
Update rust version in docker
var77 Feb 9, 2024
8d53997
Fix embedding usage function name
var77 Feb 15, 2024
4a862dd
Add tests for embedding usage tracking
var77 Feb 15, 2024
6a7714d
Expand backoff mechanism for body validation as well
var77 Feb 16, 2024
bc6c049
Implement product quantization in lantern cli
var77 Feb 10, 2024
a8d887a
Process all splits in parallel
var77 Feb 11, 2024
2bf0ccc
Add subvector-id argument and ability to horizontally scale the runni…
var77 Feb 11, 2024
a6a1c50
Fix progress tracking for pq
var77 Feb 11, 2024
8825e3e
Fix indexing bug
var77 Feb 11, 2024
908d0db
Parallelize vector compression
var77 Feb 12, 2024
2b5ffe2
Parallelize data fetching and export
var77 Feb 12, 2024
071cee8
Refactor and separate code parts
var77 Feb 14, 2024
cea3f6a
Refactor code, pack arguments in a struct
var77 Feb 15, 2024
92da38c
Add gcp batch job flow
var77 Feb 15, 2024
99974aa
Add tests for lantern_pq
var77 Feb 16, 2024
8d06963
Add action to push cli image to GCR
var77 Feb 16, 2024
ef6bc54
Remove unnecessary arguments
var77 Feb 16, 2024
d42719f
Rename codebook table and params to match lantern pq
var77 Feb 19, 2024
96b9ff6
Fix naming issues, add --dataset-limit argument
var77 Feb 20, 2024
bce7aa2
Conditionaliy publish latest tag for cli docker image
var77 Feb 20, 2024
b0e0217
Use renamed lantern access method
Ngalstyan4 Feb 17, 2024
6151ddf
Release v0.2.0
Ngalstyan4 Feb 17, 2024
1619b71
Temporarily change lantern tag for testing before lantern is released
Ngalstyan4 Feb 17, 2024
6e57e6b
Implement pq-quantization in external index construction
Ngalstyan4 Feb 20, 2024
21876f2
Fix codebook offset bug
Ngalstyan4 Feb 20, 2024
dce46ed
set pq parameter in index construction when importing
Ngalstyan4 Feb 20, 2024
6dce519
Fix codebook lifetime bug in rust<->C interface
Ngalstyan4 Feb 21, 2024
493cd67
Prepare for release
Ngalstyan4 Feb 21, 2024
3b51d4b
Fix naming for uppercase table names, check if codebook table exists …
var77 Feb 21, 2024
437b548
Add pq argument for external index reindexing
var77 Feb 21, 2024
eed1443
Add base_url param for OpenAi runtime
var77 Feb 16, 2024
c3335bc
Fix openai args, bump version
var77 Feb 20, 2024
32461b0
Fix openai model default dims to 1536, add base_url param from sql
var77 Feb 20, 2024
592bfaa
Fix authorization for openai azure deployment
var77 Feb 20, 2024
6cf6c92
Add GUC for OpenAI base url
var77 Feb 21, 2024
2f6e3d3
Change codebook table name prefix to pq_
var77 Feb 22, 2024
9d5fb9a
Add codebook table name size validation
var77 Feb 22, 2024
86db8d8
Fix range bug for pq data fetching
var77 Feb 23, 2024
d5ae7fd
Merge cli packages into one crate
var77 Feb 23, 2024
a9af359
Remove lantern_ prefix from cli modules
var77 Feb 23, 2024
228241c
Remove unnecessary features
var77 Feb 23, 2024
4c0cb68
Remove unintended change of sql trigger names
var77 Feb 24, 2024
a8f2a71
Fix lantern version
var77 Feb 24, 2024
2b2c05e
Omit invalid images when generating visual embeddings
var77 Feb 26, 2024
7c51f96
Put invalid vector for broken images
var77 Feb 26, 2024
bbd8e16
Do mean pooling for jina embeddings
var77 Feb 27, 2024
7fb31e3
Fix usage function in tests
var77 Feb 27, 2024
69eab2d
Select random subset from dataset if limit is passed
var77 Feb 29, 2024
28ea40e
Add time logs for external indexing
var77 Feb 29, 2024
09e3a80
Fix pq tests
var77 Feb 29, 2024
610b90b
Pass dataset limit to gcp jobs
var77 Feb 29, 2024
b77db72
Add allocation policy to gcp batch jobs
var77 Mar 1, 2024
a1f50ca
Use attention mask to zero padded tokens when mean pooling
var77 Mar 1, 2024
618dabe
Fix offset bug in gcp job
var77 Mar 2, 2024
41872a1
Fix typo in log
var77 Mar 2, 2024
33c42e3
[WIP] add http server with actix
var77 Feb 29, 2024
932c0b4
[WIP] Add routes for http interface
var77 Mar 4, 2024
ba3b377
Fix insert and search routes, add pq routes, add api docs [WIP]
var77 Mar 5, 2024
009c723
Add tests for HTTP server, improve docs, add features to cli crate
var77 Mar 6, 2024
796b44a
Install extras extension in CI for CLI tests
var77 Mar 6, 2024
8cd792c
Call CREATE EXTENSION for extras in CI
var77 Mar 6, 2024
d301cac
Make feature dependencies optional, add overwrite argument to pq
var77 Mar 6, 2024
fded947
Fix openai issue for full sequence
var77 Mar 6, 2024
2f31d6d
Increase http api batch sizes to use parallel cores
var77 Mar 6, 2024
f9decf5
Send index definitions on collection response
var77 Mar 7, 2024
e91b376
Set max batch size to embeddings when exporting results
var77 Mar 9, 2024
002ffe5
Ignore embedding rows which has empty string
var77 Mar 9, 2024
1401b22
Add connection ping for client database, retry failed updates after 5…
var77 Mar 13, 2024
746890b
Update version
var77 Mar 13, 2024
0edde8a
Separate db connections for each daemon task
var77 Mar 13, 2024
445f50a
Add caching to cargo builds
var77 Mar 11, 2024
4094e2b
Move pg configuration to different function
var77 Mar 11, 2024
92b9d8d
Fix tests for CI, increase body limit for http
var77 Mar 13, 2024
fa6ab2c
Improve copy performance
var77 Mar 14, 2024
c9bac64
Reduce optimization level for ci builds
var77 Mar 14, 2024
2e88d8e
Update version [skip ci]
var77 Mar 14, 2024
a81c989
Add basic auth to http server
var77 Mar 14, 2024
9c9d5b6
Make channels unbounded, change Atomic to Channel (#100)
var77 Mar 15, 2024
c28e687
Stream init job instead of blocking thread
var77 Mar 16, 2024
9d1b69b
Fix batch size and channel type for embedding jobs
var77 Mar 17, 2024
3391fc3
Bump version
var77 Mar 17, 2024
ed3e35c
Add bge m3 model
var77 Mar 18, 2024
7e084b5
Configure model params for bge m3 model
var77 Mar 18, 2024
c0ae274
Change ctid to id for daemon embedding jobs, because of ctid concurre…
var77 Mar 26, 2024
8f9c426
Update version in ci
var77 Mar 26, 2024
1de0053
Fix cuda version in docker
var77 Mar 26, 2024
52fae8c
Fix libnvrtc.so not found error for cli cuda image
var77 Mar 26, 2024
81a5dbc
Bring back pk argument for embeddings
var77 Mar 26, 2024
810fc87
Use pk in producer_worker of embedding
var77 Mar 26, 2024
84934e0
Track failed embedding requests
var77 Mar 20, 2024
130ab44
Update version
var77 Mar 26, 2024
e5c0565
Set default value for --create-column to false
var77 Mar 26, 2024
262c0e6
Add arm64 platform to CLI docker publish
var77 Mar 29, 2024
a652da1
Fix onnxlib for arm64
var77 May 3, 2024
4a46b9d
remove unnecessary if statement from dockerfile
var77 May 10, 2024
36943d6
update usearch to new verison, bump versions to 0.2.0
var77 May 13, 2024
9d06eda
rollback cargo config file format
var77 May 13, 2024
7cf70ad
Update filter to ignore source embeddings from daemon
var77 May 28, 2024
d3ffecb
Update rustc to 1.78 in dockerfiles
var77 May 28, 2024
74611af
Client listener bug when passing wrong argument order
var77 May 29, 2024
333ed52
Check ignore filter before sending notification from trigger
var77 May 29, 2024
a7fe787
Make daemon jobs to run from client database tables, add master_db ar…
var77 May 22, 2024
4e91806
Add tests, get rid of static maps
var77 May 28, 2024
1970985
Update lanern version in CI
var77 May 28, 2024
8b13cb8
Add more tests for daemon embedding jobs, fix bugs related job stream…
var77 May 29, 2024
3ea92df
Handle database connection failures and restart jobs for daemon
var77 May 31, 2024
2bc6305
use usearch with old lantern storage
var77 May 31, 2024
07f95c3
update lantern version in ci
var77 May 31, 2024
bf4bf5c
change default name for databases table
var77 May 31, 2024
261ee39
Keep embedding usage info in a table
var77 Jun 2, 2024
4f0b1f3
Create index on embedding usage table
var77 Jun 3, 2024
4de0b62
change client job static map to local map, fix underflow subtraction …
var77 Jun 3, 2024
468c240
add labels to embedding jobs, fix init_finished_at for empty tables
var77 Jun 7, 2024
5f68525
remove unnecessarry migration
var77 Jun 7, 2024
75dcd6b
Add code coverage info (#119)
var77 Jun 12, 2024
ffdea61
Splade v3 model (#123)
var77 Jun 12, 2024
d947a44
Add daemon functions in lantern_extras extension (#120)
var77 Jun 13, 2024
35962e8
add healthcheck for master db listener
var77 Jun 17, 2024
eaf0717
convert embedding generation code to async, so mutexes wont block io …
var77 Jun 17, 2024
0338813
add bytes to embedding deps
var77 Jun 17, 2024
1e72d5e
remove unnecessarry tokio runtime creation on http_runtime
var77 Jun 17, 2024
9d6e9e1
run daemon jobs from a single central queue
var77 Jun 18, 2024
7d414d7
add healthcheck for db notification listener tasks
var77 Jun 18, 2024
0dfe4df
fix error for running blocking tasks inside tokio runtime
var77 Jun 21, 2024
1430c32
remove long living portal from streaming embedding jobs to not block …
var77 Jun 20, 2024
ab1f6bb
use another table to keep row ids for init streaming jobs
var77 Jun 22, 2024
c4b0ee1
rename _lantern_internal schema to _lantern_extras_internal
var77 Jun 22, 2024
a367a93
update version
var77 Jun 22, 2024
d7f98d6
create _lantern_extras_internal schema on http server setup
var77 Jun 23, 2024
b4cf733
reserve 20% progress for index import by increasing row count in exte…
var77 Jun 24, 2024
2dfee22
maove http collections schema nameto constant
var77 Jun 24, 2024
f7ce61b
add dynamic batching for splade-v3 model
var77 Jun 27, 2024
563e111
properly close embedding jobs to avoid duplicates on failure retry
var77 Jun 30, 2024
0a3b170
use child_token for spawned jobs to cancel on parent process exit
var77 Jun 30, 2024
9c258af
Update usearch to support lantern 0.3+
var77 Jul 5, 2024
2e89f8d
Optimize relu max pooling and fix sql query for non-integer primary k…
var77 Jul 6, 2024
1fa63b7
Optimize relu_max_pooling and mean_pooling functions
var77 Jul 8, 2024
9b3c403
Limit update batching for embedding jobs to specified defaults
var77 Jul 8, 2024
99c6c63
do not take any other jobs if daemon has specified label
var77 Jul 8, 2024
464de77
fix bug for initial label caching, update tests
var77 Jul 8, 2024
ffa8818
remove cache for labels and handle label updates in update processor,…
var77 Jul 8, 2024
c9e1ee6
make daemon label check more strict, so jobs with specified labels wi…
var77 Jul 10, 2024
7f5463a
fix progress issue in external indexing for small tables, change sess…
var77 Jul 11, 2024
90656b6
add external indexing tcp server, which will accept streamed tuples f…
var77 Jul 16, 2024
63d0d1a
Fix external index resizing segfault, add tests for external index se…
var77 Jul 16, 2024
cb878ce
Update lantern version on CI
var77 Jul 16, 2024
e9b33ed
take scalar quantization from params
var77 Jul 17, 2024
dc8c960
properly parse distance metric
var77 Jul 17, 2024
d484b9a
add tmp_directory option, make tests consistent over platforms
var77 Jul 17, 2024
fd30bb3
set socket timeout for both read and write
var77 Jul 18, 2024
ef0f94b
fix tuple parsing for bit arrays, add test for hamming distance
var77 Jul 23, 2024
f64df19
update cli version
var77 Jul 23, 2024
7c250e8
correctly handle error when target db url is not valid and wrong op c…
var77 Jul 26, 2024
2797cee
add ssl config to external indexing server
var77 Aug 2, 2024
b053f68
cleanup tmp indexes after indexing finishes or errors, show some stat…
var77 Sep 5, 2024
73ea19a
send server type on start, add status server
var77 Sep 13, 2024
8d54349
write tests for external indexing status server
var77 Sep 13, 2024
9f6495b
send error message length in case of error
var77 Sep 13, 2024
1ca8f5a
send protocol version on first message
var77 Sep 13, 2024
9277fd2
fix memory leak in exernal indexing by not shadowing the variable
var77 Sep 17, 2024
8d52242
push containers with cpu-native build for common intel CPUs
var77 Sep 18, 2024
84feb25
show indexing speed in logs
var77 Sep 18, 2024
c458731
update cli to 0.3.24
var77 Sep 18, 2024
b6df5fe
pass usearch defines to enable simsimd and native f16 for optimized b…
var77 Sep 23, 2024
19c51fa
add more target architectures
var77 Sep 24, 2024
cee7ee9
add quantization support for external indexing
var77 Sep 4, 2024
7fba4a9
parse vector elements based on element_bits passed from header
var77 Sep 24, 2024
45091e5
use usearch add_raw to avoid double type conversion and accelerate fo…
var77 Sep 25, 2024
32a70e6
upgrade usearch, remove cpu-optimized build as new version of usearch…
var77 Sep 26, 2024
2c1847e
revert usearch update, birng back the x64 optimized builds
var77 Sep 27, 2024
ce8995d
update usearch to use upstream version
var77 Sep 27, 2024
1606459
remove saphirerapids build from CI
var77 Sep 30, 2024
be94557
replace isahc with reqwest, as isahc creates thread-pool on import wh…
var77 Oct 2, 2024
3a196af
add background worker for daemon in lantern_extras extension, fix tes…
var77 Oct 2, 2024
7aad65d
use GUC variables for openai and cohere tokens for default values on …
var77 Oct 2, 2024
da3c483
convert status server to actix server
var77 Oct 3, 2024
fb6d7bd
increase timeout for file download
var77 Oct 3, 2024
94e2d56
update cli version
var77 Oct 3, 2024
664f1a7
add data path to daemon to store models in postgres data dir when run…
var77 Oct 7, 2024
39b979f
restructure repo
var77 Oct 8, 2024
883e5fa
restructure repo
var77 Oct 8, 2024
b906512
merge lantern_extras with lantern repo
var77 Oct 8, 2024
f1d9e92
fix docker build for lantern
var77 Oct 8, 2024
5620a30
fix docker build for lantern_cli
var77 Oct 8, 2024
8b5afe9
fix docker build for lantern dev
var77 Oct 8, 2024
2208793
move scripts under lantern_hnsw
var77 Oct 8, 2024
7209baf
update test workflow and build.sh file for CI
var77 Oct 8, 2024
19ff9c1
combine build action for lantern and lantern_extras
var77 Oct 8, 2024
ad4c691
cache model files for CI tests
var77 Oct 9, 2024
8f964fe
remove cache from ci tests, fix install script logs
var77 Oct 9, 2024
a26c79f
debug codecov action
var77 Oct 9, 2024
d3dbecb
fix codecov action and pgvector build
var77 Oct 9, 2024
7fd2f4a
fix coverage file name
var77 Oct 9, 2024
634240a
update installation instructions in README
var77 Oct 9, 2024
ef12dba
set extension versions to 0.4.0
var77 Oct 9, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
10 changes: 10 additions & 0 deletions .cargo/config
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
[target.aarch64-apple-darwin]
rustflags = ["-C", "link-args=-Wl,-rpath,/usr/local/lib/onnxruntime/lib"]
[target.x86_64-apple-darwin]
rustflags = ["-C", "link-args=-Wl,-rpath,/usr/local/lib/onnxruntime/lib"]
[target.'cfg(target_os="macos")']
# Postgres symbols won't be available until runtime
rustflags = ["-Clink-arg=-Wl,-undefined,dynamic_lookup"]
[env]
ORT_STRATEGY = { value = "system" }
ORT_LIB_LOCATION = { value = "/usr/local/lib/onnxruntime/lib" , relative = false }
6 changes: 6 additions & 0 deletions .dockerignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
.git
.cargo
.github
target
.DS_Store
lantern_hnsw/build
62 changes: 53 additions & 9 deletions .github/workflows/build.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -16,12 +16,12 @@ on:
required: false
default: false
jobs:
build:
build_lantern:
runs-on: ${{ matrix.os }}
strategy:
fail-fast: false
matrix:
os: [ubuntu-22.04, ubicloud-standard-2-arm, macos-13]
os: [ubuntu-22.04, ubicloud-standard-4-arm, macos-13]
postgres: [11, 12, 13, 14, 15, 16]
steps:
- uses: actions/checkout@v4
Expand All @@ -37,23 +37,69 @@ jobs:
run: sudo sh -c "GITHUB_OUTPUT=$GITHUB_OUTPUT ./ci/scripts/package-archive.sh"
- name: Upload deb package artifacts
uses: actions/upload-artifact@v4
if: ${{ steps.build.outputs.deb_package_path != '' }}
if: ${{ steps.build.outputs.deb_package_path != '' && github.event_name == 'workflow_dispatch' && inputs.create_release }}
with:
name: ${{ steps.build.outputs.deb_package_name }}
path: ${{ steps.build.outputs.deb_package_path }}
- name: Upload archive package artifacts
uses: actions/upload-artifact@v4
if: ${{ steps.archive.outputs.archive_package_path != '' }}
if: ${{ steps.archive.outputs.archive_package_path != '' && github.event_name == 'workflow_dispatch' && inputs.create_release }}
with:
name: ${{ steps.archive.outputs.archive_package_name }}
path: ${{ steps.archive.outputs.archive_package_path }}
build_extras:
runs-on: ${{ matrix.os }}
strategy:
fail-fast: false
matrix:
os: [ubuntu-22.04, ubicloud-standard-4-arm]
postgres: [11, 12, 13, 14, 15, 16]
steps:
- uses: actions/checkout@v4
with:
submodules: "recursive"
- name: Build
id: build
run: sudo su -c "PG_VERSION=$PG_VERSION SETUP_ENV=1 USE_SOURCE=1 SETUP_POSTGRES=1 PACKAGE_EXTENSION=1 GITHUB_OUTPUT=$GITHUB_OUTPUT ./ci/scripts/build-extras.sh"
env:
PG_VERSION: ${{ matrix.postgres }}
- name: Build Lantern CLI
id: build_cli
run: sudo su -c "PACKAGE_CLI=1 GITHUB_OUTPUT=$GITHUB_OUTPUT ./ci/scripts/build-extras.sh"
if: ${{ matrix.postgres == 15 }} # run only once
- name: Upload archive package artifacts
if: ${{ github.event_name == 'workflow_dispatch' && inputs.create_release }}
uses: actions/upload-artifact@v4
with:
name: ${{ steps.build.outputs.archive_package_name }}
path: ${{ steps.build.outputs.archive_package_path }}
- name: Upload Lantern CLI artifacts
if: ${{ matrix.postgres == 15 && github.event_name == 'workflow_dispatch' && inputs.create_release }} # run only once
uses: actions/upload-artifact@v4
with:
name: ${{ steps.build_cli.outputs.cli_package_name }}
path: ${{ steps.build_cli.outputs.cli_package_path }}
package:
runs-on: ubuntu-22.04
needs: [build]
needs: [build_lantern, build_extras]
if: ${{ github.event_name == 'workflow_dispatch' && inputs.create_release }}
steps:
- uses: actions/checkout@v4
with:
submodules: "recursive"
- uses: actions/download-artifact@v4
with:
pattern: lantern-extras-*.tar
merge-multiple: true
path: /tmp/lantern-extras-package
- uses: geekyeggo/delete-artifact@v4
with:
name: lantern-extras*.tar
- uses: actions/download-artifact@v4
with:
pattern: lantern-cli-*
merge-multiple: true
path: /tmp/lantern-cli-package
- uses: actions/download-artifact@v4
with:
pattern: lantern-*.tar
Expand All @@ -73,24 +119,22 @@ jobs:
name: ${{ steps.package.outputs.package_name }}
path: ${{ steps.package.outputs.package_path }}
- name: Create source code archive with submodules
if: ${{ github.event_name == 'workflow_dispatch' && inputs.create_release }}
run: |
find ./ -name '.git*' -exec rm -r {} \; || true
tar -czf /tmp/lantern-v${{ steps.package.outputs.package_version }}-source.tar.gz .
- name: Create GitHub release
uses: softprops/action-gh-release@v1
uses: softprops/action-gh-release@v2
id: create_release
if: ${{ github.event_name == 'workflow_dispatch' && inputs.create_release }}
with:
name: Lantern v${{ steps.package.outputs.package_version }}
tag_name: v${{ steps.package.outputs.package_version }}
files: |
${{ steps.package.outputs.package_path }}
/tmp/lantern-v${{ steps.package.outputs.package_version }}-source.tar.gz
/tmp/lantern-cli-package/*
generate_release_notes: true
- name: Homebrew release
uses: var77/bump-homebrew-formula-action@main
if: ${{ github.event_name == 'workflow_dispatch' && inputs.create_release }}
with:
formula-name: lantern
formula-path: Formula/lantern.rb
Expand Down
170 changes: 170 additions & 0 deletions .github/workflows/publish-cli-docker.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,170 @@
name: publish-cli-docker
on:
workflow_dispatch:
inputs:
LATEST:
type: boolean
description: "Publish as latest release"
required: false
default: false
VERSION:
type: string
description: "CLI version"
required: true
default: "0.3.27"
IMAGE_NAME:
type: string
description: "Container image name to tag"
required: true
default: "lanterndata/lantern-cli"
jobs:
build-x64:
runs-on: ubuntu-22.04
strategy:
fail-fast: false
matrix:
device: [cpu, gpu]
steps:
- uses: actions/checkout@v4
- name: Set up QEMU
uses: docker/setup-qemu-action@v3
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Login to DockerHub
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Login to GCR Container Registry
uses: docker/login-action@v3
with:
registry: ${{ secrets.GCP_REGION }}-docker.pkg.dev
username: _json_key_base64
password: ${{ secrets.GCP_CREDENTIALS_JSON_B64 }}
- name: Build and push
uses: docker/build-push-action@v5
id: build_image_latest
with:
context: .
platforms: |
linux/amd64
file: docker/Dockerfile.cli${{ (matrix.device == 'gpu' && '.cuda' || '') }}
push: true
# We will only correctly tag GPU image as we have it only for x86_64 platform
# CPU image will be tagged with github sha, to be merged later with arm64 image and pushed with correct tags
tags: |
${{ (matrix.device == 'cpu' && format('{0}:{1}-cpu-amd64', inputs.IMAGE_NAME, github.sha) || format('{0}:gpu', inputs.IMAGE_NAME)) }}
${{ (matrix.device == 'gpu' && format('{0}:{1}-gpu', inputs.IMAGE_NAME, inputs.VERSION)) || '' }}
${{ (matrix.device == 'gpu' && (inputs.LATEST == true || inputs.LATEST == 'true') && format('{0}:latest-gpu', inputs.IMAGE_NAME)) || '' }}
${{ (matrix.device == 'gpu' && (inputs.LATEST == true || inputs.LATEST == 'true') && format('{0}-docker.pkg.dev/{1}/{2}:latest-gpu', secrets.GCP_REGION, secrets.GCP_PROJECT_ID, inputs.IMAGE_NAME)) || '' }}
${{ (matrix.device == 'gpu' && format('{0}-docker.pkg.dev/{1}/{2}:{3}-gpu',secrets.GCP_REGION,secrets.GCP_PROJECT_ID, inputs.IMAGE_NAME, inputs.VERSION)) || '' }}
build-x64-optimized:
runs-on: ubuntu-22.04
strategy:
fail-fast: false
matrix:
target: [skylake, cascadelake, icelake-server]
steps:
- uses: actions/checkout@v4
- name: Set up QEMU
uses: docker/setup-qemu-action@v3
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Login to DockerHub
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Login to GCR Container Registry
uses: docker/login-action@v3
with:
registry: ${{ secrets.GCP_REGION }}-docker.pkg.dev
username: _json_key_base64
password: ${{ secrets.GCP_CREDENTIALS_JSON_B64 }}
- name: Build and push
uses: docker/build-push-action@v5
id: build_optimized_image
with:
context: .
platforms: |
linux/amd64
build-args: |
CXXFLAGS=${{ format('-march={0} -DUSEARCH_USE_SIMSIMD=1 -DUSEARCH_USE_FP16LIB=0', matrix.target) }}
file: docker/Dockerfile.cli
push: true
tags: |
${{ format('{0}:{1}-cpu-{2}', inputs.IMAGE_NAME, inputs.VERSION, matrix.target) }}
${{ format('{0}-docker.pkg.dev/{1}/{2}:{3}-cpu-{4}',secrets.GCP_REGION,secrets.GCP_PROJECT_ID, inputs.IMAGE_NAME, inputs.VERSION, matrix.target) }}
build-arm64:
runs-on: ubicloud-standard-4-arm
steps:
- uses: actions/checkout@v4
- name: Set up QEMU
uses: docker/setup-qemu-action@v3
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Login to DockerHub
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Build and push without latest tags
uses: docker/build-push-action@v5
id: build_image
with:
context: .
platforms: |
linux/arm64
file: docker/Dockerfile.cli
push: true
tags: |
${{ inputs.IMAGE_NAME }}:${{ github.sha }}-cpu-arm64
push:
runs-on: ubuntu-22.04
needs: [build-x64, build-arm64]
steps:
- uses: actions/checkout@v4
- name: Set up QEMU
uses: docker/setup-qemu-action@v3
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Login to DockerHub
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Login to GCR Container Registry
uses: docker/login-action@v3
with:
registry: ${{ secrets.GCP_REGION }}-docker.pkg.dev
username: _json_key_base64
password: ${{ secrets.GCP_CREDENTIALS_JSON_B64 }}
- name: Create latest tags and push
if: ${{ (inputs.LATEST == true || inputs.LATEST == 'true') }}
run: |
# :latest tag
docker buildx imagetools create -t ${{ inputs.IMAGE_NAME }}:latest \
${{ inputs.IMAGE_NAME }}:${{ github.sha }}-cpu-amd64 \
${{ inputs.IMAGE_NAME }}:${{ github.sha }}-cpu-arm64
# :latest-cpu
docker buildx imagetools create -t ${{ inputs.IMAGE_NAME }}:latest-cpu \
${{ inputs.IMAGE_NAME }}:${{ github.sha }}-cpu-amd64 \
${{ inputs.IMAGE_NAME }}:${{ github.sha }}-cpu-arm64
# :latest gcr
docker buildx imagetools create -t ${{ secrets.GCP_REGION }}-docker.pkg.dev/${{ secrets.GCP_PROJECT_ID }}/${{ inputs.IMAGE_NAME }}:latest \
${{ inputs.IMAGE_NAME }}:${{ github.sha }}-cpu-amd64 \
${{ inputs.IMAGE_NAME }}:${{ github.sha }}-cpu-arm64
# :latest-cpu gcr
docker buildx imagetools create -t ${{ secrets.GCP_REGION }}-docker.pkg.dev/${{ secrets.GCP_PROJECT_ID }}/${{ inputs.IMAGE_NAME }}:latest-cpu \
${{ inputs.IMAGE_NAME }}:${{ github.sha }}-cpu-amd64 \
${{ inputs.IMAGE_NAME }}:${{ github.sha }}-cpu-arm64
- name: Create and versioned tags and push
run: |
# :version-cpu tag
docker buildx imagetools create -t ${{ inputs.IMAGE_NAME }}:${{ inputs.VERSION }}-cpu \
${{ inputs.IMAGE_NAME }}:${{ github.sha }}-cpu-amd64 \
${{ inputs.IMAGE_NAME }}:${{ github.sha }}-cpu-arm64
# :version-cpu gcr
docker buildx imagetools create -t ${{ secrets.GCP_REGION }}-docker.pkg.dev/${{ secrets.GCP_PROJECT_ID }}/${{ inputs.IMAGE_NAME }}:${{ inputs.VERSION }}-cpu \
${{ inputs.IMAGE_NAME }}:${{ github.sha }}-cpu-amd64 \
${{ inputs.IMAGE_NAME }}:${{ github.sha }}-cpu-arm64
16 changes: 8 additions & 8 deletions .github/workflows/sanitizer-build-and-test.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -33,16 +33,16 @@ env:
CXXFLAGS: "-g -fsanitize=address -fno-omit-frame-pointer -Og -fno-inline-functions"
LDFLAGS: "-fsanitize=address"

ASAN_OPTIONS: suppressions=${{ github.workspace }}/scripts/sanitizers/suppressions/suppr_asan.txt
ASAN_OPTIONS: suppressions=${{ github.workspace }}/lantern_hnsw/scripts/sanitizers/suppressions/suppr_asan.txt
detect_odr_violation=0 log_path=${{ github.workspace }}/sanitizer/
log_exe_name=true print_suppressions=false exitcode=27
detect_leaks=0 abort_on_error=1

LSAN_OPTIONS: suppressions=${{ github.workspace }}/scripts/sanitizers/suppressions/suppr_leak.txt
LSAN_OPTIONS: suppressions=${{ github.workspace }}/lantern_hnsw/scripts/sanitizers/suppressions/suppr_leak.txt
print_suppressions=0 log_path=${{ github.workspace }}/sanitizer/
log_exe_name=true print_suppressions=false exitcode=27

UBSAN_OPTIONS: suppressions=${{ github.workspace }}/scripts/sanitizers/suppressions/suppr_ub.txt
UBSAN_OPTIONS: suppressions=${{ github.workspace }}/lantern_hnsw/scripts/sanitizers/suppressions/suppr_ub.txt
print_stacktrace=1 halt_on_error=1 log_path=${{ github.workspace }}/sanitizer/
log_exe_name=true print_suppressions=false exitcode=27

Expand Down Expand Up @@ -127,7 +127,7 @@ jobs:
tar --extract --file postgresql.tar.bz2 --directory ~/$PG_SRC_DIR --strip-components 1
# Add instrumentation to the Postgres memory contexts. For more details, see
# https://www.postgresql.org/message-id/CAM-w4HNH7%2BU9jZevpVK7Wr49tkfpWSR6wav0RLYrq0HWuP5cxw%40mail.gmail.com
patch -F5 -p1 -d ~/$PG_SRC_DIR < scripts/sanitizers/postgres-asan-instrumentation.patch
patch -F5 -p1 -d ~/$PG_SRC_DIR < lantern_hnsw/scripts/sanitizers/postgres-asan-instrumentation.patch
cd ~/$PG_SRC_DIR
./configure --prefix=$PG_INSTALL_DIR --enable-debug --enable-cassert \
--with-openssl --without-readline --without-zlib --without-libxml
Expand Down Expand Up @@ -160,8 +160,8 @@ jobs:

- name: Build Lantern
run: |
mkdir lantern_build
cd lantern_build
mkdir lantern_hnsw/lantern_build
cd lantern_hnsw/lantern_build
CXXFLAG="" cmake ..
make install

Expand All @@ -177,7 +177,7 @@ jobs:

- name: make test
run: |
cd lantern_build
cd lantern_hnsw/lantern_build
make test

- name: Show regression diffs
Expand Down Expand Up @@ -229,7 +229,7 @@ jobs:
info locals
bt full
" 2>&1 | tee stacktrace.log
./scripts/sanitizers/bundle_coredump.sh
./lantern_hnsw/scripts/sanitizers/bundle_coredump.sh
grep -C40 "was terminated by signal" postgres.log > postgres-failure.log ||:

- name: Coredumps
Expand Down
Loading
Loading