- [fea] Added
array_remove
andarray_remove_once
functions for the UPDATE-queries. Details - [fea] Increased limit for IdSet join preselect from 10'000 to 20'000 documents
- [fea] Added C++ benchmarks for
sparse
-indexes - [fea] Disabled comparators for
sparse
-indexes. From nowsparse
-indexes always use more effective IdSets instead - [fea] Added
DeleteMeta
method and simplified meta storing/reading logic - [fix] Fixed race condition in the JOINS cache
- [fix] Fixed results serialization for MERGE-queries with multiple JOINS in cases when some of the JOIN-queries have not joined any items
- [fix] Fixed
distinct
result in cases whenWHERE
-condition contains duplicate values (e.g.distinct(id) WHERE id IN (1,1,1,3)
)
- [fea] Increased max
merge_limit
value (new values range is[1, 0x1FFFFFFF]
) - [fix] Fixed phrase search behavior for the phrases containig single word
- [fea] Added
EnumMeta
andDeleteMeta
functions - [fix] Fixed
RenameNamespace
function - now upsert after namespace's renaming works properly
- [fea] Add
DELETE
-method for the/metabykey
HTTP-endpoint
- [fea] Added APT-repo for
AltLinux P10
- [fea] Added possibility to delete namespace's Meta data
- [fea] Added Git documentation link for the Bm25 config
- [fea] Added explicit null-values in the Grid view
- [fix] Fixed the inform window that appeared on the Cancel button on the NS Config page
- [fix] Fixed extra data uploading on the Performace page
- [fix] Changed Git documentation link in the Main menu
- [fix] Fixed console issues on the add/edit indexes
- [fix] Fixed caching of the NS config
- [fix] Fixed layout issues on the Index form
- [fix] Fixed crash in the incremental fulltext index during typos handling
- [fix] Fixed crash in the UPDATE-query in the case when this query sets values for some array-field and composite index simultaneously
- [fix] Fixed
joined
andcomposite
fields behavior: from now fields with those tags will not be created in the database
- [fix] Fixed
Release
build with GCC-12 - [fix] Added version check for
Google Benchmark
library during the build
- [fea] Added
clang-tidy
configs intoGitHub
source tree
- [fea] Improved queries condition injection injection on the both directions: joined-to-main and main-to-joined
- [fea] Improved heuristic for the joins preselect/condition injection. If query has some conditions with high selectivity, scheduler will try to avoid high cost preselect/injections attempts
- [fea] Added logic for the intersecting conditions merge on the query preprocessing stage
- [fea] Added clock wrapper to force vDSO for the
clock_gettime
-calls. This gives up to 20% overall performance on the some operation systems, which using libstdc++ without vDSO (for example, on Centos7) - [fea] Updated bundled libbactrace to support DWARF-v5 debug info format
- [fix] Fixed indexes/count cache drop on the indexes config update
- [fea] Optimized handling of the unknow fields in the Go binding (in cases, when some field exists in the database, but not in the go-struct)
- [fea] Updated Redos build/deploy image to v3.3.4
- [fea] Added Prettify feature to the SQL editor
- [fea] Made yarn upgrade
- [fea] Added Cache settings to the NS config
- [fea] Made the new UI component for the pagination
- [fea] Added tooltips with the UTC dates for the timestamp dates in the Grid view of the Namespace
- [fea] Added redirect to the created NS
- [fea] Added new settings to the Full text config
- [fea] Added Stop Words list to the Full text index
- [fea] Improved layout of the Stop words and Synonyms lists
- [fix] Fixed columns enabling/disabling in the Grid views
- [fix] Fixed issue related to the previously NS current columns displaying for the NS
- [fix] Fixed issue related to the empty config opening
- [fix] Fixed issue related to the pagination on the Query result page
- [fix] Removed eslint popup
- [fix] Fixed "see & edit" link on the Queries Perfstats page
- [fix] Fixed tooltips view
- [fix] Fixed
COUNT()
for fulltext queries, whenpreselect_before_ft
is enabled in the index config - [fix] Fixed
LIMIT
/OFFSET
behavior forMERGE
-queries, whenpreselect_before_ft
is enabled in the index config - [fix] Disabled in-memory WAL for the system namespaces
- [fix] Improved transactions replication via WAL queries: from now transactions will not be splitted into separate insert/updates on the follower
- [fix] Fixed the Check request
- [fix] Added bottom padding to the Performance Updates chart
- [fea] Added
explain
results for the subqueries - [fea] Added support for limit/offset in
Delete
andUpdate
queries - [fea] Optimized ordered indexes' cache logic to achive more cache hits and more compact cache size
- [fea] Added support for
COUNT_CACHED(*)
/CachedTotal()
aggregation in the queries with INNER JOINS. Now it's possible to cache total count results for such queries - [fix] Fixed SQL parsing for combinations of the subqueries and other conditions in the main query
- [fix] Fixed select functions with '.' delimiter. Previously those functions actually expected '=' as a delimiter
- [fea] Reworked logic for the stop-words. More details
- [fea] Added config for the base ranking algorithm. Check
bm25_config
field in the fulltext settings
- [fea] Fixed sync logic to allow modification of the server's ID at runtime
- [fix] Fixed SQL suggests for subqueries and certain types of JOIN-queries
- [fea] Base docker image was updated to alpine 3.19
- [fix] Fixed dependencies and build for alpine 3.15+
- [fix] Fixed Release build with GCC 13.2
- [fea] Added the subqueries field to the explain mode
- [fea] Upgraded Webpack to 5.х
- [fea] Added the default values to the NS config during the mode changing
- [fix] Fixed the message about the outdated browser version after Chrome upgraded to v120.
- [fix] Fixed the settings panel layout on the Performance page, which was overlapped by the message about the outdated browser version
- [fix] Fixed the table columns auto resizing
- [fix] Fixed the table header width issue that appeared on the table resizing
- [fix] Fixed the table layout that crashed on scrolling
- [fix] Fixed the empty space between the last NS and the Total section on the Memory page
- [fix] Fixed the title changing on the NS page during a new NS creating
- [fix] Fixed the tooltip position in the sidebar menu
- [fix] Fixed the "+" button for the Expire after field
- [fea] Added subqueries support (
explain
for subqueries will be implement in the next releases) - [fea] Added backtraces/minidump support for Windows platform
- [fea] Added query crash tracker support for Windows platform
- [fix] Added explicit error for aggregations in joined queries
- [fix] Fixed UPDATE-queries for array-indexes with multiple JSON-paths
- [fix] Fixed UPSERT/UPDATE for sparse arrays with null-values
- [fix] Optimized tagsmatcher's updates in UPDATE-queries
- [fea] Added some temporary replication fixes for v4-compatibility (one of the next v4 releases will contain v3-v4 compatibility mode for migration)
- [fea] Added HTTP DSL for subqueries
- [fea] Added Go API and DSL-convertor for subqueries
- [fea] Changed CJSON-to-object convetrion logic for slices: now the single JSON values and fields with multiple JSON-paths will be concatenated together in the target field
- [fea] Added
WithStrictJoinHandlers
. This option allows to validate JoinHandlers usage in runtime - [fix] Fixed panic handling in the CJSON deserialization
- [fix] Fixed logging in
cproto
-binding. Error messages will no longer be redirected to stdout instead of user's logger
- [fea] Saved the scroll position on the sorting
- [fea] Changed the Server ID range
- [fea] Improved the notification about the supported browsers
- [fea] Added the default values to the config form when the default config is using
- [fix] Fixed the wrong redirect to a fake database
- [fix] Fixed the column order changing on the data sorting
- [fix] Fixed the horizontal scroll on the data sorting
- [fix] Fixed the wrong data filtering in the Statistics tables
- [fix] Fixed the modal window with the notification about the JSON-tags clearing
- [fix] Fixed the "+/-" buttons for the inputs
- [fix] Fixed the console issue appeared on the array data sorting
- [fix] Fixed the layout of the Performance page
- [fix] Fixed the pagination buttons
- [fix] Fixed the misprint in Config
- [fea] Added crash query report for Update/Delete queries
- [fea] Added configs for LRU index cache size (check section
cache
in thenamespaces
entity of the#config
-namespace) - [fea] Optimized CJSON deserialization
- [fea] Optimized WAL size (unchaged indexes and schemas will not be added into the WAL anymore)
- [fea] Added atomic rollback for multiple field UPDATE-queries in case of errors during query execution (currently it is atomic on the level of the individual document)
- [fix] Fixed column indexes optimization (some of the comparators have become noticeably more effective)
- [fix] Added PK check for UPDATE-queries
- [fix] Fixed JOINs on composite indexes
- [fix] Fixed select functions with MERGE queries for cases when the same namespace is merged multiple times
- [fix] Fixed non-indexed string/int fields convertion on index creation in cases when index type is not equal to the field type
- [fix] Disabled leveldb's log files (in rare cases those logs could lead to the problems with storage reopenning)
- [fix] Disable background indexes optimization for the temporary namespaces
- [fix] Removed attempts to reopen storage with flush errors befors it's destruction
- [fix] Some of the storage flushes were moved outside of the unique namespaces lock
- [fix] Fixed directories deletion for Windows
- [fea] Reduced memory consumptio for online-updates
- [fix] Fixed updates size calculation during max allowed updates size check (now it checks actual allocated memory, not the data size)
- [fix] Namespaces config applying after FORCE-sync replication
- [fix] Fixed some rare tagsmatcher conflicts in replicated namespaces in case when namespace was not replicted previously and had some data in it
- [fix] Fixed some unnecessary force syncs after go clients connection
- [fix] Fixed documents duplication after PK change in UPDATE-query
- [fix] Fixed logical race in cascade replication resync
- [fea] Added support for UNIX domain sockets for RPC-server. Disabled by default (check
urpcaddr
-flag in server's config) - [fea] Added support for default timeouts in HTTP-server (support for
http-write-timeout
andhttp-read-timeout
options in server's config) - [fea] Added support for
Request-Timeout
header in HTTP-requests to setup individual timeout for each request
- [fea] Added support for UNIX domain sockets (dsn format:
ucproto://<socket_path>:/<dbname>
, example:ucproto:///tmp/reindexer.sock:/my_db
)
- [fea] Added support for UNIX domain sockets in cproto-binding (dsn format:
ucproto://<socket_path>:/<dbname>
, example:ucproto:///tmp/reindexer.sock:/my_db
) - [fix] Fixed deadlock in
EnableLogger
method betweenn Go and C++ mutexes
- [fea] Added the ability to use hot keys to navigate over the UI
- [fea] Added the link to the documentation to the left bar menu
- [fea] Changed the column filter with the case sensitive one
- [fea] Added validation of the JSON paths field to the Index Config page
- [fea] Added the wal_size field to the Namespace config
- [fea] Added the preselect_us and field_type sections fto the Explain page
- [fix] Fixed the horizontal scroll for the Grid view
- [fix] Fixed the data sorting on the Items page during the namespace changing
- [fix] Fixed the "undefined items" error during the db changing
- [fix] Fixed the console issues for the ttl index
- [fix] Made the Namespace refactoring
- [fix] Fixed the operations with the last column for the Grid view
- [fea] Added support for almalinux-9 builds in dependencies.sh
- [fea] Added background namespaces deleteion. Previously in some cases atomic transactions could cause the namespace's deletion in the querie's execution thread, which lead to the latency spike
- [fea] Added locks and flush timings for UPDATE and DELETE queries into slow log
- [fea] Added support for the COUNT/COUNT_CACHED aggregations for the MERGE-queries
- [fea] Added basic support for the SUM/MAX/MIN aggregations for the MERGE-queries without LIMIT/OFFSET
- [fea] Added more information about JOINs condtitions injection into
explain
(checkon_conditions_injections
field in the explain results) - [fea] Added
field_type
into theexplain
. This fields shows, which kind of field/comparator was used in the query:indexed
ornon-indexed
- [fea] Added support for store (
-
) UUID indexes - [fea] Optimized string<->UUID convertions in the C++ library
- [fix] Fixed
total_us
time calculation in theexplain
(previouslypreselect
time was in the explain results, but was not counted in thetotal_us
field) - [fix] Fixed JOINs conditions injection for the queries with multiple JOINs. Previously this optimization could skip some of the JOIN queries
- [fix] Fixed multiple UPDATE arrays concatenation issues: empty arrays, string array, array with scalar, etc.
- [fix] Composite indexes over the other composite indexes were explicitly disabled
- [fix] Fixed check for nested JOINs and MERGEs (nested JOIN/MERGE is not allowed)
- [fix] Multiple JSON-paths were explicitly disabled for the scalar indexes (multiple JSON-paths are allowed for composite and array indexes only)
- [fix] Fixed crash on the CJSON deserialization for array indexes with multiple JSON-paths
- [fix] Fixed handling of the updates buffer overflow (previously this logic may lead to multiple extra resyncs)
- [fea] Added experimental support for Armenian, Hebrew, Arabic and Devanagari alphabets (prefixes/postfixes/suffixes search, typos, stop-words and synonyms are supported)
- [fix] Fixed SSE4.2 support check on startup (server has to print error message if SSE support is required for the current build)
- [fix] Fixed DELETE-queries compatibility between
reindexer_server v3
andreindexer_tool v4
in cproto mode - [fix] Fixed RPC-timeout handling (extra check for unread data wasd added). Previously connect could be dropped in case of the some very long queries
- [fea] Optimized string<->UUID convertions in the Go bindings
- [fea] Default balancing algorithm for
cproto
was changed from RoundRobin to PowerOfTwoChoices. RoundRobin may still be enabled viaWithConnPoolLoadBalancing
option of the binding - [fix] Fixed transactions
Commit
/Rollback
stucking in case of the incomatible items' sctructs in client and DB - [fix] Fixed
builtinserver
logger initialization in cases when single app run multiple instances of thebuiltinserver
- [fix] Fixed RPC-connections background pinging (Ping requests became asynchronous)
- [fix] Fixed build with GCC 13.2
- [fea] Changed the numeric values position in the Grid
- [fea] Added the ability to use spaces for JSON paths
- [fix] Fixed the Statistics chart for undefined replication.wal_size
- [fix] Fixed the column set for the namespace items during the namespace switching
- [fix] Fixed the JSON paths view for values included spaces
- [fix] Changed the value format for width on the integer for sqlquery
- [fix] Fixed the bug related to the query history on the Namespace Items list
- [fix] Fixed the column titles in the table settings menu on the Performance page
- [fix] Added the validation of the negative values for the index settings
- [fea] Increased max indexes count for each namespace up to 255 user-defined indexes (previously it was 63)
- [fea] Added more info to the slow logger's output: mutexes timing for transactions and basic
explain
info forselect
-queries - [fea] Improved logic of the cost evaluation for the btree indexes usage in situations, when backgroud indexes ordering was not completed (right after write operations). Expecting more optimal execution plan in those cases
- [fix] Changed logic of the
ALLSET
operator. NowALLSET
condition returnsfalse
for empty values sets and the result behavior is similar to MongoDB $all - [fix] Fixed automatic conversion for numeric strings with leading or trailing spaces (i.e. ' 1234' or '1234 ') into integers/floats in
WHERE
/ORDER BY
- [fix] Allowed non-unique values in forced sort (
ORDER BY (id,4,2,2,5)
). If forced sort order contains same values on the different positions (i.e.ORDER BY (id,1,2,1,5)
), then the first occurance of the value will be used for sorting - [fix] Added limits for the large values sets in the composite indexes substitution algorithm, introduced in v3.15.0 (due to performance issues in some cases). If the result size of the set is exceeding corresponding limit, reindexer will try to find another composite index or skip the substitution
- [fea] Added support for JOINs and brackets into JSON DSL wrapper
- [fea] Added support and deploy for Debian 12 (bookworm). Debian 10 (buster) build was deprecated
- [fea] Enabled SSE4.2 for the default reindexer's builds and for the prebuilt packages. SSE may still be disabled by passing
-DENABLE_SSE=OFF
tocmake
command
- [fea] Changed the scale window icon for textareas
- [fea] Added the background color to the Close icon in the search history on the Namespace page
- [fea] Improved the buttons' behavior on the Query builder page
- [fea] Added the database name size limit.
- [fea] Improved the drop-down section behavior on the Query builder page
- [fea] Added new proc settings to the Index config
- [fix] Fixed the columns' settings resetting after the Perfstats page reloading
- [fix] Removed the double requests on the Perfstats page
- [fix] Fixed the JSON Paths tooltip description
- [fix] Fixed the pie chart position in Safari
- [fix] Fixed the popup window size for the long text
- [fix] Fixed the bottom padding on the statistics legend window
- [fix] Fixed the modal window to inform about disabled memory statistics
- [fix] Fixed the filter removal
- [fix] Fixed the filter result page when the filter is removed
- [fix] Fixed the redirect to the wrong page after all items were removed
- [fea] Optimized namespaces' locks for queries to the system namespaces, containing explicit list of names (for example,
SELECT * FROM #memstats WHERE "name" IN ('ns1', 'nsx', 'ns19')
now requires shared locks for the listed namespaces only) - [fea] Added update queries for the arrays of objects (i.e. queries like
UPDATE ns SET object_array[11].field = 999
) - [fea] Added more fulltext index options for the base rankings tuning. Check
FtBaseRanking
struct in the config doc - [fix] Fixed update queries for the sparse indexed arrays
- [fix] Fixed selection plans and cost calculation for
NOT
-conditions in queries - [fix] Disabled composite indexes over non-indexed fields (except fulltext indexes) and sparse composite indexes. Previously those indexes could be created, but was not actually implemented, so queries with them could lead to unexpected errors
- [fix] Fixed merging of the conditions by the same index in queries' optimizer (previously it could sometimes cause SIGABORT in case of the empty resulting set)
- [fix] Disabled LIMIT for internal merged queries (it was not implemented and did not work properly on previous versions)
- [fix] Fixed cache behavior for fulltext queires with JOINs and
enable_preselect_before_ft: true
- [fea] Optimized perfstats config access
- [fea] Added support for CSV results for select queries via HTTP (experimental, probably this API will be modified later on)
- [fea] Added
SortStPointDistance
andSortStFieldDistance
(simplified aliases for the long constructions withST_Distance
) - [ref] Added
reindexer.Point
type instead of[2]float64
- [fea] Added support and deploy for RedOS 7.3.2
- [fea] Added UUID field type for indexes
- [fix] Fixed fulltext areas highlighting for the queries with prefixes/suffixes/postfixes
- [fix] Fixed segfault on max unique json names overflowing
- [fix] Dissalowed system namespaces deletion/renaming
- [fea] Added support for OpenTelemetry traces. Details
- [fea] Added prometheus client-side metrics. Details
- [fix] Fixed bool value parsing/validation in DSL package
- [fea] Added the Namespace name length limitation
- [fea] Added the UUID Index type
- [fea] Added the notification about doubles in the Query Builder filter
- [fix] Fixed the scroll in the Index table
- [fix] Fixed the empty table in Statistics->Memory
- [fix] Removed the select_functions parameter from the JSON preview of Query Builder
- [fix] Fixed the URL clearing after clicking by opened Namespace tabs
- [fix] Fixed the Memory table layout
- [fix] Fixed the console errors on the replication config page
- [fix] Fixed the column displaying for the Query -> Facet request
- [fix] Fixed the synonyms displaying for the UI view
- [fix] Fixed the console errors on the namespace pin icon clicking
- [fix] Added the bottom padding to the legend of the Statistics
- [fix] Fixed the NavigationDuplicated console error on the pagination using on the Queries page
- [fea] Improved typos handling agorithm for
text
-indexes. New options:max_typo_distance
,max_symbol_permutation_distance
,max_missing_letters
andmax_extra_letters
were added - [fea] Improved composite indexes substitution. Now optimizer is able to find composite index' parts on almost any positions in query and choose the largest corresponding composite index if multiple substitutions are available
- [fea] Improved sorting by fields from joined-namespaces (for
inner joins
). Added support for string types and improved conversion logic (previously this type of sorting were able to sort only numeric fields) - [fea] Added more options for
snippet_n
:with_area
,left_bound
andright_bound
. Details - [fix] Fixed handling of update-queries (with
set
), which tried to update non-existing array element. Now those queries will return error and will not change target array-content
- [fea] Added support for non-string map keys for msgpack decoded (positive and negative integer values may be used as tag names in msgpack messages now)
- [fea] Added
OptionConnPoolLoadBalancing
. This options allows to chose load balancing algorithm for cproto connections
- [fea] Automized filling the key field on the Meta creation page
- [fea] Added new fields to the full-text config
- [fea] Improved the layout of the Namespace renaming window
- [fea] Replaced the load more feature with the pagination one on the Connection and Queries pages
- [fea] Changed the "Close" button title with "Save changes" on the namespace page
- [fix] Fixed a few small issues on the Statistics page
- [fix] Fixed the onboarding pointer in the case of undefined namespace
- [fix] Fixed the namespace choosing on the page reloading on the Indexes and Meta tabs
- [fix] Improved UI for long values in the Add item window
- [fix] Fixed the layout of the error message on the Query page
- [fix] Fixed the notification about necessity of the statistics activation on the Memory page
- [fix] Fixed the index value with precept
- [fix] Fixed the console issue during the namespace switching
- [fix] Fixed the wrong namespace redirecting on the Horizontal bar and Pie chart in Statistics
- [fix] Changed the column title on the Performance page
- [fix] Fixed the spelling issues
- [fix] Fixed the Add Database action
- [fix] Fixed grammar in the "Query performance statistics is disabled" popup
- [fix] Fixed the database list layout when the list is big
- [fix] Changed the design of the tooltip appeared on the "Collapse the sidebar" icon
- [fix] Fixed the NavigationDuplicate console issue
- [fix] Fixed the issue with the Gear button on the Statistics -> memory page
- [fix] Reduced preselect limit for joined queries (previous values from v3.14.0 could cause some performance issues)
- [fix] Fixed cost calculation for 'between fields' comparators
- [fix] Improved namespaces loading order
- [fix] Fixed server connections drops after outdated Close() call from RPC-client
- [fix] Fixed 'SetSchema' RPC-call logging
- [fix] Enlarged stop attemtps before SIGKILL for reindexer service
- [fix] Fixed client connections drops after some of the queries time outs (CPROTO)
- [fix] Fixed minor issues with queriesperfstats and explain
- [fix] Fixed the visible field set storing for the same SQL queries
- [fix] Restored the Load more feature to the Connections page
- [fea] Reworked fulltext search for multiword phrases in quotes (check description here)
- [fea] Optimized database/server termination
- [fea] Improved and optimized suffix tree selection for terms from stemmers in fulltext index
- [fea] Optimized select queries with limit/offset and ordered index in conditions, but without explicit sort orders
- [fea] Changed weights for ordered queries with limit/offset and ordered index in
where
ororder by
sections - [fea] Improved performance for large joined namespaces
- [fea] Improved selection plan for non-index fields and optimized non-index field filtration
- [fea] Added snippet_n function for fulltext highlighting. It will get more functionality later on
- [fix] Fixed aggregation results for empty namespaces and non-existing fields
- [fea] Optimized aggregations results sending. From now all the aggregations results will be sent only once
- [fea] Changed aggregations interface to support optional aggregations results
- [fea] Added the information about supported browsers
- [fix] Fixed the column settings for the Statistics table
- [fix] Improved the Statistics UI
- [fix] Fixed the SQL -> truncate response
- [fix] Fixed the infinity requests to namespases on the Config page
- [fix] Fixed the validator of the tag field
- [fix] Fixed the error on the Explain page
- [fix] Fixed issues with the Position boost
- [fix] Replaced the step from 0.001 to 0.05 for input fields
- [fix] Fixed the sorting pointer icon on the Queries table
- [fix] Fixed collisions resolving in indexes hash map (worst case scenarious were significantly improved)
- [fix] Fixed errors handling for custom indexes sort orderes in case of incorrect sort_orders config
- [fix] Enlarged default fetch limit for cproto binding
- [fix] Fixed large join requests execution (with 10k+ documents in result)
- [fix] Fixed 'pretty' output mode (now reindexer_tool will not stuck on formating after request)
- [fea] Switched Fedora's versions for prebuilt packages to Fedora 36/37
- [fea] Added the bulk deleting items on the list
- [fea] Chnaged the lifetime of the editing form for the Item adding operation
- [fea] Replaced the Create new database label to the Choose a database in the main menu
- [fea] Forbade entering cyrillic symbols for DB and NS titles
- [fea] Added the ability to rollback to the default DB config
- [fea] Improved the filtering on the Namespace page
- [fea] Replaced the empty page with the inform message on the Meta page
- [fea] Disabled the Create NS button if none DB exists
- [fea] Added the ability to export the SQL result in CSV
- [fea] Added the settings of the slow requests logging to the NS config
- [fea] Fixed the ability to change the Item limit on the page if it exceeds the item total
- [fix] Fixed collapsing/expanding details for the list items after the page changing
- [fix] Changed the double quotes with the quotes for strings in json-view-tree
- [fix] Fixed the Index list displaying after the DB removing
- [fix] Fixed the filtered list of Namespaces on the Memory page
- [fix] Fixed the item list after removing of all items
- [fix] Added the redirect from a selected namespace to the index page during the DB changing
- [fix] Fixed boolean values displaying in the Grid view
- [fix] Fixed the displaying of the empty and fact result at the same time
- [fix] Fixed the redirect to the Explain page during loading new items on the List and Grid list on the QUERY -> SQL page
- [fix] Fixed the error appeared on the list resizing on the Query Builder page
- [fix] Fixed wrong sort order for unbuilt tree-indexes combined with unordered conditions (SET/IN/ALLSET)
- [fix] Fixed assertion for sparse indexes with multiple JSON-paths
- [fix] Fixed assertion for wrong CJSON tags in storage
- [fix] Fixed double values restrictions for JSON-documents (previously in some cases negative double values could cause JSON parsing exceptions)
- [fix] Fixed Query.Set method with arrays of objects and maps (now it calls SetObject in those cases)
- [fix] Fixed composit indexes fields update after new indexes addition
- [fix] Fixed SEGFAULT on string precepts
- [ref] Added version postfix to the modules' name (.../reindexer -> .../reindexer/v3)
- [fix] Allowed SET condition with 0 arguments in DSL query
- [fea] Added logging for slow queries and transactions (check
profiling.long_queries_logging
section in#config
-namespace)
- [fix] Fixed connections balancing and threads creation in default (shared) mode
- [fix] Fixed cleanup for balancing mode for reused connections
- [fea] Renewed the Onboarding UI
- [fea] Added the data-test attribute
- [fix] Fixed console errors appeared on hover for the Client cell in the Current Statistics
- [fix] Fixed the column width resizing on the page reloading
- [fix] Fixed disapiaring of the Item table part on the Namespace page
- [fea] Added background TCMalloc's cache sizes managment (this feature was also supported for Go-builtin, Go-builtinserver and standalone modes). Check
allocator-cache-*
section in server's config - [fix] Fixed handling of the
no space left
errors for asynchronous storage - [fix] Fixed and improved composite indexes substitution optimization in select-queries
- [fix] Fixed SEGFAULT on large merge limit values in fulltest indexes
- [fea] Added more info about the storages' states into prometheus metrcis
- [fix] Fixed precepts parsing in HTTP API
- [fea] Replaced the Scrolly component with the Vue-scroll one
- [fea] Added strings_waiting_to_be_deleted_size to Statistics -> Memory for NC
- [fea] Added tooltips to the action bar on the Namespace page
- [fea] Added a default value for Rtree type
- [fea] Added tooltips to the sidbar buttons
- [fea] Made visible the default options of namespaces
- [fea] Changed the Disabled view of the Resent button on the SQL page
- [fix] Fixed sending NULL value for max_preselect_part
- [fix] Removed the search bar from the Indexes page
- [fix] Fixed the title of the index editor
- [fix] Removed oldated libraries usage
- [fix] Fixed the Expand/Collapse actions for lists
- [fix] Fixed the Collapse all button on the Namespace page
- [fix] Fixed the Statistics menu pointer
- [fea] Add go.mod file with dependecies versions
- [ref] Cproto binding now requires explicit import of the
_ "github.com/restream/reindexer/bindings/cproto"
-module
- [ref] Move benchmarks into separate repository
- [fea] Improve conditions injection from joined queries into main query. This optimization now covers much wider class of queries
- [fea] Add parenthesis expansion for queries' conditions
- [fea] Switch yaml parser to more functional one
- [fix] Fix priority of
NOT
operations in queries (now it always has highest priority among all the others logical operations) - [fix] Fix race condition in indexes optimization logic
- [fea] Add support for separate connections threads by request
- [fea] Add support for large JSON-strings (larger than 16 MB)
- [fea] Add HTTP method to force drop of TCMalloc caches
- [fix] Fix SIGABORT after incorrect RPC query results' reuse
- [fea] Make the "Gear" button visible for tables
- [fea] Redesign the Statistics->Memory page
- [fea] Redesign the Statistics->Performance page
- [fea] Add the Namespace settings button to the Namespace list
- [fea] Add the ability to pin Namespaces in the Namespace list
- [fea] Redesign the feature of the column resizing
- [fix] Fix UI availability with DB config issues
- [fix] Fix the issue with Scrolly on the Statistics page
- [fix] Fix SEGFAULT in fulltext index after documents deletion
- [fea] Add
enable_preselect_before_ft
option for fulltext indexes. It allows to prioritize non-fultext indexes in query - [fix] Fix runtime index convertations (from
sparse
and tosparse
) - [fix] Fix fulltext index memstats race
- [fix] Fix query results overflow for large joined requests (in cases, when joined items count is more than 10 billions)
- [fix] Fix rare query results leak after request timeout
- [fix] Fix RPC connections leak after reconnect
- [fea] Add the
enable_preselect_before_ft
option to the fulltext indexconfig - [fea] Improve snackbars view
- [fea] Add the pagination instead of the 'load more' feature
- [fea] Improve the Precepts UI
- [fea] Add a message about ofline status on 500 server response
- [fea] Add the description of the 5хх codes to the message body
- [fix] Fix a misprint in the database config
- [fix] Fix the value array clearing
- [fea] Optimize selects with large id sets
- [fea] Optimize max index structures resize time on documents insertion/deletion/modification
- [fea] Add max highlighted areas setting for fulltext indexes (
max_areas_in_doc
andmax_total_areas_to_cache
) - [fix] Add some of the missing memory into #memstats
- [fea] Reduce allocations count for query result responses
- [fix] Fix assertion in RPC query results container
- [fix] Fix assertion on response buffer overflow
- [fix] Fix SEGFAULT in Go/JSON queries to WAL
- [fix] Server will clear unknown flags in cproto responses
- [fea] Increase cache lifetime for a number of resources
- [fea] Add
strict_mode
to config - [fea] Add
sync_storage_flush_limit
to config - [fea] Add new ft-index fields (
max_areas_in_doc
,max_total_areas_to_cache
,optimization
) - [fea] Add new fields in memory statistics (
index_optimizer_memory
,tracked_updates_size
) - [fea] Add server unavailability indicator
- [fea] Add parsing error messages from responses with 500 status code (for error log)
- [fix] Fix uptime indicator behavior
- [fix] Fix labels and table filters views in the Statistics tab
- [fea] Optimize fulltext index
- [fea] Add optimization mode for fulltext index (Memory or CPU. Check ft index configs)
- [fea] Optimize unordered facets (ordering was disabled by default)
- [fea] Optimize storage reading on startup (multithread storage reading)
- [fea] Optimize storage flush (write locks will not affect storage flush anymore)
- [fix] Fix conflict in idset and composite index merge optimizations
- [fix] Fix the NavigationDuplicated issue
- [fix] Fix the limit in the request of the items on the SQL page
- [fix] Fix timed out query results reuse
- [fix] Fix exception handling on connection drop
- [fea] Add numeric fields names support in sort expressions
- [fea] Add optional counting mode for index updates tracker
- [fix] Fix temporary namespaces bloat by replicator in case of namespace creation error
- [fix] Fix timeout and strict mode logic in transaction queries
- [fix] Fix ALLSET for non-index fields
- [fix] Fix forced sort parsing/encoding
- [fea] Add idle timeout for inactive query results
- [fea] Add fields filter support for joined queries in queries DSL
- [fix] Fix cproto
Status()
update, when remote server becomes available
- [fea] Add line numbers output in case of errors in dump handling (while performing restoration)
- [fea] Add new values to the condition list on the Query Builder page
- [fea] Add the Return back button to the second level of the Statistic table
- [fea] Add the Loader icon for heavy requests
- [fea] Change the full-text config
- [fea] Add the logging of the error messages
- [fea] Add the action disabling for the Add button in the JSON editor when an syntax error is detected
- [fix] Fix filters on the Query builder page
- [fix] Fix the pagination issue on the SQL page
- [fix] Fix the Namespace settings button position during the browser window resizing
- [fix] Fix the NavigationDuplicated issue
- [fix] Fix the auto scrolling page up during the infinity scrolling of the data table
- [fix] Fix the cursor position during the index creating
- [fix] Fix the incorrect redirect to the Explain tab from the List/Grid view on the SQL page
- [fix] Fix sigabort after querie's filters merging
- [fix] Fix crash query report for joined queries
- [fix] Fix SQL parsing for numeric field names (in update-queries and in filter conditions)
- [fea] Add the 'More' button for the long text fields on the List view
- [fix] Exclude the es5-ext library
- [fea] Optimize composite fulltext indexes rebuilding. Composite ft index will not be rebuild after update, if non of the index's parts were actually changed
- [fea] Add current query to backtrace for builtin/builtinserver modes
- [fix] Fix string copying for array indexes
- [fix] Fix ALLSET keyword parsing for SQL
- [fea] Improve
explain
representation for queries with joins - [fea] Add 'copy' button for fro json preview in Query Builder
- [fix] Fix floating point numbers' behavior in numeric inputs in 'config' tab
- [fix] Fix 'x' button in 'meta' tab
- [fix] Fix type in 'partitial_match_decrease' field in index config
- [fea] Now time in TTL indexes may be changed without index deletion/recreation
- [fea] Improve
equal postion
(add support for OR operator in combinations withequal position
)
- [ref] Change
equal position
format in HTTP Query DSL (incompatible with oldequal position's
format`)
- [fea] Improved the aggregation result UI
- [fix] Fixed scrolling on the Indexes and Meta pages in Firefox
- [fix] Fix segfault on max indexes count constraint check
- [fix] Fix segfault on composite indexes replication (in some corner cases)
- [fix] Fix assertion on joins by non-index fields
- [fix] Fix incorrect time counting for left joins in explain
- [fix] Fix build with clang 13.0
- [fix] Fix index cache invalidation after items modification
- [fix] Fix heap-use-after-free in 'delete *' query
- [fix] Fix the undefined fields for the "List" view
- [fix] Fix the kebab menu for the "List" view
- [fea] Replace the list component
- [fix] Fix the issue related to namespace settings
- [fix] Fix the issue related to the "Statistics -> Performance" and "Statistics -> Queries" settings
- [fix] Fix the issue with the "load more" button for the "Aggregations" and "Explain" sections
- [fix] Fix the issue with the empty popup during the index editing
- [fea] Allow comparison between fields in queries' filters
- [fea] (BREAKS COMPATIBILITY) More strict SQL syntax: composite indexes must be enclosed in double quotes and string literals - in single quotes
- [fix] Fix inner joins for sparse indexes
- [fix] Fix memory corruption on item modify, when json had some whitespace symbols at the end
- [fix] Fix default behaviour for joins optimization from v3.2.4 and add more settings for it in #config
- [fix] Fix build for msvc 14.29.30133
- [fix] Fix doc for FT-rank
- [fea] Add settings for inner join optimization to NS config
- [fix] Remove ‘id’ from the ‘Also create primary key index (id)’ label
- [fix] Fix the wrong message during the item editing
- [fix] Fix building in directories, containing dots (also fixes homebrew installation)
- [fea] Add e2k support
- [fix] Fix memory leak in SetObject for non-index fields
- [fea] Optimize join queries with filters in both main and joined query
- [fix] Fix join queries SQL serialization
- [fix] Fix join queries with '<', '<=', '>' and '>=" operators in join condition
- [fix] Fix \quit command
- [fea] Changed position of the Config menu for Namespaces
- [fix] Changed the log level input with selector
- [fea] Added the possibility to keep synonyms with spaces
- [fix] Removed excess requests in the tutorial
- [fix] Fixed the message popup position
- [fea] Changed the first item in the list view with namespace_<pk_name>_<pk_value>
- [fix] Fixed the set of columns on Statistics after forwarding from a Namespace
- [fix] Fixed the displaying of the enabled columns on Statistics -> Performance
- [fix] Fixed the format of the "start-time" value on the index page
- [fix] Fixed the scroll that appeared on the SQL page after enabling the disabled columns
- [fix] Fixed the long-name issue in the popup of the namespace deleting
- [fix] Fixed indexes for client stats
- [fix] Fixed optimization cancelling for concurrent queries
- [fix] Do not rebuild composite indexes after update
- [fix] Removed TSAN suppressions for tests
- [fea] Added tooltips to Grid columns
- [fea] Changed the DB Config menu position
- [fix] Fixed the issue with an empty table appearing on the Query result page after another query applying
- [fea] Added the ability to create PK during the Namespace creation
- [fix] Removed incorrect functions of editing and deleting items on the SQL result page
- [fix] Fixed the issue with the "Top-up" button
- [fix] Fixed the 'Desc' sorting on Statistics -> Grid
- [fix] Fixed the issue with losing a namespace focus during tabs changing
- [fix] Performed yarn upgrade
- [fix] Fixed the issue with the sorting params keeping
- [fix] Fixed the issue with case sensitive field names during the grid building
- [fix] Fixed the issue with slow 3g in the Namespace list
- [fix] Fixed the "Default stop words" option on the "Add index" form
- [fix] Fixed the issue with the full-text config and full-text synonyms definition config areas on the "Add index" form
- [fix] Fixed the table settings displaying
- [fix] Fixed the converting from timestamp to human-readable date
- [fix] Fixed issues appeared after the bootstrap upgrade
- [fix] Fixed the issue with the grid building appeared for indexes with multiple JSON paths
- [fea] Optimize string refs counting for wide-range queries
- [fix] Fix merge limit handling for deleted values in fultext index
- [fix] Fix cascade replication for nodes without storage
- [fix] Fix sorted indexes update
- [fix] Fix authorization for http update sql-queries and schema getters
- [fix] Fix pprof segfault during CPU profiling of builtin/builtinserver
- [fix] Fix special characters escaping in asm files regexp
- [fea] Added optional fulltext index warmup after atomic namespace copy (EnableWarmupOnNsCopy)
- [fix] Fixed assertion on namespace reconfiguration, while force-sync is in progress
- [fix] Fixed fulltext index rebuilding after max_typos config update
- [fix] Fixed sort by expression in joined queries
- [fix] Fixed numeric strings handling (for cases, when value is greater than "2147483648")
- [fix] Fixed assertion in upsert with multiple jsonpaths (now it returns error instead)
- [fix] Fixed indexing for null-value
- [fea] Covered more text representation for huge numbers in fulltext search
- [fix] Fixed sigabort on remote's server disconnect
- [fix] Collate mode became required for the 'string' field type only
- [fea] Added enable_warmup_on_ns_copy option to the full text index
- [fix] Fixed issue with the namespace config during database switching
- [fix] Slight design changes in the top menu and left sidebar
- [fix] Fixed type errors for Namespace -> Grid
- [fea] Added fields ranks summation syntax for fulltext queries
- [fea] Changed typos handling config for fulltext (new max_typos option)
- [fix] Fixed error handling for fulltext PK
- [fea] Added separate options for http and rpc threading modes
- [fea] Added option for max http request size
- [fix] Fixed dangling threads for http-connections in dedicated threading mode
- [fix] Fixed sigabort in \bench
- [fix] Fixed double requests during the sorting in the Performance table.
- [fea] Changed the step of the Bm25 weight option
- [fea] Changed max_typos_in_word to max_typos
- [fea] Added the sum_ranks_by_fields_ratio option
- [fea] Changed data type to integer for max_typo_len and max_rebuild_steps
- [fix] Disable dedicated threads mode for HTTP-server
- [fea] C++17 is now required to build reindexer from sources
- [fix] Fixed segfault in fulltext query with brackets
- [fix] Fixed deadlock in selecter in case of concurrent namespace removing
- [fix] Fixed true/false tokens parsing inside query to composite index
- [fea] Optional dedicated threads mode for RPC and HTTP server
- [fix] Fixed heap use after free in concurrent requests to HTTP server
- [fix] Fixed stack use after free on RPC client disconnect and server shutdown
- [fix] Fixed bug on Statistics -> Performance -> Selects/Updates
- [fix] Fixed default config for join_cache_mode
- [fix] Centered table data
- [fea] Design changes on Performance statistics
- [fix] Limited responsive layout by 1280px
- [fea] Design changes for DB creation
- [fea] Added DB name to DB removing UI
- [fea] Added extra actions to Reset to default config and Save changes buttons
- [fea] Added samples to namespace search panel
- [fix] Replaced color for rtree tips on Indexes
- [fix] Changed font to Hack for code in popups
- [fix] Removed sorting from Query table
- [fix] Fixed Load more error on Query -> SQL
- [fix] Fixed zero value displaying in Grid view
- [fix] Fixed hot-key S for SQL query on tablets
- [fix] Fixed scroll issue for tables
- [fix] Bug in full text query with single mandatory word fixed
- [fix] Bug in query with condition ALLSET by nonindexed field fixed
- [fix] Bug in query with merge and join by the same namespace fixed
- [fix] Simultaneous update of field and whole object fixed
- [fix] Build on aarch64 architecture fixed
- [fix] Fixed replication updates limit trackig, and possible inifity full namespace sync
- [fix] Fixed web face page corruption on Windows builds
- [fea] GRPC module included in docker container and enabled by default
- [fix] Select with DISTINCT by GRPC fixed
- [fix] Fix for removing a single database
- [fix] Increased the edit label width of the index row
- [fea] Added the server configs to the homepage
- [fea] Added relevance between "Fields specific config" and "JSON paths" fields
- [fix] Upgraded Lo-Dash to the last version.
- [fix] Changed the font style of the "Create new database" menu.
- [fix] Start of reindexer with DB containing indexes with invalid names fixed
- [fix] Mandatory terms with multiword synonyms in fulltext queries fixed
- [fea] Verification of EQUAL_POSITION by the same field added
- [fea] Added new syntax for update of array's elements
- [fea] Impoved verification of fulltext index configuration
- [fea] api/v1/check returns more information
- [fea] GRPC module moved to dynamic library
- [fea] Call of Go signal handler improved
- [fix] Fixed the tables sorting
- [fix] Limited the modal window width
- [fix] Fixed the Statistics -> Queries view
- [fix] Fixed the horizontal scroll for /statistics-memory_stats and /statistics-perfstats
- [fix] Fixed the memory issue for big data
- [fea] Changes for the full-text config
- [fea] Added new fields to the Clientstats
- [fea] Added the ability to save column set for tables
- [fix] Crash on full text query with empty variants
- [fix] Race namespace caches on transactions with atomic ns change
- [fix] Race on force sync replication
- [fea] Improved position search in fulltext
- [fea] Improved timeouts handling in select operations
- [fea] Added support for Content-Encoding: gzip in http server
- [fix] Build builtin/builtinserver on mingw
- [fea] Added tooltips to longest query
- [fix] Fixed the query view on the Query -> SQL page
- [fix] Added checking for unsaved data during the window closing
- [fix] Bug with the pagination in the List mode
- [fea] Added validation for the Server ID field
- [fea] Added validation for the positive value of the Cluster ID field
- [fea] Extra parameters added to fulltext config
- [fea] Validate PK index to be not scan, strict index names validation
- [fea] COUNT and COUNT_CACHED results added to aggregations results
- [fix] DISTINCT with 800k+ unique value execution time on Linux improved
- [fix] SQL representation of JOIN queries
- [fea] Optimize indexes before atomic transactions ns exchange
- [fea] Choose IN condition execution plan depend on another condition selectivity
- [fea] Added configurable size limit of online replication updates buffer
- [fix] Cascade replication fixes
- [fix] Shutdown time reduced
- [fix] Search by multi word synonyms is fixed
- [fix] Comparator performance issue of condition IN (many strings)
- [fix] List view performance issues
- [fix] Enable edit items in query results page
- [fea] Sort by distance
- [fea] Geo indexes performance improved
- [fix] Disable rename ns on slave
- [fix] Disable fulltext log in case loglevel is set to 0
- [fix] Overlap and possible assert on serial int32 overflow
- [fea] Added GRPC support. reindexer.proto
- [fea] Added reindexer version to prometheus metrics
- [fix] Decreased time of shutdown reindexer server with enabled prometheus
- [fea] Completely rewritten network cproto client
- [fix] reindexer.SetDefaultQueryDebug behavior fixed in case missed default namespace config
- [fea] Completely redesigned
- [fea] Added debug traces for Query and Iterator misuse. To enable tracer set REINDEXER_GODEBUG env
- [fix] Binary incompatibility of UpdateQuery with pre v2.14.0 fixed, except case with Update array with single element
- [fix] Binary incompatibility of SetSchema WAL Record with pre v2.14.0 fixed.
- [fea] Add geometry indexes support
- [fea] Add logs for current query in case of crash
- [fix] Fix secondary slave replication after main master restart
- [fix] Fix set and update methods for non-indexed array fields
- [fix] Fix select filters for aggregation functions
- [fea] Add protobuf schema generating and protobuf data handling
- [fea] Add upsert command to http-api
- [fix] Fix outdated namespace removing from prometheus stats
- [fix] Fix command execution iterrupts on SIGINT
- [fix] Disable replicator for reindexer_tool
- [fix] Fix objects cache size setting
- [fix] Fix Status()-call for cproto-connector
- [fea] Added extra parameter to clients stats
- [fea] Added update, delete, truncate statement in DSL
- [fix] Added support for equal_positions in sql suggester
- [fix] Crash on distinct whith composite index
- [fix] Crash on query whith incorrect index type after index conversion
- [fix] Crash on upsert array object as first json tag
- [fix] Cproto connection freezes if timeout occurs while reading from socket
- [fix] Crash on fulltext build, if typos map exceed 2GB
- [fix] Crash on DSL query with IN (string,...) conditions
- [fix] Cproto connection freezes on async transaction timeout
- [fea] WAL size settings via #config namespace
- [fea] WAL updates filtering
- [fea] Return error for queries with EqualPosition to fields with IS NULL condition
- [fea] Transactions HTTP API
- [fea] Add RPC-transactions limit for each connection
- [fea] More advanced JSON DSL validation for queries
- [fea] Items cache size limits setting
- [fix] Fix SEGFAULT on unauthorized builtin server
- [fix] Fulltext snippet location in text
- [fix] Unneeded force replication fixed
- [fix] Reset state on reconnect to different server
- [fix] Increased performance of queries with custom sort order
- [fix] Fixed behavior of SQL UPDATE statement with true/false/null values
- [fix] Do not reset expire_after value of ttl indexes after copying tx
- [fix] Error loading of system records (indexes/tags/replState) after copying tx
- [fix] To config added default value of
optimization_sort_workers
- [fix] Windows specific error with IN () condition executed by comparator
- [fea] Removed default limit=10 in GET :db/namespaces/:ns/items method
- [fea] Added
REINDEXER_NOREUSEIDLE
env var for disable server connection reuse
- [fix] Fixed async tx goroutines leak
- [fix] Crash with SEGV or assert on ordered queries after copying tx
- [fix] Correct normalization of SELECT COUNT(*) SQL queries
- [fea] More efficient replication startup on active master updates
- [fix] Namespace indexes optimization after load was not started
- [fix] Centos 7 build fixed
- [fea] Cascade replication
- [fea] MsgPack format support for query and updates
- [fea] Initial JsonSchema v4 support.
- [fea] Query strict mode support - Check indexes or fields names before query execution
- [fea] MsgPack format support for http and cproto
- [fea] Moved to separate repository
- [fix] Optimize indexes after ns load
- [fix] Correct Drop fields by json path
- [opt] Execution plan with wide IN condition to low selectivity indexes
- [fix] Fulltext search kb layout filter with symbols like ',' ']'
- [fix] Segfault with distinct on field with different types
- [fix] Behavior of --help command line argument
- [fix] Do not report error on restore exiting namespaces with compatible indexes
- [fix] Backtrace behavior with musl builds
- [fix] Turn cgo backtrace symbolizer off by default (fixes random crashes on go 1.14)
- [fix] Alpine linux build
- [fea] Output relevancy rank information to json format
- [fea] Optimized query to #memstats. Now it's O(1)
- [fea] Added app_name field #clientsstats
- [fix] Fixed SQL suggestion behavior on concatenated tokens
- [fix] Fixed and enabled multiple dsn support in cproto
- [fix] unexpected "terminate called"
- [fea] Fulltext - rank by word position
- [fea] Explain information improved
- [fix] Memory corruption on copying tx-es
- [fix] Fixed crash on query with joins
- [del] Removed useless "storage_enabled" flag from GET db/namespaces method response
- [fea] Query builder refactored
- [fea] New document page now modal
- [ci] Ubuntu 20.04 build added
- [rev] Disabled multiple dsn support in cproto
- [fix] Requests with general sort and offset without limit can produce wrong sort
- [fix] Full text synonyms can not work after transactions
- [fea] More efficient arrays packing from json source
- [fix] NOT operator in full text queries
- [fix] Tuple memory leak on Update by condition
- [fea] Multi-word synonyms support
- [fix] Potential large memory allocation on DISTINCT queries
- [fix] Potential crash with aggregation on object fields
- [fea] Optional snappy network traffic compression
- [fea] OnWALUpdates now used shared buffers - can seriously decrease memory usage with many slave
- [fix] Replication fixes on bad network connections
- [fix] Connection ID overflow, and bad connID error fixed
- [fea] Added --createdb flag.
- [fea] Improved behavior while input is redirected
- [fix] Enable to create multiple instances of builtinserver
- [fea] Multiple dsn support in cproto
- [fix] Fixed precepts of new item
- [fea] Rename namespace feature
- [fea] Namespace config moved to dedicated page
- [fix] Wrong conn id full fix
- [fix] Full text search ranking with synonyms
- [fea] Distinct execution plan optimization
- [fix] Crash on incorrect json in config (array, when object expected)
- [fix] Crash on concurrent full text updates/selects
- [fix] Search by second field in full text, while term present in first field
- [fea] Multiple dsn support in cproto client
- [fix] Do not create users.yml in in-memory only mode
- [fix] Wrong conn id fix
- [fix] Hang on error in batch mode
- [fix] db name begins with cproto or builtin correct handling
- [fix] Hang on parsing recursive types references in struct
- [fea] Multiple distinct in single query using indexes
- [fix] Unload by idle timeout feature is disabled
- [fea] Update Query now can update object or array of objects
- [fea] Enable tx.Rollback after tx.Commit
- [fix] Crash on Upsert to tables with composite pk with non indexed fields as part of PK
- [fea] Stronger txID & queryID validation and isolation between clients
- [fix] Correct lsn & id invalidation after UpdateQuery
- [fea] Clients connection statistics added
- [fea] Enable tx.Rollback after tx.Commit,
- [fea] Added read tx.Query support
- [fea] Log warning about reindexer library and client mismatch
- [fix] Unmarshall []bool indexed fields
- [fix] Unsafe Query flag reset after recycle from sync.Pool
- [fea] DB.SetDefaultQueryDebug now copies default ns settings
- [fea] Synonyms feature in fulltext search
- [fea] New full_match_boost parameter in fulltext search
- [fix] last_updated_time of ns will not change on restart
- [fea] Enable server startup without storage
- [fea] Backward compatibility of tx replication with old reindexer versions
- [fix] Windows build
- [fea] Atomic applying transaction with namespace copy & replace
- [fea] Transaction performance statistics
- [fix] Equal position behavior fixed
- [fea] Sort queries by right namespace field
- [fix] UPDATE statement fixes
- [fix] Transaction replication fixes
- [fix] Select fields filter fix for right namespace
- [fea] web static resources are embeded to server binary by default
- [fix] Fixed backward compat of RPC with 2.5.2-
- [fea] Added rename namespace API
- [fea] Improved -dev package behavior
- [fix] Transactions memory consumption are seriously decreased
- [fea] Added
\namespace rename
command
- [add] Added HTTP API method /namespaces/rename
- [fix] Fixed docker image
- [fea] Auto pass list of detected C/C++ dependencies libraries to go
- [fea] Added RenameNamespace function
- [fea] Replication of transactions
- [fea] EqualPosition support in sql in dsl
- [fix] Forced sort fixes
- [fix] Distinct keyword fixes in sql-dsl parsers/encoders
- [fix] Sql auto-complete fixes
- [fix] Replication lsn mismatch fix
- [fix] Merge queries with joins fix
- [fix] Mac OS X table-view paging fix
- [fix] Fix: forced replication can lead to infinite loop
- [fea] Add .pkg file and autotest in -dev package
- [fix] Replication of meta in forcedSync
- [fea] Canceling of connecting to server if the deadline is expired
- [fix] Fix of incorrect paging when output to file or stdout redirection
- [fix] Fix of suggest of '<key word>'
- [fix] Do not lock preResult values if from cache fixed potential assert on queries with join with used join cache
- [fix] Fix assert in sort by composite indexes
- [fea] Add composite values parsing for SQL select
- [fix] Make circular accumulator for stddev performance statistic
- [fix] Fix unhandled exception while caclulating perf stat
- [fix] RawBuffer leak due to unclosed iterators in transactions
- [fea] Add '' as a special escaping symbol to FtDSL
- [fix] Merge-join queries fixes and optimizations
- [fix] Fix hit_count_to_cache overflow for idset cache
- [fea] Add master's config check on slave connect
- [fea] Disable automatic database creation on RPC-connect
- [fix] Add force-resync after online replication errors
- [fix] Fix lsn overflow after convertion to int
- [fea] Add replication status to memstats
- [fix] Joins optimizations
- [fix] cjson lock + deep copy performance fixes
- [fea] Sort by expressions
- [fea] Optimized lock time for joins with small preresult set
- [fea] Added more info about replication state to #memstat namespace
- [fix] LSN on row-based query replication (possible assert on server startup)
- [fix] Replication clusterID for namespaces without storage
- [fix] PK precepts replication
- [fix] Query results row calculation for http queries with limit
- [fea] Table pagination
- [fea] Queries cancellation
- [fix] Tags race on concurrent transactions
- [fix] Iterator.NextObj(): performance fix
- [fix] Fix of Windows build
- [fix] disabled OR operator for Fulltext indexes
- [fix] replication: using row records instead of statements for UpdateQuery/DeleteQuery (performance improvement)
- [fea] new statistics parameter: items count (for prometheus)
- [fix] UpdateQuery/DeleteQuery crash fix
- [fea] Cancelling queries execution by Ctrl+C
- [fea] Iterator.NextObj() unmarshals data to any user provided struct
- [fix] wrong WAL ring buffer size calculation on load from storage
- [fix] Make storage autorepair optional
- [fix] firstSortIndex assert on sort by hash indexes
- [fix] Possible deadlock on tx, if it is canceled by timeout
- [fea] Join optimization (use indexes from left ns, instead of scan) if possible
- [fix] Replication races fixes
- [fea] Atomic namespace replace on forced sync replication
- [fea] Try to auto repair storage if reindexer does not shutdown correctly
- [fea] Table mode output
- [fea] Added columns pre calculation for table output in GET /query request
- [fea] Added averaged cgo limiter usage statistics
- [fea] CGOSymbolizer added, output mixed go/c++ backtraces on crash
- [fea] Improved SQL editor component
- [fix] Fixed behavior of keyboard shortcuts
- [fix] Total count of update/select operation in perf stats
- [fix] Idset cache invalidation on upsert/delete null values to indexes
- [fix] Possible crash if sort orders disabled
- [fix] Wrong lowercasing field name on SQL UPDATE query
- [fea] Delete & Update queries in transactions
- [fea] Add command
databases
for operating with databases - [fea] Add suggestions for commands and databases names
- [fix] Replxx dependency reverted to stable version
- [fea] Using default dsn cproto:://127.0.0.1:6534/
- [fea] Delete & Update queries in transactions
- [fix] Fulltext queries sort by another field
- [fea] Number of background threads for sort optimization can be changed from #config namespace
- [fix] Sort optimization choose logic is improoved
- [fix] leak seq from chan
- [fix] check ctx.Done while waiting on cgo limiter
- [fea] More effective usage of btree index for GT/LT and sort in concurent read write operations
- [fix] Potential crash on index update or deletion
- [fea] Timeout of background indexes optimization can be changed from #config namespace
- [fea] User list moved from users.json to users.yml
- [fea] Hash is used insead of plain password in users.yml file
- [fix] Pass operation timeout from cproto client to core
- [fea] Updated behaviour of Or InnerJoin statement
- [fea] Store backups of system records in storage
- [fix] Replicator can start before db initalization completed
- [fix] Search prefixes if enabled only postfixes
- [fea] Added prometheus /metrics handler
- [fea] Fulltext config editor
- [fea] Quick copy item's JSON from list view
- [fea] Dynamic switch of replication role
- [fea] Facets by array fields
- [fea] JOIN now can be used in expression with another query conditions
- [fea] Support rocksdb as storage engine
- [fix] Race on concurent read from system namespaces
- [fix] Replication config sync fixed
- [fea] Add repair storage function
- [fix] Async tx goroutine fixed
- [fix] Replication in builtin mode fixed
- [fea] Reindexer server will not start if storage is corrupted,
startwitherrors
config flag is used to override - [fix] Do not write to WAL empty update queries
- [fix] Replication config sync
- [fea] Added two way sync of replication config and namespace
- [fea] Memory usage of indexes decreased (tsl::sparesmap has been added)
- [fea] Added non-normalized query in queries stats
- [fea] Add truncate namespace function
- [fix] Fixed unexpected hang and huge memory alloc on select by uncommited indexes
- [fix] Correct usage of '*' entry as default in namespaces config
- [fix] Memory statistics calculation are improoved
- [fix] Slave will not try to clear expired by ttl records
- [fea] Added requests execution timeouts and cancelation contexts
- [fea] Join memory consumption optimization
- [fea] Current database activity statistics
- [fea] Use composite indexes for IN condition to index's fields
- [fea] Reset perfomance and queries statistics by write to corresponding namespace
- [fix] Crashes on index removal
- [fix] Do not lock namespace on tx operations
- [fix] SQL dumper will not add exceeded bracets
- [fea] Added
updated_at
field to namespace attributes
- [fea] Added requests execution timeouts and cancelation contexts
- [fea] Added async tx support
- [fea] Removed (moved to core)
updated_at
legacy code
- [fix] sparse index crashes on type conflicts
- [fix] fixed memory stats for dataSize of string hash indexes
- [fix] possible crash on http meta update
- [fix] return back item data via cproto on UpdateQuery operation
- [fix] Build builinserver with libunwind conflict fixed
- [fix] Query.Update panic fixed
- [fix] Stronger check of namespace's item's type (PkgPath is included to check)
- [fea] Bracets in DSL & SQL queries
- [fix] Crash on LRUCache fast invalidation
- [fix] Relaxed JSON validation. Symbols with codes < 0x20 now are valid
- [fix] '\0' symbol in JSON will not broke parser
- [fea] Backtrace with line numbers for debug builds
- [fix] Replication fixes
- [fea] Support for jemalloc pprof features
- [fea] Detect tcmalloc pprof features in runtime
- [opt] Optimized memory statistics calculation
- [fea] Return back item after update with atomic on update functions
- [fea] Add timeout/deadline support
- [fea] Add *Ctx methods with context.Context
- [fea] Return back item after update with atomic on update functions
- [fea] Added table view of memory statistics
- [fea] Added red mark of error in SQL editor
- [fea] Facets API improoved. Multiply fields and SORT features
- [fea] TTL added
- [fea]
LIKE
condition added - [fea] Add expressions support in SQL
UPDATE
statement - [fix] Invalid JSON generation with empty object name
- [fix] Unneccessary updating of tagsmatcher on transactions
- [fix] LRUCache invalidation crash fix
- [fea] Added metadata maniplulation methods
- [fea] Added metadata maniplulation GUI
- [fix] Performance statistics GUI improovements
- [fea] Update fields of documents, with SQL
UPDATE
statement support - [fea] Add SQL query suggestions
- [fea] Add
DISTINCT
support to SQL query - [fea] Queries to non nullable indexes with NULL condition will return error
- [fix] Fixes of full text search, raised on incremental index build
- [fix] Queries with forced sort order can return wrong sequences
- [fix] RPC client&replicator multithread races
- [fix] DISTINCT condition to store indexes
- [fix] Caches crash on too fast data invalidation
- [fix] Disable execiton of delete query from namespace in slave mode
- [fix] Rebuild fulltext index if configuration changed
- [fix] Fixed handling SQL numeric conditions values with extra leading 0
- [fea]
Query.Update
method added - [doc] Updated documentation and mapping for system Namespaces struct
- [fix] Support of POD types derived custom types
- [fix] Added
MATCH
condition support (aliasEQ
) to DSL
- [fix] Report error if config file is not found
- [fea] Add
UPDATE
statement support
- [fea] Add SQL query suggest
- [fea] GUI for database configuration
- [fea] GUI and charts for performance and memory statistics
- [fea] Master-slave replication added (beta). Documentation
- [fea] Transactions support
- [fea] min/max/stddev values added to perfstat
- [fea] storage lazy load option added
- [fea] \subscribe command added
- [fix] int64 and double conversion in JSON parser loose precision
- [fea]
DELETE FROM
SQL statement added - [fix]
SELECT *,COUNT(*)
will not return items - [fix] Crash on condition with arguments of different type to same index
- [fea] Aggregation function name added to aggregations results
- [fix] Incorrect limit/offset calculation on queries with
SORT
by non indexed fields
- [fix] Struct verificator incorrect validation of composite
reindex
tags - [fea] Pool usage statistics added to
DB.Status()
method
- [fea] Added fields
namespaces
andenable_cache
to GET|POST /db/:db/query method
- [fea] Query builder added
- [fea]
Delete all
button added to items page - [fea] Aggregations results view
- [fea] Edit/Delete function of query results added
- [fea] JSON index configuration editor
- [fea] Memory usage statistics round precision
- [fix] Potential crash on delete from store string index
- [fix] Slow cache cleanup
- [fix] Print precision of double values decreased to actual double range
- [fix] Invalid http redirects, if compiled with -DLINK_RESOURCES
- [fix] Unhandled exception in case trying of create output file in unexisting directory
- [fix] RPC client optimizations and races fixes
- [fea] \bench command added
- [fea] Indexes rebuilding now is non blocking background task, concurrent R-W queries performance increased
- [fix] Fulltext index incremental rebuild memory grow fixed
- [fix] Logger buffer increased, and will not block on errors
- [fix] DELETE Query method fixed
- [fix] urldecode of database names fixed
- [fix] Pretty print fixed
- [fea] Incremental fulltext search index rebuild
- [fea] Async C++ RPC client
- [fix] Fixed incorrect behaviour with non indexed field conditions
- [fix] Extra non indexed fields tests added
- [fix] Json parser memleak fixed
- [fea] REST API documentation improoved
- [fea] Optimized performance
- [fea] Operation speed is improoved
- [fea] Added explain query feature
- [fea] Added min, max and facets aggregation functions
- [fea] Added EqualPosition query function
- [fea] In SQL query parser/printer added is NULL condition
- [fea] Native bool data type support
- [fea] Filter nested fields in SelectFilter statement
- [fix] Fix crash on comparator with Join queries
- [fix] Incorrect sort order using with Join queries in join cache optimization step
- [ref] Composite indexes now using json_paths for list of fields
- [ref] Storage format has been changed, and incompatible with this version. To migrate date from previous version use reindexer_tool
- [fea] reindexer.Status method added, to check connector status after initialization
- [fea] OpenNamespace now register namespace <-> struct mapping without server connection requiriment
- [fix] int type is now converted to int32/int64 depends on architecture
- [fea] Python connector v.0.0.1 is released.
- [fea] Added fields filter to method GET /api/v1/:db/:namespace:/items mathed
- [fea] Added method DELETE /api/v1/:db/query
- [fea] Added poll loop backend (osx,bsd)
- [ref]
json_path
renamed tojson_paths
, and now array - [ref] Binary cproto protocol has been optimized and changed. Please consider to update clients
- [fix] EnumMeta method has been fixed
- [fix] ModifyItem will retry attempt if tags <-> names state is invalidated
- [fea] Added EXPLAIN query stats view
- [fea] Added tags selector component for json_paths to index create/modify form
- [fea] Storing index configuration in storage
- [fea] Concurent R-W queries performance optimization
- [fea] Added indexes runtime performance statistics
- [fix] Incorrect NOT behaviour on queries with only comparators
- [fix] Race condition on shutdown
- [fix] Type conversion on queries without indexes
- [fea] Added public AddIndex/DropIndex/UpdateIndex methods
- [ref] ConfigureIndex method deprecated
- [ref]
appendable
logic has been moved from C++ core to golang connector - [fix] Multiple database support in
embeded
mode.
- [fix] Fixed restoring namespaces with index names non equal to json paths
- [fea] Merge with Join queries support
- [fea] Sort by multiple columns/indexes
- [fix] Case insensivity for index/namespaces names
- [fix] Sparse indexes behavior fixed
- [fix] Full text index - correct calculatuon of distance between words
- [fix] Race condition on concurent ConfigureIndex requests
- [fea] Added modify index method
- [fea] New builtinserver binding: builtin mode for go application + bundled server for external clients
- [fea] Improoved validation of go struct
reindex
tags
- [fea] Sparse indexes
- [fix] Fixed errors on conditions to unindexed fields
- [fix] Fulltext terms relevancy, then query contains 2 terms included to single word
- [fea] Customizable symbols set of "words" symbols for fulltext
- [fix] Incorrect behavior on addition index with duplicated json path of another index
- [fix] Fixed deadlock on linux
- [fix] Fixed \dump command namespace list parsing
- [fea] Added method /api/v1/check with system information about memory consumption, uptime and version
- [fea] Passing to RPC client information about version and uptime
- [fea] Optional embed web resources to server binary
- [fix] Incorrect urlencode for document update API url
- [fix] Namespace view layout updated, jsonPath added to table
- [fix] Fixed error after closing connection by timeout
- [fix] Caches invalidation on server restart
- [fea] Conditions to any fields, even not indexed
- [fea] cproto network client added
- [fix] Query execution plan optimizator fixes.
- [fea] Command line editor. tool has been mostly rewritten at all
- [fea] Interopertion with standalone server
- [fea] Pagination in the GET sqlquery HTTP method
- [fea] Filtration in the GET items HTTP method
- [fea] Table view of items page
- [fea] Filtration in the items page
- [fea] SQL queries history
- [fea] Added system namespaces #memstats #profstats #queriesstats #namespaces with executuin and profiling statistics
- [fea] Added system namespace #config with runtime profiling configuration
- [fix] Join cache memory limitation
- [fix] Fixed bug with cjson parsing in nested objects on delete
- [fix] 32 bit reference counter for records instead of 16 bit
- [fix] Crash on load namespaces from storage with custom sort order
- [fix] Crash on select from composite index, after delete last shared string copy for sub part of composite index
- [fix] Full text build threads limited to 8
- [fea] Load data in multiple threads on startup
- [fea] Auto rebalance connection between worker threads
- [fix] "Authorization" http header case insensitivity lookup
- [fix] Unexpected exit on SIGPIPE
- [fix] Namespaces names are now url decoded
- [fea] Ability to pass extra options to bindings
- [ref] cgo buffers cleanup optimization
- [fea] SQL parser performance improved
- [fea] Caching of intermediate join results
- [fix] Assert on error cjson parser disabled: server will not crash on application errors
- [fix] Relaxed check of fields type on index addition and loading from storage
- [fix] Potential field data corruption on runtime index addition
- [fix] Correct grow of input buffer for http and cproto connections
- [ref] HTTP parser and router refactored.
- [fix] gprof handlers fixes
- [fix] packages dependencies fixed, installation errors on centos fixes, path to webroot fixed
- [ci] added sanity tests of packages installations
- [fea] Checking for duplicate names in
json
struct's tags on OpenNamespace - [fea] Checking DeepCopy interface for correct return value on OpenNamespace
- [fix] Fixed error with sync payload types, on json queries
- [fix] Local imports of ./repo in benchmarks package broke gb
- [fix] path to queries API
- [fix] error on create indexes
- [fix] show 'new database windows 'in case of start without any databases
- [fea] Search digits by words representation (now only for Russian language) in ft1
- [fix] Forced flush all batched writes to disk on exit
- [fix] Incorrect total count for queries without where clause
- [fea] custom collate now accepts sequence of letters
- [fix] Build issues with clang 3.9
- [fix] Cmake build dependencies, leveldb and snappy optionally added as ExternalProject
- [port] Windows and BSD build
- [port] 32 bit build
- [fea] Ability to input/output dump from stdin/stdout
- [ref] Flags
create_if_missed
anddrop_on_format_error
are removed from namespaces API - [fix] Correct behavior on logging different loggers to the same file
- [fix] CPU profiler error in case of
- [port] Ability to run as Windows service and cmake Windows NSIS installer
- [fea] Removed cproto connector dependency on cgo
- [fea] cproto connector are compiled by default
- [fix] Fix KeyValue::operator == for strings (IdSetCache isn't worked due this)
- [fix] Describe for composite indexes will return name alias
- [fix] Check for invalid PK indexes: Throw error on '-' (scan) PK
- [fix] Add missed comma in IndexDef JSON serializer
- [fix] Relevancy in case when first term from query found in non boosted field first
- [opt] Optimize AND performance in ft1
- [fea] Add extra debug output to ft1
- [fix] Golang SQL query pseudo pre-parser accept all whitespace chars, not only ' '
- [fix] Correct composite PK handling in QueryTest
- [fix] Support of multiply index options in struct tag
- [fea] Support of custom letters order set for string collates
- [fea] Full text indexing memory consumption optimization
- [fea] Thread russian letter
ё
asе
in full text index - [fix] Fixed incorrect behavior of full text search with term
*<stop-word>
- [fix] Fixed full text behavior with FtDSL started with
+
- [fix] Fix conflict of with leveldb's and reindexer's tcmalloc library
- [fea] Added daemonize mode to reindexer_server
- [fix] init.d script fixes
- [fea] Added CPU profiling mode to built-in HTTP pprof server
- [fea] Support join, marge, aggregations in json DSL & SQL queris
- [fea] Added multiline form and comments in SQL query
- [fix] Last symbol of documents was not used by fulltext indexer
- [fix] Potential data corruption after removing index
- [fea] Batching of free c-buffers calls
- [fea] Added cgo limiter for deleteQuery call
- [fea] POST /api/v1/:db/sqlquery method
- [fea] Added sort_order to GET /api/v1/db method
- [fea] Composite indexes direct queries support
- [fea] Fulltext support functions
snippet
andhighlight
- [fix] Added utf8 strings validation
- [fix] WrSerializer::Printf incorrect buffer maxlen calculation
- [ref] utf8 collates does not allocate extra memory
- [ref] sort by unordered indexes optimizations
- [ref] Join queries optimizations
- [ref] Raise panic on Query reuse in Join
- [fea] Composite indexes direct queries support
- [fea] Write components logs to separate files
- [ref] Protocol breaking changes
- [fea] Added cmake package target for RPM & DEB based systems
- [fea] sysv5 initscript added
- [fea] Binary cproto RPC protocol introduced
- [fea] Graceful server shutdown on SIGTERM and SIGINT
- [fea] Multiply databases support was implemented
- [fea] HTTP REST API changed: db name added to path, optional HTTP basic authorization (disabled by default)
- [fea] HTTP REST API for add/drop indexes added
- [fea] Configuration moved to separate .yml file
- [ref] Item and Reindexer classes API has been redesigned. C++ tests was refactored to run with new API
- [fix] Potential race conditions and memory leak was fixed
- [fix] Fixed Query optimization bug. Queries with Join and precondition with GT/LT condition can return incorrect results
- [fea] Add/Drop indexes without reloading data
- [ref] Redundant Makefiles removed
- [del] Ugly RenameNamespace & CloneNamespace API was removed
- [fix] Fixed unnecessary copy results of precondition Join Query
- [fea] cproto connector to standalone server
- [fix] Potential races was fixed
- [del] Tx now alias to Batch. Old update logic was deprecated
- [fix] Limit cgo execution to 2K goroutines to avoid exceed of OS threads limit
- [ref] EnableStorage method was deprecated
- [fix] Query builder did not reset opOR after InnerJoin