kdb Insights Enterprise - Previous Release Notes
This page outlines release notes from past releases. For the most recent release, refer to the latest release page.
1.14.6
Release Date 2025-09-09
Fixes
This release includes various bug and security fixes across the entirety of kdb Insights Enterprise!
Expand to view details of key issues that have been resolved
Database
- Database conversions that changed a charcolumn type to astringcolumn type now work correctly.
- Conversions between compound column types (for example, from floatstolongs) now function correctly.
- Added schema validation to ensure the configured prtnColvalue is a list oftimestamptype, as required.
- If the EOI process crashes during a database conversion, SM now correctly maintains the HDB lock when EOI is restarted.
Stream Processor
- Resolved an issue in which direct write save-down failed to write data to disk. This previously resulted in the following error: No session dir exists for: kdb Insights Database.
Artifacts
| Type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.14.6.tgz | insights-1.14.6.tgz | 
| Operator | kxi-operator-1.14.2.tgz | kxi-operator-1.14.2.tgz | 
| CLI | kxicli-1.14.3-py3-none-any.whl | kxicli-1.14.3-py3-none-any.whl | 
| RT q interface | rt.1.14.0.qpk | rt.1.14.0.qpk | 
| RT C interface | kxi-c-sdk 1.14.0 | kxi-c-sdk 1.14.0 | 
| RT Python interface | kxi-rtpy-1.14.0 | kxi-rtpy-1.14.0 | 
| RT Java interface | kxi-java-sdk 1.13.0 | kxi-java-sdk 1.13.0 | 
| RT C# interface | kxi-csharp-sdk 1.14.0 | kxi-csharp-sdk 1.14.0 | 
| Infrastructure | kxi-terraform-1.14.0.tgz | kxi-terraform-1.14.0.tgz | 
| kxi-management-service | kxi-management-service-1.0.0.tgz | kxi-management-service-1.0.0.tgz | 
| insights-on-k8s | insights-on-k8s-0.4.28.tgz | insights-on-k8s-0.4.28.tgz | 
1.14.5
Release Date 2025-08-29
Fixes
This release includes various bug and security fixes across the entirety of kdb Insights Enterprise!
Expand to view details of key issues that have been resolved
Database
- Fixed an issue that prevented using peaching over arguments with .kxi.selectTable, such as.kxi.selectTable peach args.
Security
- This release includes fixes to various CVEs.
Artifacts
| Type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.14.5.tgz | insights-1.14.5.tgz | 
| Operator | kxi-operator-1.14.2.tgz | kxi-operator-1.14.2.tgz | 
| CLI | kxicli-1.14.3-py3-none-any.whl | kxicli-1.14.3-py3-none-any.whl | 
| RT q interface | rt.1.14.0.qpk | rt.1.14.0.qpk | 
| RT C interface | kxi-c-sdk 1.14.0 | kxi-c-sdk 1.14.0 | 
| RT Python interface | kxi-rtpy-1.14.0 | kxi-rtpy-1.14.0 | 
| RT Java interface | kxi-java-sdk 1.13.0 | kxi-java-sdk 1.13.0 | 
| RT C# interface | kxi-csharp-sdk 1.14.0 | kxi-csharp-sdk 1.14.0 | 
| Infrastructure | kxi-terraform-1.14.0.tgz | kxi-terraform-1.14.0.tgz | 
| kxi-management-service | kxi-management-service-1.0.0.tgz | kxi-management-service-1.0.0.tgz | 
| insights-on-k8s | insights-on-k8s-0.4.28.tgz | insights-on-k8s-0.4.28.tgz | 
1.14.4
Release Date 2025-08-22
Urgent Upgrade and Deployment Considerations
Bitnami Image Repository Changes
This release includes changes to the default image.repository for several Bitnami images used in Insights Enterprise. The repository will be updated to bitnamilegacy in alignment with the Bitnami announcement. Upgrading to 1.14.4 will ensure your application points to the new location of the images required to run the relevant services. 
Fixes
This release includes various bug and security fixes across the entirety of kdb Insights Enterprise!
Expand to view details of key issues that have been resolved
Web Interface
- The Performance Tuning Wizard previously allowed users to attempt re-sorting data already on-disk - an unsupported operation that caused failures. To prevent this, the Performance Tuning Wizard will no longer be available once data has been ingested into the database.
Artifacts
| Type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.14.4.tgz | insights-1.14.4.tgz | 
| Operator | kxi-operator-1.14.2.tgz | kxi-operator-1.14.2.tgz | 
| CLI | kxicli-1.14.3-py3-none-any.whl | kxicli-1.14.3-py3-none-any.whl | 
| RT q interface | rt.1.14.0.qpk | rt.1.14.0.qpk | 
| RT C interface | kxi-c-sdk 1.14.0 | kxi-c-sdk 1.14.0 | 
| RT Python interface | kxi-rtpy-1.14.0 | kxi-rtpy-1.14.0 | 
| RT Java interface | kxi-java-sdk 1.13.0 | kxi-java-sdk 1.13.0 | 
| RT C# interface | kxi-csharp-sdk 1.14.0 | kxi-csharp-sdk 1.14.0 | 
| Infrastructure | kxi-terraform-1.14.0.tgz | kxi-terraform-1.14.0.tgz | 
| kxi-management-service | kxi-management-service-1.0.0.tgz | kxi-management-service-1.0.0.tgz | 
| insights-on-k8s | insights-on-k8s-0.4.28.tgz | insights-on-k8s-0.4.28.tgz | 
1.14.3
Release Date 2025-08-15
Urgent Upgrade and Deployment Considerations
Bitnami Image Repository Changes
Changes to the default image.repository for several Bitnami images used in Insights Enterprise have been announced, effective August 28, 2025. As a result, if a pod is restarted on a node where its image is not cached, it will fail to start due to the image no longer being available at the original location. 
To address this, the required images will continue to be available from the Bitnami legacy repository bitnamilegacy in alignment with the official announcement. In order to work around this, either upgrade to 1.14.4, or perform the following:
1) Perform an “upgrade” to the same version you are using, via the modified values.yamlfile referenced below, with this command: kxi install upgrade --filepath ./values.yaml --version <my-current-insights-version>
2) Once it’s redeployed, you can check using: kubectl describe pods > pods.desc, followed by searching pods.desc for all instances of bitnami. The Image: lines must say bitnamilegacy.
Note that if the ImageID: lines still say bitnami, the SHA of the bitnamilegacy image is identical to the SHA of the existing Bitnami Image.
The values.yaml file configuration:
    keycloak:
      image:
        repository: bitnamilegacy/keycloak
    ...
      postgresql:
        image:
          repository: bitnamilegacy/postgresql
    ...
    kxi-scratchpad-manager:
      initDBJob:
        image:
          repository: bitnamilegacy
      cleanup:
        image:
          repository: bitnamilegacy
    ...
    kxi-ent-srv:
      initDBJob:
        image:
          repository: bitnamilegacy
Applying these changes will ensure your application points to the new location of the images required to run the relevant services.
Fixes
This release includes various bug and security fixes across the entirety of kdb Insights Enterprise!
Expand to view details of key issues that have been resolved
Packaging
- Resolved an issue where the Package Manager was unable to unpack a package that contained a user-defined function.
Security
- Security patches have been applied and CVEs have been remediated.
Artifacts
| Type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.14.3.tgz | insights-1.14.3.tgz | 
| Operator | kxi-operator-1.14.2.tgz | kxi-operator-1.14.2.tgz | 
| CLI | kxicli-1.14.3-py3-none-any.whl | kxicli-1.14.3-py3-none-any.whl | 
| RT q interface | rt.1.14.0.qpk | rt.1.14.0.qpk | 
| RT C interface | kxi-c-sdk 1.14.0 | kxi-c-sdk 1.14.0 | 
| RT Python interface | kxi-rtpy-1.14.0 | kxi-rtpy-1.14.0 | 
| RT Java interface | kxi-java-sdk 1.13.0 | kxi-java-sdk 1.13.0 | 
| RT C# interface | kxi-csharp-sdk 1.14.0 | kxi-csharp-sdk 1.14.0 | 
| Infrastructure | kxi-terraform-1.14.0.tgz | kxi-terraform-1.14.0.tgz | 
| kxi-management-service | kxi-management-service-1.0.0.tgz | kxi-management-service-1.0.0.tgz | 
| insights-on-k8s | insights-on-k8s-0.4.28.tgz | insights-on-k8s-0.4.28.tgz | 
1.14.2
Release Date 2025-07-28
Improvements
This release includes various improvements, bug and security fixes across the entirety of kdb Insights Enterprise!
Expand to review details of key improvements!
Ability to target specific Data Access Processes when calling APIs
- 
The distinguished parameter scopenow takesdapas a key to allow a user to target a specificDAP. Note this parameter is supported only ifscope.assemblyis specified. This cannot be used withscope.tier.
- 
The dapkey ofgetMetawill give detail on individual DAPs when the new parameteradvancedis set totrue. Refer to DAPs for details.
Fixes
Expand to view details of key issues that have been resolved
Packaging
- Packages now allow column names to end with _.
Artifacts
| Type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.14.2.tgz | insights-1.14.2.tgz | 
| Operator | kxi-operator-1.14.2.tgz | kxi-operator-1.14.2.tgz | 
| CLI | kxicli-1.14.2-py3-none-any.whl | kxicli-1.14.2-py3-none-any.whl | 
| RT q interface | rt.1.14.0.qpk | rt.1.14.0.qpk | 
| RT C interface | kxi-c-sdk 1.14.0 | kxi-c-sdk 1.14.0 | 
| RT Python interface | kxi-rtpy-1.14.0 | kxi-rtpy-1.14.0 | 
| RT Java interface | kxi-java-sdk 1.13.0 | kxi-java-sdk 1.13.0 | 
| RT C# interface | kxi-csharp-sdk 1.14.0 | kxi-csharp-sdk 1.14.0 | 
| Infrastructure | kxi-terraform-1.14.0.tgz | kxi-terraform-1.14.0.tgz | 
| kxi-management-service | kxi-management-service-1.0.0.tgz | kxi-management-service-1.0.0.tgz | 
| insights-on-k8s | insights-on-k8s-0.4.22.tgz | insights-on-k8s-0.4.22.tgz | 
1.14.1
Release Date 2025-07-08
Fixes
This release includes numerous bug, stability and security fixes.
Expand to view details of key issues that have been resolved
Database
- Resolved an issue with GUIDsorting. Users experienced an EOD mismatch error when there was late data and EOD attempts to sort data across multiple dates.
SQL
- .kxi.sqlqueries that use- EXCEPT ALLhave been corrected to align with postgreSQL behavior, in which duplicates would be included in query results.
Packaging
- Previously, the UUIDs of User-Defined Functions changed when the package was pushed/pulled. This has been updated to make use of existing UUIDs when they are present.
Web Interface
- Exporting a database configuration was silently failing. This has been resolved.
Security
- 
Various CVEs have been patched as part of this release. 
- 
Blocked the ability for unsafe cross-site scripting code execution in Views. 
- 
Insights Enterprise HTTP responses now include a Cross-Origin-Opener-Policy (COOP) Header to protect against cross-origin attacks. 
- 
Third party libraries in Views (DOMPurify, monaco-editor) were updated to remove vulnerabilities. 
Artifacts
| Type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.14.1.tgz | insights-1.14.1.tgz | 
| Operator | kxi-operator-1.14.1.tgz | kxi-operator-1.14.1.tgz | 
| CLI | kxicli-1.14.1-py3-none-any.whl | kxicli-1.14.1-py3-none-any.whl | 
| RT q interface | rt.1.14.0.qpk | rt.1.14.0.qpk | 
| RT C interface | kxi-c-sdk 1.14.0 | kxi-c-sdk 1.14.0 | 
| RT Python interface | kxi-rtpy-1.14.0 | kxi-rtpy-1.14.0 | 
| RT Java interface | kxi-java-sdk 1.13.0 | kxi-java-sdk 1.13.0 | 
| RT C# interface | kxi-csharp-sdk 1.14.0 | kxi-csharp-sdk 1.14.0 | 
| Infrastructure | kxi-terraform-1.14.0.tgz | kxi-terraform-1.14.0.tgz | 
| kxi-management-service | kxi-management-service-1.0.0.tgz | kxi-management-service-1.0.0.tgz | 
| insights-on-k8s | insights-on-k8s-0.4.11.tgz | insights-on-k8s-0.4.11.tgz | 
1.14.0
Release Date 2025-06-30
kdb Insights Enterprise 1.14 delivers powerful new language interfaces and improvements (C#, C, Python), embeddable dashboards, enhanced access controls, greater flexibility for data subscriptions, and many performance, usability, and deployment improvements. Read on to find out more!
New Features
- Embeddable Dashboards
- New C# Interface
- Subscription to data streams in C
- Improved Access Control
- CLI for Windows
- Topic Filtering
- RT Python Interface Enhancements
1. Embeddable Dashboards
Integrate your kdb Insights Enterprise views into any web-based application. This feature enables you to leverage your views further for other systems or user bases, in both internal applications and external-facing portals. Refer to Embedding in an iframe for details.
2. New C# interface
A new C# language interface has been added for publishing & subscribing to data in kdb Insights Enterprise from client applications implemented in C#. This language interface supports cross-platform client application deployment on Windows and Linux. Refer to Using the kdb Insights C# interface for details.
3. Subscription to data streams in C
Client applications written in C using the C language interface can now subscribe to data streams from kdb Insights Enterprise, using the new secure data egress endpoints. Refer to the Subscription section of the Using the C Interface documentation for details. Here is a helpful example of how to establish a subscription in q, or how to configure this using Stream Settings in the web interface.
4. Views-only user role
A new Views-only role has been added, allowing administrators to grant certain users read-only access to Views without access to other entities such as databases or pipelines. This gives administrators better control over access and security. Refer to Roles for details.
5. Windows support for the CLI
The kdb Insights CLI now supports Windows, eliminating the need for WSL. This enhancement reduces complexity and administrative burden, simplifying management and development for kdb Insights Enterprise users working in Windows environments. Read the documentation for instructions on how to install or upgrade the CLI.
6. Subscribe to multiple topics of a data stream
Reliable Transport now allows subscription to multiple topics of the data stream, allowing users to publish/subscribe only to messages of interest. This gives greater control over how data is passed through the system and can boost throughput. This feature is available in the Python, Java, C, and q RT interfaces. Refer to Subscribe for details on how to subscribe to a full stream or particular topics within the stream.
This will be available in the Stream Processor's UI Reader/Writer in a future release.
7. Reliable Transport Python Interface Enhancements
- 
The RT Python interface can now be used to subscribe to updates from an RT stream and leverage RT topic filtering. Refer to the Subscribe section of the Python API documentation. 
- 
You can now query kdb Insights Enterprise data using the RT Python interface. Refer to the grant_typeparameter and thekxi.query.QueryAPI for how to configure an authenticated connection, and the Quickstart guide to help set this up.
Improvements
This release includes a variety of improvements across the entirety of kdb Insights Enterprise!
Expand to read details of the full set of improvements!
Python 3.11 Upgrade
- The Stream Processor and Data Access Processes have been upgraded to run Python 3.11, improving performance and providing access to the latest language features.
Potential Breaking Change
Note that this upgrade may impact any User-Defined Functions/Analytics or Python code in a pipeline that was developed against the prior version. Refer to the Important Upgrade & Deployment Considerations section for full details on potential breaking changes.
Data Flow Observability
- A new API for Reliable Transport has been added to help troubleshoot data flow issues where publisher clients have deduplication enabled. Refer to RT deduplication for details of the API and also to the kdb Insights Reliable Transport documentation for more general information on the RT deduplication capabilities.
SQL2
- 
.kxi.sql2queries that contain more than oneUNION,EXCEPT,INTERSECToperation are now supported for combining queries. For example:(select a, b from table1) union (select a, b from table2) except (select a, b from table3)Note When using EXCEPT ALLin SQL2, the result presently aligns to q/kdb+ behavior (that is, all duplicates are removed) rather than postgresql behavior where duplicates would be included. This will be resolved in a future patch.
- 
SQL2 queries with multiple set operation clauses are now supported. ((w union x) intersect y) except z
- 
.kxi.sql2now supportscurrent_timein theSELECTandWHEREclause of a query.
Improved Organization for Views
- Views can now be organized into groups using tags. This feature improves the management and arrangement of views, making it easier for users to navigate and locate the views of interest to them. Refer to Tags for details.
Improved performance and efficiency of pipeline ingestion from object storage
- SP object store read performance has been significantly enhanced through the introduction of parallelization in downloading and processing files. This improvement greatly reduces load times for large datasets, enabling faster data ingestion and processing from object storage. To take advantage of these improvements, update your pipelines to use the v2 versions of the Amazon S3, Microsoft Azure Storage or Google Cloud Storage readers. Refer to the guide Ingesting from Object Storage for details.
Configurable Timeout on Test Pipeline
- Pipeline testing now includes configurable timeouts for both Quick and Full tests. Users can adjust timeout settings to accommodate specific environmental circumstances regarding data arrival. Refer to Test Timeout for details.
Query Tabs
- 
The Query tab now has a Cancel button to interrupt the current query. Note that cancel does not work for Python queries at this time. 
- 
The Query tab now has a Reset button, which restarts the scratchpad process, causing any scratchpad state to be lost. This can be used to reset the scratchpad to a usable state when it is running a query that can't be interrupted with Cancel. 
- 
The default disk size for scratchpads has been increased from 50mbto250mbto avoid experiencing resource contention when running test deploys or running Python installs that require more space.
- 
For User-Defined Analytics, [nulls], positive infinity, and negative infinity can now be used for any parameters that have a type where this value is present. They can be entered as, and only as, 0N,0w, and-0wrespectively.
- 
The Stream Processor's beta features are now available in quick tests and the scratchpad when beta features are enabled. If your values file is set to have betaFeatures: true, then quick tests and the scratchpad honor this.
- 
Added logging improvements to the scratchpad. Now, all output from STDOUTandSTDERRare captured and can be retrieved using.com_kx_edi.getLogs[]and.com_kx_edi.clearLogs[]. This feature is disabled on startup and needs to be started using.com_kx_edi.cacheLogs[].
Database Configuration
- zstdhas been added as a database compression option in the web interface.
Packaging
- 
kxi pm infonow allows deeper inspection of a package, namely the ability to look attableandpipelinecontents. Refer to PM Info for details.
- 
kxi pm pushCLI command now supports locking Q files during upload. Refer to PM Push and Lock Code for details.
- 
Entitlements administrators can now create/delete/add/remove entitlements from a group using the kxi entitlement managecommand. Row-level entitlements can now also be managed using thekxi entitlement managecommand. Refer to Manage for details.
- 
The Package Manager now supports backup and restore options. Refer to Package Backup and Restore for details. 
- 
It is now possible to add a new pipeline to a running package. 
Deployment
- Using the Terraform scripts, it is now possible to deploy into an existing VPC in AWS. Refer to Configure a Kubernetes cluster on AWS for details.
Fixes
This release includes numerous bug, stability and security fixes.
Expand to read details of some important resolved issues here
Stream Processor
- Resolved an issue related to input ordering for nodes that utilize multiple inputs.
Database
- 
DBM now resumes interrupted data migration processes, preserving progress in cases where the operation was previously halted unexpectedly. 
- 
On the Schema Settings page, Code View now prevents schema changes where a column with type anyattempts to set the compound field totrue.
SQL2
- 
Fixed an issue where an error could be experienced in a SQL2 join query where only the table was referenced, and no SELECT … FROM [table name]clause was provided.
- 
Fixed an issue where a SQL2 query would fail if the column in the WHEREclause did not appear in theSELECTclause.
User-Defined Analytics
- UDAs now support empty lists. Previously, the Run Query button in the web interface would be disabled if there were any empty lists present.
Packaging
- Deleting a package from CLI now explicitly asks for user confirmation. Previously, there was no confirmation before the permanent delete was executed.
Scratchpad
- Basic queries now default to show the last 100 rows to help avoid resource usage issues.
Security
- Various CVEs were remediated as part of this release.
Important Upgrade and Deployment Considerations
Python 3.11 Upgrade
The upgrade to Python 3.11 in the Stream Processor and Data Access Processes brings the following important changes:
- 
EmbedPy Removal: Customer code using EmbedPy no longer works. 
- 
PyKX Upgrade: PyKX has been upgraded from version 2.5.5 to 3.1, which includes breaking changes to PyKX behavior. For more details, refer to this article. 
- 
Machine Learning API Update: The scikit-learnlibrary has been upgraded from 1.5.2 to 1.6.1. This upgrade introduces the following breaking API changes:- adaBoostClassifier: The SP operator no longer supports- SAMME.R.
- randomForestClassifier: The- maxFeaturesparameter now defaults to- sqrtinstead of- auto.
- Time-Based Features: Time columns are no longer automatically converted to a supported type (integer or float).
 
getData
The behavior of distinct when used in the agg parameter of the arguments of .kxi.getData is now always returned enlisted. Refer to the following example:
1) With `agg=enlist`distA`distinct`a` would get the following payload returned:
Old Behavior:
distA
-----
1
0
2
4
New Behavior:
distA
-------
1 0 2 4
2) With `agg=((`distA`distinct`a);(`distB`distinct`b))` both old and new behavior would return this:
distA   distB
-----------------
1 0 2 4 4 0 2 1 3
Terraform Scripts
- 
The bastion host for AWS has been changed from Amazon Linux to Ubuntu. 
- 
If deploying on OpenShift, it is required to define storage class values to ensure they appear in the web interface. Refer to OpenShift Specific Config for details. 
Profile Configuration
There is an upgrade requirement for release 1.14 that you must either configure the default profile for the environment you are upgrading, or specify a profile override.
To upgrade with a previously configured default profile, run:
kxi install upgrade --version 1.14.0 --operator-version 1.14.0 --filepath values.yaml
To upgrade with a profile override, run:
kxi --profile <profile name> install upgrade --version 1.14.0 --operator-version 1.14.0 --filepath values.yaml
Configuring a profile
Run the kxi configure --profile <name of new profile> command to configure a new profile. For more information, read Profiles.
Enabled Entitlements before the upgrade of kdb Insights Enterprise
If you are upgrading a system that has Entitlements enabled, or if you are turning Entitlements on as part of the upgrade, ensure you have the Administrator role so that the packages can be redeployed. If you do not have the Administrator role, you will not be able to run and complete the upgrade.
Rollback
As of 1.14, the rollback process has been greatly simplified. To take advantage of this, ensure you are using the 1.14 version of the KXI CLI. Refer to Rollback for details.
Deprecations
- Package manager V1 API is now marked as deprecated for future removal. It is recommended to begin migrating to V2, if possible.
Third-party Dependencies
kdb Insights Enterprise 1.14.0 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.14.0 release of the standalone infrastructure installation scripts.
Please consult these pages for important information on supported versions:
Artifacts
| Type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.14.0.tgz | insights-1.14.0.tgz | 
| Operator | kxi-operator-1.14.0.tgz | kxi-operator-1.14.0.tgz | 
| CLI | kxicli-1.14.0-py3-none-any.whl | kxicli-1.14.0-py3-none-any.whl | 
| RT q interface | rt.1.14.0.qpk | rt.1.14.0.qpk | 
| RT C interface | kxi-c-sdk 1.14.0 | kxi-c-sdk 1.14.0 | 
| RT Python interface | kxi-rtpy-1.14.0 | kxi-rtpy-1.14.0 | 
| RT Java interface | kxi-java-sdk 1.13.0 | kxi-java-sdk 1.13.0 | 
| RT C# interface | kxi-csharp-sdk 1.14.0 | kxi-csharp-sdk 1.14.0 | 
| Infrastructure | kxi-terraform-1.14.0.tgz | kxi-terraform-1.14.0.tgz | 
| kxi-management-service | kxi-management-service-1.0.0.tgz | kxi-management-service-1.0.0.tgz | 
| insights-on-k8s | insights-on-k8s-0.4.11.tgz | insights-on-k8s-0.4.11.tgz | 
Summary
We hope you find some useful features that optimize your kdb Insights Enterprise experience. Try them out and contact our Support Team if you need any help.
We look forward to bringing you even bigger features in kdb Insights Enterprise 1.15, coming soon!
1.13.5
Release Date 2025-06-02
Urgent Upgrade and Deployment Considerations
Bitnami Image Repository Changes
Changes to the default image.repository for several Bitnami images used in Insights Enterprise have been announced, effective August 28, 2025. As a result, if a pod is restarted on a node where its image is not cached, it will fail to start due to the image no longer being available at the original location. 
To address this, the required images will continue to be available from the Bitnami legacy repository bitnamilegacy in alignment with the official announcement. In order to work around this, either upgrade to 1.14.4, or perform the following:
1) Perform an “upgrade” to the same version you are using, via the modified values.yamlfile referenced below, with this command: kxi install upgrade --filepath ./values.yaml --version <my-current-insights-version>
2) Once it’s redeployed, you can check using: kubectl describe pods > pods.desc, followed by searching pods.desc for all instances of bitnami. The Image: lines must say bitnamilegacy.
Note that if the ImageID: lines still say bitnami, the SHA of the bitnamilegacy image is identical to the SHA of the existing Bitnami Image.
The values.yaml file configuration:
    keycloak:
      image:
        repository: bitnamilegacy/keycloak
    ...
      postgresql:
        image:
          repository: bitnamilegacy/postgresql
    ...
    kxi-scratchpad-manager:
      initDBJob:
        image:
          repository: bitnamilegacy
      cleanup:
        image:
          repository: bitnamilegacy
    ...
    kxi-ent-srv:
      initDBJob:
        image:
          repository: bitnamilegacy
Applying these changes will ensure your application points to the new location of the images required to run the relevant services.
Fixes
This release includes numerous bug, stability, and security fixes.
Expand to see detail of some important resolved issues here
Packages
- Resolved an issue whereby the metadata annotation size breached the Kubernetes limit, resulting in the inability to deploy packages.
Third-party Dependencies
kdb Insights Enterprise 1.13.5 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.13.5 release of the standalone infrastructure installation scripts.
Please consult these pages for important information on supported versions:
Artifacts
| Type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.13.5.tgz | insights-1.13.5.tgz | 
| Operator | kxi-operator-1.13.1.tgz | kxi-operator-1.13.1.tgz | 
| CLI | kxicli-1.13.3-py3-none-any.whl | kxicli-1.13.3-py3-none-any.whl | 
| RT q interface | rt.1.13.2.qpk | rt.1.13.2.qpk | 
| RT C interface | kxi-c-sdk 1.13.2 | kxi-c-sdk 1.13.2 | 
| RT Python interface | kxi-rtpy-1.12.0 | kxi-rtpy-1.12.0 | 
| RT Java interface | kxi-java-sdk 1.13.0 | kxi-java-sdk 1.13.0 | 
| Infrastructure | kxi-terraform-1.13.3.tgz | kxi-terraform-1.13.3.tgz | 
| kxi-management-service | kxi-management-service-0.2.8.tgz | kxi-management-service-0.2.8.tgz | 
| insights-on-k8s | insights-on-k8s-0.3.5.tgz | insights-on-k8s-0.3.5.tgz | 
1.13.4
Release Date 2025-05-27
Fixes
This release includes numerous bug, stability, and security fixes.
Expand to see detail of some important resolved issues here
Pipelines*
- Resolved an issue where the web interface could sporadically time out on the Pipeline Viewer page while loading the Data Preview panel for a Full Test. This occasionally led to incorrect reporting that the query returned no data.
Database
- Resolved an edge cause defect in which the Storage Manager would remain stuck in an INITIALIZINGstate if an upgrade to 1.13 was performed before the first EOI had occurred.
Third-party Dependencies
kdb Insights Enterprise 1.13.4 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.13.4 release of the standalone infrastructure installation scripts.
Please consult these pages for important information on supported versions:
Artifacts
| Type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.13.4.tgz | insights-1.13.4.tgz | 
| Operator | kxi-operator-1.13.1.tgz | kxi-operator-1.13.1.tgz | 
| CLI | kxicli-1.13.2-py3-none-any.whl | kxicli-1.13.2-py3-none-any.whl | 
| RT q interface | rt.1.13.2.qpk | rt.1.13.2.qpk | 
| RT C interface | kxi-c-sdk 1.13.2 | kxi-c-sdk 1.13.2 | 
| RT Python interface | kxi-rtpy-1.12.0 | kxi-rtpy-1.12.0 | 
| RT Java interface | kxi-java-sdk 1.13.0 | kxi-java-sdk 1.13.0 | 
| Infrastructure | kxi-terraform-1.13.3.tgz | kxi-terraform-1.13.3.tgz | 
| kxi-management-service | kxi-management-service-0.2.8.tgz | kxi-management-service-0.2.8.tgz | 
| insights-on-k8s | insights-on-k8s-0.3.5.tgz | insights-on-k8s-0.3.5.tgz | 
1.13.3
Release Date 2025-05-27
Fixes
This release includes numerous bug, stability, and security fixes.
Expand to see detail of some important resolved issues here
Database
- 
Fixed an issue where certain .kxi.selectTablequeries did not properly account for row-level entitlements. (Note: Row-level entitlements is currently a beta feature.)
- 
Resolved an issue where an internal reload flag was not incremented correctly during upgrades from version 1.12 to 1.13. This could result in a no 'dbVintage' reported by SMerror, though it did not impact core system functionality.
Security
- Various CVEs were remediated as part of this release.
Third-party Dependencies
kdb Insights Enterprise 1.13.3 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.13.3 release of the standalone infrastructure installation scripts.
Please consult these pages for important information on supported versions:
Artifacts
| Type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.13.3.tgz | insights-1.13.3.tgz | 
| Operator | kxi-operator-1.13.1.tgz | kxi-operator-1.13.1.tgz | 
| CLI | kxicli-1.13.2-py3-none-any.whl | kxicli-1.13.2-py3-none-any.whl | 
| RT q interface | rt.1.13.2.qpk | rt.1.13.2.qpk | 
| RT C interface | kxi-c-sdk 1.13.2 | kxi-c-sdk 1.13.2 | 
| RT Python interface | kxi-rtpy-1.12.0 | kxi-rtpy-1.12.0 | 
| RT Java interface | kxi-java-sdk 1.13.0 | kxi-java-sdk 1.13.0 | 
| Infrastructure | kxi-terraform-1.13.3.tgz | kxi-terraform-1.13.3.tgz | 
| kxi-management-service | kxi-management-service-0.2.8.tgz | kxi-management-service-0.2.8.tgz | 
| insights-on-k8s | insights-on-k8s-0.3.5.tgz | insights-on-k8s-0.3.5.tgz | 
1.13.2
Release Date 2025-05-13
Improvements
Expand to see detail of the full set of improvements!
Terraform Scripts
- Rationalized Certification options for the scripts are now available. The default option is now set to use Existing Certificates that a user provides for ingress, as opposed to the previous default of Certificate Manager with HTTP validation. See the Terraform script documentation for details on AWS, Azure, and GCP.
Fixes
This release includes numerous bug, stability, and security fixes.
Expand to see detail of some important resolved issues here
Database
- 
A query with a large payload could cause some QIPC queries to be lost and the connection to be corrupt. This issue has now been resolved. 
- 
The HDB could stop serving query requests when the Storage Manager executed migration of partitions. This defect would result in a core dump error in the HDB DAP logs. 
- 
If data from today was ingested using Batch Ingest, the HDB DAP would expand its purview without loading the existing IDB and RDB data, making this data invisible until the next EOD. 
Security
- Various CVEs were remediated as part of this release.
Third-party Dependencies
kdb Insights Enterprise 1.13.2 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.13.2 release of the standalone infrastructure installation scripts.
Please consult these pages for important information on supported versions:
Artifacts
| Type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.13.2.tgz | insights-1.13.2.tgz | 
| Operator | kxi-operator-1.13.1.tgz | kxi-operator-1.13.1.tgz | 
| CLI | kxicli-1.13.1-py3-none-any.whl | kxicli-1.13.1-py3-none-any.whl | 
| RT q interface | rt.1.13.2.qpk | rt.1.13.2.qpk | 
| RT C interface | kxi-c-sdk 1.13.2 | kxi-c-sdk 1.13.2 | 
| RT Python interface | kxi-rtpy-1.12.0 | kxi-rtpy-1.12.0 | 
| RT Java interface | kxi-java-sdk 1.13.0 | kxi-java-sdk 1.13.0 | 
| Infrastructure | kxi-terraform-1.13.1.tgz | kxi-terraform-1.13.1.tgz | 
| kxi-management-service | kxi-management-service-0.2.8.tgz | kxi-management-service-0.2.8.tgz | 
| insights-on-k8s | insights-on-k8s-0.3.5.tgz | insights-on-k8s-0.3.5.tgz | 
1.13.1
Release Date 2025-04-28
Improvements
Expand to see detail of the full set of improvements!
Reliable Transport
- You can now subscribe to a list of tables in the RT stream. Previously, topic filtering supported a subscription only to a single table.
Database
- zstdhas been added as a database compression option in the web interface.
Fixes
This release includes numerous bug, stability, and security fixes.
Expand to see detail of some important resolved issues here
Database
- Resolved an issue where the selectTableAPI could return an incorrect result if executing an aggregation that included data on disk. For example, a call such as.kxi.selectTabletableagg!(trade;enlist[x]!enlist(avg;price))could be subject to this defect.
Pipelines
- When using Full Test, moderately-large or complex pipelines could fail to deploy resulting in a 0 Network Error.
Packaging
- In the CLI, users are now prompted to confirm they intend to delete a package before the deletion operation is executed.
Web Interface
- 
The Database page no longer displays errors when you're opening a database created from the CLI. 
- 
When copying a pipeline from one package to another, the new pipeline was not visible in the Associated Pipelines list until a page refresh was done. This has been resolved. 
- 
On the Schema Settings page, the Code View for databases now prevents applying a schema change if a column with type Anyattempts to set the compound field totrue.
- 
When deploying a new database, the Recently Deployedtable on the landing page was briefly displaying the database with a status ofREADYeven though the database was not fully deployed yet. This has been resolved.
Third-party Dependencies
kdb Insights Enterprise 1.13.1 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.13.1 release of the standalone infrastructure installation scripts.
Please consult these pages for important information on supported versions:
Artifacts
| Type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.13.1.tgz | insights-1.13.1.tgz | 
| Operator | kxi-operator-1.13.1.tgz | kxi-operator-1.13.1.tgz | 
| CLI | kxicli-1.13.1-py3-none-any.whl | kxicli-1.13.1-py3-none-any.whl | 
| RT q interface | rt.1.13.0.qpk | rt.1.13.0.qpk | 
| RT C interface | kxi-c-sdk 1.13.0 | kxi-c-sdk 1.13.0 | 
| RT Python interface | kxi-rtpy-1.12.0 | kxi-rtpy-1.12.0 | 
| RT Java interface | kxi-java-sdk 1.13.0 | kxi-java-sdk 1.13.0 | 
| Infrastructure | kxi-terraform-1.13.1.tgz | kxi-terraform-1.13.1.tgz | 
| kxi-management-service | kxi-management-service-0.2.8.tgz | kxi-management-service-0.2.8.tgz | 
| insights-on-k8s | insights-on-k8s-0.3.5.tgz | insights-on-k8s-0.3.5.tgz | 
1.13.0
Release Date 2025-04-08
kdb Insights Enterprise 1.13 gives you tighter control over system processes, more flexible deployment and configuration, and a host of impactful upgrades designed to boost performance, ease-of-use and efficiency. Read on to find out more!
New Features
- Native Kubernetes Support
- Manually Trigger EOD Processing
- Views: Permissioned Exporting of Views Data
- Backup/Restore in the CLI
- Event-based Triggers for Pipelines
1. Native Kubernetes Support
Support for Native Kubernetes distribution has been added, eliminating the dependency on commercial K8s capabilities. This change provides greater flexibility in determining the right Kubernetes runtime for deployment. Refer to Kubernetes Infrastructure Prerequisites and Installation Validation for details.
2. Manually Trigger EOD Processing
You can now manually trigger Storage Manager to perform end of day (EOD) writedown. This functionality enables requesting an emergency EOD action to push data to the HDB on-disk before the scheduled time, thereby removing memory pressure. This is particularly useful when dealing with large amounts of late data that would be held in the HDB's memory. Read Manual EOD Trigger for details.
3. Views: Permissioned Exporting of Views Data
Views now support role-based file export functionality. This restricts users from exporting data they do not have access to. Read Guide to building Views for details.
4. Backup/Restore in the CLI
The KXI CLI backup and restore now supports backup and restore to all three cloud providers through command-line operations.
5. Event-based Triggers for Pipelines
Pipelines now allow you to auto-trigger execution based on a pre-defined event like EOD or batch ingest completion. Refer to the Pipeline Triggering documentation for details.
Improvements
This release includes a variety of improvements across the entirety of kdb Insights Enterprise!
Expand to see detail of the full set of improvements!
System Resources & Query Environments
Query Environments (QEs) are now disabled by default on a new install to optimize resource usage and improve overall system efficiency. Read the Query Environments documentation for details on how to configure your deployment to include/exclude QEs.
Sample Packages
Sample packages are now available on the KX Downloads Portal to aid in setting up the ingestion examples for both Kafka and S3-based data. Refer to Batch S3 ingest and Streaming Kafka Ingest for guidance on these examples and where to locate the reference packages. Don't forgot about these other pre-existing quickstarts/packages for publishing & querying with the Python API and streaming data from kdb Insights Enterprise over WebSockets too!
CLI Support for Accessing Logs
The KX CLI has been enhanced with a new command for easy log retrieval. This allows developers and admins to easily access and view logs, improving the observability of deployed packages and pipelines. Read Observability Logs for details.
Data Services Events
Data service events allow you to customize and automate the behavior of the system, and trigger other system operations off of them. You can add customized code to run at key points in the data processing lifecycle (like during initialization). This means you can tailor the system's responses, making your data workflows more flexible and dynamic.
Delete Rows in a Table
The Delete Rows in a Table API has been improved now allowing permissioned users to delete rows from tables in the IDB and HDB (deletion from RDB and object storage is not supported). This API remains a beta feature. See Delete Rows in a Table for details.
New Web Interface Landing Page for Improved Usability
A new overview landing page has been introduced to improve the experience for both first-time and experienced users.
Entitlements
Entitlement owners can now manage the entitlements they own without the requiring the insights.entitlement.admin role. See Entitlements for details on Entitlements, and Roles for the specific application roles and their capabilities.
Tier Support in Scope
The scope.tier parameter has been introduced to allow you to target one specific tier in an API call. See Scope for details.
Query Improvements
- 
You can now use SQL value functions current_date,current_timestamp, andcurrent_timeso queries of the formselect * from trade where date=current_datenow works in SQL2. See Value Functions for details.
- 
qSQL queries now enforce database entitlements, enhancing security measures. 
- 
There is now a distributedoption in the scratchpad for qsql queries, enabling the query to run against the RDB, IDB and HDB. Read the details of theargs.scope.tierparameter in the qSQL documentation. Note that responses from multiple DAPs are removed.
Reliable Transport Enhancements
- 
Improvements have been made to Reliable Transport to help reduce latency in message flow, especially when dealing with hundreds of publishers. 
- 
If the RT archiver settings are left blank, they now adopt the defaults introduced in 1.13. The retention period is 7 days and the max percentage of available disk is 90%. This protects against overly-rapid truncation of RT logs. See Retention Duration for details on this parameter. 
Streaming to Views Enhancements
- 
Support for viewstates as part of the filtering capability of Streaming data sources. This improvement allows dashboard designers to utilize viewstate variables and filter more easily. Read the Filtering based on a drop-downsection of the Streaming subway data guided walkthrough.
- 
Caching support in Streaming to Views now allows you to see the recent historical view of the data represented together with updates, giving users a more meaningful view of how data is changing over time. Read the Backtest trading strategies tutorial for an example of adding a View that includes streaming data with historical data included. 
- 
Users can now modify the streaming cache on the Subscriber - read the Updating the Cachesection. This functionality enables the deletion or replacement of all or specific rows from the cache. This is particularly useful for managing expired futures contracts or performing backtesting.
Scratchpad Enhancements
- In q editors, you can now select a q keyword or operator and press Alt + / to open the doc for the selection.
Packaging Enhancements
- 
A new command kxi pm infoshows detailed information about a package on the server.
- 
Maintaining or tearing down individual pipelines or databases of a package deployment without impacting other entities is now supported. Read Tear down a specific pipeline for details. 
User-Defined Analytics (UDAs) Enhancements
- 
Python pipelines can now read from databases using UDAs. See Readers for details. 
- 
The Query tab now supports additional parameter types, as well as parameters that can take on multiple types. For full details, read Supported q types. 
- 
All of the distinguished parameters now exist as optional parameters on the Query tab and can be used to customize the routing for every available query. 
- 
Support for calling UDAs has been improved with various web interface updates in the query window. These include: - Encapsulated panels with resizing handles
- An expand/collapse toggle in the Output panel
- The ability to save user-configured workspaces
 
Terraform Deployment Script Updates
Terraform scripts for AWS, Azure, and GCP have been enhanced with architectural profiles representing the three most common confirmation patterns: High Availability, Performance, and Cost-Optimized. Refer to the Architecture Profiles documentation for details.
Fixes
This release includes numerous bug, stability and security fixes.
Expand to see detail of some important resolved issues here
Insights Core
- Insights 1.13 has been updated to run Insights Core 4.1.10, which contains fixes related to the object storage library. Refer to the Insights Core release notes for details of these fixes.
Database
- 
.kxi.getDatawould hit alengtherror when trying to apply more than one filter to a reference table joined using a foreign key.
- 
Schema change performance has been improved to support multi-threaded operations, and to only execute against only the impacted tables. 
- 
The database now waits to initialize connection to Reliable Transport until its processes are fully online. Previously, DAPs would sometimes try to connect before fully available, resulting in an excessive number of RT logs being generated and issues with their processing. 
Reliable Transport
- 
When subscribing to the latest position in RT, all log files, rather than just the log files with the latest data, were copied to the subscriber node. Now, only the log files required are copied. 
- 
Resolved an issue in which an incorrect RT_LOG_PATHwas set after a restart byqsup.
Web Interface
- 
On the Schema Settings page, it was not possible to sort on multiple columns when any column had the partedattribute set. This restriction has been removed, allowing for sorting on multiple columns regardless of attribute.
- 
On the Pipelines page, there was previously no indication when a pipeline only partially succeeded in its operations. Now, pipelines report partial status, making confirmation or debugging clearer. 
Security
- CVE-2024-38541,- CVE-2024-38541, and various other CVEs were remediated as part of this release.
Upgrade & Deployment Changes
Terraform Scripts
- This release removes support for rook-ceph using local SSDs for all three Architecture Profiles. Instead of using local SSD rook-ceph, all rook-ceph deployments will be backed by managed disk to protect against the potential of data loss. Also, the rook-ceph MDS cache size has been set to 4GB to improve stability.
If you are running an environment using local SSD rook-ceph, you should not use this version of the Terraform scripts to upgrade.
Profile Configuration
There is a new upgrade requirement for release 1.13 that you must either configure the default profile for the environment you are upgrading, or specify a profile override.
To upgrade with a previously configured default profile, run:
kxi install upgrade --version 1.13.0 --operator-version 1.13.0 --filepath values.yaml
To upgrade with a profile override, run:
kxi --profile <profile name> install upgrade --version 1.13.0 --operator-version 1.13.0 --filepath values.yaml
Configuring a profile
Run the kxi configure --profile <name of new profile> command to configure a new profile. For more information, read Profiles.
Enabled Entitlements before the upgrade of kdb Insights Enterprise
If you are upgrading a system that has Entitlements enabled, or if you are turning Entitlements on as part of the upgrade, ensure you have the Administrator role so that the packages can be redeployed. If you do not have the Administrator role, you will not be able to run and complete the upgrade.
Rollback
If performing a rollback from 1.13.x to any earlier version, assemblies must not be running prior to initiating the rollback to ensure no data is lost. Refer to Upgrading for how to perform upgrades/rollbacks and the available commands to use. The specific instructions per version are listed below:
Rollback from 1.13.x to 1.13.0:
- Rollback kdb Insights Enterprise per the rollback instructions referenced above.
Rollback from 1.13.x to 1.12.x:
- Teardown your package(s).
- Run the kxi-db-rollback chart with the following command for each package in turn, substituting the desired values:
helm install rollback kx-insights/kxi-db-rollback --version="[current Insights version]" --set rollback.assembly="[your-package-name]" --set rollback.version="[Insights version to rollback to]" -f[your values.yaml file]
Uninstall the rollback chart between each invocation of the kxi-db-rollback chart:
helm uninstall rollback
Repeat this step until all packages have been processed (including any which weren't deployed).
- Rollback kdb Insights Enterprise per the rollback instructions referenced above.
- Redeploy the packages which you tore down.
Rollback from 1.12.x to 1.11.x:
- Teardown your package(s).
- Run the kxi-db-rollback chart with the following command for each package in turn, substituting the desired values:
helm install rollback kx-insights/kxi-db-rollback --version="[current Insights version]" --set rollback.assembly="[your-package-name]" --set rollback.version="[Insights version to rollback to]" --set rollback.currentVersion="[current Insights version]" -f[your values.yaml file] 
Uninstall the rollback chart between each invocation of the kxi-db-rollback chart:
helm uninstall rollback
Repeat this step until all packages have been processed (including any which weren't deployed).
- Rollback kdb Insights Enterprise per the rollback instructions referenced above.
- Redeploy the packages which you tore down.
Deprecations
- The deleteAPI for performing data deletion from the IDB and HDB will be renamed todeleteRowsas of Insights 1.14. This is an advanced warning of the name change.
Third-party Dependencies
kdb Insights Enterprise 1.13.0 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.13.0 release of the standalone infrastructure installation scripts.
Please consult these pages for important information on supported versions:
Artifacts
| Type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.13.0.tgz | insights-1.13.0.tgz | 
| Operator | kxi-operator-1.13.0.tgz | kxi-operator-1.13.0.tgz | 
| CLI | kxicli-1.13.0-py3-none-any.whl | kxicli-1.13.0-py3-none-any.whl | 
| RT q interface | rt.1.13.0.qpk | rt.1.13.0.qpk | 
| RT C interface | kxi-c-sdk 1.13.0 | kxi-c-sdk 1.13.0 | 
| RT Python interface | kxi-rtpy-1.12.0 | kxi-rtpy-1.12.0 | 
| RT Java interface | kxi-java-sdk 1.13.0 | kxi-java-sdk 1.13.0 | 
| Infrastructure | kxi-terraform-1.13.0.tgz | kxi-terraform-1.13.0.tgz | 
| kxi-management-service | kxi-management-service-0.2.8.tgz | kxi-management-service-0.2.8.tgz | 
| insights-on-k8s | insights-on-k8s-0.3.5.tgz | insights-on-k8s-0.3.5.tgz | 
Summary
We hope you find some useful features that optimize your kdb Insights Enterprise experience. Try them out and email our Support Team if you need any help.
We look forward to bring you even bigger features in kdb Insights Enterprise 1.14 coming soon!
1.12.7
Release Date 2025-04-17
Urgent Upgrade and Deployment Considerations
Bitnami Image Repository Changes
Changes to the default image.repository for several Bitnami images used in Insights Enterprise have been announced, effective August 28, 2025. As a result, if a pod is restarted on a node where its image is not cached, it will fail to start due to the image no longer being available at the original location. 
To address this, the required images will continue to be available from the Bitnami legacy repository bitnamilegacy in alignment with the official announcement. In order to work around this, either upgrade to 1.14.4, or perform the following:
1) Perform an “upgrade” to the same version you are using, via the modified values.yamlfile referenced below, with this command: kxi install upgrade --filepath ./values.yaml --version <my-current-insights-version>
2) Once it’s redeployed, you can check using: kubectl describe pods > pods.desc, followed by searching pods.desc for all instances of bitnami. The Image: lines must say bitnamilegacy.
Note that if the ImageID: lines still say bitnami, the SHA of the bitnamilegacy image is identical to the SHA of the existing Bitnami Image.
The values.yaml file configuration:
    keycloak:
      image:
        repository: bitnamilegacy/keycloak
    ...
      postgresql:
        image:
          repository: bitnamilegacy/postgresql
    ...
    kxi-scratchpad-manager:
      initDBJob:
        image:
          repository: bitnamilegacy
      cleanup:
        image:
          repository: bitnamilegacy
    ...
    kxi-ent-srv:
      initDBJob:
        image:
          repository: bitnamilegacy
Applying these changes will ensure your application points to the new location of the images required to run the relevant services.
Fixes
Expand to see the full details of resolved issues
Database
- Resolved an issue where the selectTableAPI could return an incorrect result if executing an aggregation that included data on disk. For example, a call such as.kxi.selectTabletableagg!(trade;enlist[x]!enlist(avg;price))` could be subject to this defect.
Stream Processor
- Resolved a memory leak that occurred when using the MQTT reader.
Security
- Various CVEs were remediated as part of this release.
Third-party Dependencies
kdb Insights Enterprise 1.12.7 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.12.0 release of the standalone infrastructure installation scripts.
Please consult these pages for important information on supported versions:
Artifacts
KX Nexus
The KX Nexus repository will be sunsetted in the future. Nexus links on this page are provided as a temporary alternative to the KX Downloads Portal for existing users. The KX Downloads Portal is the preferred repository for all use cases and KX Nexus links will be removed once the KX Nexus repository is decommissioned.
| Type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.12.7.tgz | insights-1.12.7.tgz | 
| Operator | kxi-operator-1.12.2.tgz | kxi-operator-1.12.2.tgz | 
| CLI | kxicli-1.12.2-py3-none-any.whl | kxicli-1.12.2-py3-none-any.whl | 
| RT C interface | kxi-c-sdk 1.12.0 | kxi-c-sdk 1.12.0 | 
| RT Python interface | kxi-rtpy-1.12.0 | kxi-rtpy-1.12.0 | 
| RT Java interface | kxi-java-sdk 1.12.0 | kxi-java-sdk 1.12.0 | 
| Infrastructure | kxi-terraform-1.12.1.tgz | kxi-terraform-1.12.1.tgz | 
| kxi-management-service | kxi-management-service-0.2.7.tgz | kxi-management-service-0.2.7.tgz | 
| insights-on-k8s | insights-on-k8s-0.2.3.tgz | insights-on-k8s-0.2.3.tgz | 
1.12.6
Release Date 2025-03-25
Fixes
Expand to see the full details of resolved issues
Database
- 
Schema change performance has been improved to support multi-threaded operations, and to only execute against only the impacted tables. 
- 
The database now waits to initialize connection to Reliable Transport until its processes are fully online. Previously, DAPs would sometimes try to connect before fully available, resulting in an excessive number of RT logs being generated and issues with their processing. 
Reliable Transport
- Resolved an issue in which an incorrect RT_LOG_PATHwas set after a restart byqsup.
Stream Processor
- Resolved an edge case issue in which the SP would report a session not founderror.
Security
- Various CVEs were remediated as part of this release.
Third-party Dependencies
kdb Insights Enterprise 1.12.6 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.12.0 release of the standalone infrastructure installation scripts.
Please consult these pages for important information on supported versions:
Artifacts
KX Nexus
The KX Nexus repository will be sunsetted in the future. Nexus links on this page are provided as a temporary alternative to the KX Downloads Portal for existing users. The KX Downloads Portal is the preferred repository for all use cases and KX Nexus links will be removed once the KX Nexus repository is decommissioned.
| Type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.12.6.tgz | insights-1.12.6.tgz | 
| Operator | kxi-operator-1.12.1.tgz | kxi-operator-1.12.1.tgz | 
| CLI | kxicli-1.12.2-py3-none-any.whl | kxicli-1.12.2-py3-none-any.whl | 
| RT C interface | kxi-c-sdk 1.12.0 | kxi-c-sdk 1.12.0 | 
| RT Python interface | kxi-rtpy-1.12.0 | kxi-rtpy-1.12.0 | 
| RT Java interface | kxi-java-sdk 1.12.0 | kxi-java-sdk 1.12.0 | 
| Infrastructure | kxi-terraform-1.12.1.tgz | kxi-terraform-1.12.1.tgz | 
| kxi-management-service | kxi-management-service-0.2.7.tgz | kxi-management-service-0.2.7.tgz | 
| insights-on-k8s | insights-on-k8s-0.2.3.tgz | insights-on-k8s-0.2.3.tgz | 
1.12.5
Release Date 2025-03-12
Fixes
Expand to see the full details of resolved issues
Insights Core
- Insights 1.12.5 has been updated to run Insights Core 4.1.10, which contains fixes related to the object storage library. Refer to the Insights Core release notes for details of these fixes.
Security
- Various CVEs were remediated as part of this release.
Third-party Dependencies
kdb Insights Enterprise 1.12.5 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.12.0 release of the standalone infrastructure installation scripts.
Please consult these pages for important information on supported versions:
Artifacts
KX Nexus
The KX Nexus repository will be sunsetted in the future. Nexus links on this page are provided as a temporary alternative to the KX Downloads Portal for existing users. The KX Downloads Portal is the preferred repository for all use cases and KX Nexus links will be removed once the KX Nexus repository is decommissioned.
| Type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.12.5.tgz | insights-1.12.5.tgz | 
| Operator | kxi-operator-1.12.1.tgz | kxi-operator-1.12.1.tgz | 
| CLI | kxicli-1.12.2-py3-none-any.whl | kxicli-1.12.2-py3-none-any.whl | 
| RT C interface | kxi-c-sdk 1.12.0 | kxi-c-sdk 1.12.0 | 
| RT Python interface | kxi-rtpy-1.12.0 | kxi-rtpy-1.12.0 | 
| RT Java interface | kxi-java-sdk 1.12.0 | kxi-java-sdk 1.12.0 | 
| Infrastructure | kxi-terraform-1.12.1.tgz | kxi-terraform-1.12.1.tgz | 
| kxi-management-service | kxi-management-service-0.2.7.tgz | kxi-management-service-0.2.7.tgz | 
| insights-on-k8s | insights-on-k8s-0.2.3.tgz | insights-on-k8s-0.2.3.tgz | 
1.12.4
Release Date 2025-03-05
Improvements
Infrastructure
- The Client Terraform scripts now come with an interactive configuration script which supports 3 different infrastructure profiles. Refer to Architecture profile, and the Artifacts section below for details.
Fixes
Expand to see the full details of resolved issues
Database
- 
Executing a .kxi.sql2or.kxi.getDataquery and only supplying table name andlimitin the arguments caused an out-of-memory error for large databases. Now, the limit is applied (if possible) before unenumerating the data.
- 
Temporary files created by NFS were preventing Storage Manager from deleting directories during on-disk sort. This has been resolved. 
Reliable Transport
- 
When subscribing to the latest position in RT, all log files, rather than just the log files with the latest data, were copied to the subscriber node. Now, only the log files required are copied. 
- 
RT copies log files from the RT node to the client node. If a log file is truncated by RT on the RT node, it gets truncated on the subscriber node. The subscriber can still truncate the file earlier than RT, but now RT will truncate the file on the client, even if the client has opted out of the RT garbage collection. This mitigates problems that could arise if a client keeps log files longer than RT. 
Security
- 
The following CVEs were remediated as part of this release: - CVE-2024-38541
- CVE-2024-45337
- CVE-2024-38428
- CVE-2024-45337
 
Third-party Dependencies
kdb Insights Enterprise 1.12.4 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.12.0 release of the standalone infrastructure installation scripts.
Please consult these pages for important information on supported versions:
Artifacts
KX Nexus
The KX Nexus repository will be sunsetted in the future. Nexus links on this page are provided as a temporary alternative to the KX Downloads Portal for existing users. The KX Downloads Portal is the preferred repository for all use cases and KX Nexus links will be removed once the KX Nexus repository is decommissioned.
| Type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.12.4.tgz | insights-1.12.4.tgz | 
| Operator | kxi-operator-1.12.0.tgz | kxi-operator-1.12.0.tgz | 
| CLI | kxicli-1.12.2-py3-none-any.whl | kxicli-1.12.2-py3-none-any.whl | 
| RT C interface | kxi-c-sdk 1.12.0 | kxi-c-sdk 1.12.0 | 
| RT Python interface | kxi-rtpy-1.12.0 | kxi-rtpy-1.12.0 | 
| RT Java interface | kxi-java-sdk 1.12.0 | kxi-java-sdk 1.12.0 | 
| Infrastructure | kxi-terraform-1.12.1.tgz | kxi-terraform-1.12.1.tgz | 
| kxi-management-service | kxi-management-service-0.2.5.tgz | kxi-management-service-0.2.5.tgz | 
| insights-on-k8s | insights-on-k8s-0.2.3.tgz | insights-on-k8s-0.2.3.tgz | 
1.12.3
Release Date 2025-02-05
Fixes
Expand to see the full detail of resolved issues here
Database
- 
.kxi.getDatawould hit alengtherror when trying to apply more than one filter to a reference table joined via a foreign key.
- 
If executing a .kxi.selectTablequery in the RDB for a partitioned table, and thestartTSandendTSdid not intersect with the purview of the RDB DAP, all data for the table would be returned. This has been addressed so it will now return an empty table if there is no overlap within the purview.
Third-party Dependencies
kdb Insights Enterprise 1.12.3 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.12.0 release of the standalone infrastructure installation scripts.
Please consult these pages for important information on supported versions:
Artifacts
KX Nexus
The KX Nexus repository will be sunsetted in the future. Nexus links on this page are provided as a temporary alternative to the KX Downloads Portal for existing users. The KX Downloads Portal is the preferred repository for all use cases and KX Nexus links will be removed once the KX Nexus repository is decommissioned.
| Type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.12.3.tgz | insights-1.12.3.tgz | 
| Operator | kxi-operator-1.12.0.tgz | kxi-operator-1.12.0.tgz | 
| CLI | kxicli-1.12.1-py3-none-any.whl | kxicli-1.12.1-py3-none-any.whl | 
| RT C interface | kxi-c-sdk 1.12.0 | kxi-c-sdk 1.12.0 | 
| RT Python interface | kxi-rtpy-1.12.0 | kxi-rtpy-1.12.0 | 
| RT Java interface | kxi-java-sdk 1.12.0 | kxi-java-sdk 1.12.0 | 
| Infrastructure | kxi-terraform-1.12.0.tgz | kxi-terraform-1.12.0.tgz | 
| kxi-management-service | kxi-management-service-0.2.4.tgz | kxi-management-service-0.2.4.tgz | 
| insights-on-k8s | insights-on-k8s-0.2.3.tgz | insights-on-k8s-0.2.3.tgz | 
1.12.2
Release Date 2025-01-30
Improvements
Database
- 
The helper function .kxi.selectTablenow supports the following:- The limitparameter. When no aggregation is required.kxi.sql2and.kxi.getDataapply thelimitparameter closer to the raw data selection, improving performance of the query.
- Filters that use the virtual column i.
 
- The 
- 
When using User-Defined Analytics (UDAs), the userNamevalue is now available when the helper function.kxi.getHeaderis called in the DAP. See response header for details on all fields of the response header, and kxi.getHeader for an example.
Fixes
Expand to see the full detail of resolved issues here
Database
- 
Temporary files created by NFS were preventing Storage Manager from deleting directories during post-commit cleanup. This has been resolved through improved handling of .nfs files and changes to how directory deletion is performed. 
- 
Resolved an issue in which the Query Environment and general Service Gateway were not registering new services when they were deployed, resulting in queries failing. 
Stream Processor
- Resolved a socket issue in the Stream Processor when reading from MQTT.
Web Interface
- 
On the Schema Settings page, it was not possible to sort on multiple columns when any column had the partedattribute set. This restriction has been removed, allowing for sorting on multiple columns regardless of attribute.
- 
On the Pipelines page, there was previously no indication when a pipeline only partially succeeded in its operations. Now, pipelines report partial status, making confirmation or debugging clearer. 
- 
On the Databases page, the Pipelines box previously gave the impression that you could delete the pipeline by using the backspace/delete key in that field. However, this action does not actually remove the pipeline. The ability to use backspace/delete on a pipeline name in this field has been disabled. 
Entitlements
- If using entitlements, upgrading from 1.12.0 to 1.12.1 would fail as a result of a duplicate environment variable KXI_ENTITILEMENT_SERVICEin the Observability service. This has been resolved in 1.12.2, and for previous versions, a workaround is available, in which the Observability service can be deleted prior to performing your upgrade. This could be done by executingkubectl delete deploy/insights-kxi-obs-srv.
Third-party Dependencies
kdb Insights Enterprise 1.12.2 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.12.0 release of the standalone infrastructure installation scripts.
Please consult these pages for important information on supported versions:
Artifacts
KX Nexus
The KX Nexus repository will be sunsetted in the future. Nexus links on this page are provided as a temporary alternative to the KX Downloads Portal for existing users. The KX Downloads Portal is the preferred repository for all use cases and KX Nexus links will be removed once the KX Nexus repository is decommissioned.
| type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.12.2.tgz | insights-1.12.2.tgz | 
| Operator | kxi-operator-1.12.0.tgz | kxi-operator-1.12.0.tgz | 
| CLI | kxicli-1.12.1-py3-none-any.whl | kxicli-1.12.1-py3-none-any.whl | 
| RT C interface | kxi-c-sdk 1.12.0 | kxi-c-sdk 1.12.0 | 
| RT Python interface | kxi-rtpy-1.12.0 | kxi-rtpy-1.12.0 | 
| RT Java interface | kxi-java-sdk 1.12.0 | kxi-java-sdk 1.12.0 | 
| Infrastructure | kxi-terraform-1.12.0.tgz | kxi-terraform-1.12.0.tgz | 
| kxi-management-service | kxi-management-service-0.2.4.tgz | kxi-management-service-0.2.4.tgz | 
| insights-on-k8s | insights-on-k8s-0.2.3.tgz | insights-on-k8s-0.2.3.tgz | 
Upgrade/Rollback
See Upgrade/Rollback Notes for 1.12 for considerations.
1.12.1
Release Date 2025-01-21
Improvements
Database
- Improvements have been made in Storage Manager to reduce the time spent on migrating data across tiers (when compression settings across tiers are the same).
- A new optional environment variable KXI_SKIP_HDB_SIZEhas been introduced to bypass the HDB size calculation during startup. When enabled, this variable skips the calculation of HDB sizes during SM initialization which is beneficial for systems with large HDBs, where the size calculation can be time-consuming. See Environment Variables for details.
- When using User-Defined Analytics (UDAs), the userIDvalue is now available when the helper function.kxi.getHeaderis called in the DAP. See response header for details on all fields of the response header, and kxi.getHeader for an example.
Packaging
- The kxi package checkpointcommand no longer creates a package zip by default. This option is still available if needed. See-- kxiin the kxi package checkpoint documentation for details.
Python Pipelines
- Python pipelines now support reading from databases using User-Defined Analytics (UDAs). For more information, refer to the Python readers documentation.
Fixes
Expand to see the full detail of resolved issues here
Database
- 
On the Schema Settings page, there was no default or minimum block size applied. Depending on how this was set, this could cause adverse effects on the database. A new appropriate minimum of 50,000 rows has now been set, with no maximum. See Performance for more details on block size. 
- 
Resolved an issue where late data added to an existing HDB table partition could create duplicate records at EOD write-down if the memory available to the Storage Manager process is very small. 
- 
Resolved an issue where the KXI_SM_HDB_SIZEmetric caused delays in SM initialization for systems with large historical databases (HDBs).
- 
Storage Manager now catches attempted column type conversions that aren't supported and provides a more helpful log message before shutting down. 
- 
When executing a batch ingest that spans multiple days, the Storage Manager now performs RAM garbage collection between dates. This avoids the potential for out-of-memory failures. 
Readers
- The MQTT reader now obeys the $no_proxyenvironment variable when making connections. See deploying behind a proxy server for details on this feature.
Web Interface
- 
Used and available Query, Writedown, and Stream resources were sometimes not being populated in the Database Overview page. This has been resolved. 
- 
When issuing a query (in the Query or Scratchpad panels) with the console tab selected, memory usage at the bottom of the screen was not updated if you selected either the table or visual tab. This has been resolved. 
Packaging
- 
Two databases with the same name in different packages could not be distinguished in the list of databases in the Database node editor. The package name has been appended to the list to ensure the databases can be identified correctly. 
- 
If you deleted a package that contained entities (pipelines, databases, etc.), and those entities were open in their own tabs, the web interface would throw a 404 error when trying to view them in their respective tabs. This has been resolved such that any open tabs for entities in the package are closed. 
- 
When tearing down a package in the web interface, the option to Clean up entities after teardown erroneously stated that existing data would not be deleted with this operation. This has been corrected to Warning: Cleaning up entities will delete all data associated with a database and all pipeline checkpoints and user states. If running 1.12.0, the incorrect error message will still be seen.
Third-party Dependencies
kdb Insights Enterprise 1.12.1 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.12.0 release of the standalone infrastructure installation scripts.
Please consult these pages for important information on supported versions:
Artifacts
KX Nexus
The KX Nexus repository will be sunsetted in the future. Nexus links on this page are provided as a temporary alternative to the KX Downloads Portal for existing users. The KX Downloads Portal is the preferred repository for all use cases and KX Nexus links will be removed once the KX Nexus repository is decommissioned.
| type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.12.1.tgz | insights-1.12.1.tgz | 
| Operator | kxi-operator-1.12.0.tgz | kxi-operator-1.12.0.tgz | 
| CLI | kxicli-1.12.1-py3-none-any.whl | kxicli-1.12.1-py3-none-any.whl | 
| RT C interface | kxi-c-sdk 1.12.0 | kxi-c-sdk 1.12.0 | 
| RT Python interface | kxi-rtpy-1.12.0 | kxi-rtpy-1.12.0 | 
| RT Java interface | kxi-java-sdk 1.12.0 | kxi-java-sdk 1.12.0 | 
| Infrastructure | kxi-terraform-1.12.0.tgz | kxi-terraform-1.12.0.tgz | 
| kxi-management-service | kxi-management-service-0.2.4.tgz | kxi-management-service-0.2.4.tgz | 
| insights-on-k8s | insights-on-k8s-0.2.3.tgz | insights-on-k8s-0.2.3.tgz | 
Upgrade/Rollback
See Upgrade/Rollback Notes for 1.12 for considerations.
Known Issues
Expand to see the list of known issues here
User-Defined Analytics (UDAs)
- If a UDA has a table hardcoded in the query API, then it will throw the following error Error: Querying database using (UDA) raised - Unknown API: .uda.noParamAPIin the UDA Query tab.
Entitlements
- If a user is a member of multiple user groups, their access level is based solely on the first group processed in the list of groups when checking entitlements.
1.12.0
Release Date 2024-12-11
kdb Insights Enterprise 1.12 introduces a number of new features and improvements, including; an enhanced data import and ingest experience, the ability to assign row level entitlements to tables (beta), enhancements to Views, our new Power BI connector and more. Read on to find out more!
New Features
- Batch Ingest Features & Enhancements
- Initial Database Import
- Performance Tuning for Schemas
- Row Level Entitlements (BETA)
- Natively define Python User-Defined Analytics (UDAs)
- Support calling UDAs from SP Pipeline Builder and the Query Tab
- Power BI Certified Connector
- New Filtering Options for Views
- VSCode Users - Populate your scratchpad from q code
- Second Y-Axis in Views
1. Batch Ingest Features & Enhancements
This release introduces a new version of the database writer, which improves the batch ingest experience when using direct write. The new database writer includes:
- Support for partitioned pipelines, allowing improved performance using parallelization. When maxWorkersis set to more than 1, the Stream Processor (SP) scales up to multiple workers, each taking a shard of the workload and processing it in parallel. This means a much faster processing time.
- Support for unbounded readers, allowing pipelines to read continuous streams of data but still use direct write to the database. Examples of unbounded use cases include file readers with file watching enabled, stream readers (Kafka, Insights Streams, MQTT), callback readers, or upload readers. This support removes the restrictions and limitations around the support of these use cases.
- Monitoring of database ingest sessions using a new API or the web interface. This allows you to monitor the state of ingest sessions by returning a list of them and their various states: pending,queued,progressing,completedorerrored.
An overview of the database ingest functionality is available here, and the API details can be found here: Python and q.
A walkthrough is also available for guidance.
2. Initial Database Import Enhancements
You can import your existing kdb+ database into kdb Insights Enterprise to seed your empty database with data. This release improves upon the existing the process, and also provides:
- Embedded validation to ensure the alignment of the schemas and the appropriate attributes
- Graceful handling of failures with a supported way to re-try/re-start ingest if it does fail for some reason
Read the quickstart guide for a walkthrough of using the initial import feature. The full import process can be followed here.
3. Performance Tuning for Schemas
kdb Insights Enterprise now provides in-app guidance when configuring a schema, helping new kdb+ users define appropriate table definitions and attibrutes to achieve a more optimal schema and better performance. This assists you to determine:
- What table type to use for different types of data
- What attribute(s) to set for a table for optimal performance
- Setting an appropriate column as the basis for partitioning a table
- When attributes have not been set
Read the Performance Tuning documentation for more details.
4. Row Level Entitlements (BETA)
You can now manage user access to data at the row level. Extending our existing database-level query entitlements, you can now apply policies to manage group’s entitlements to rows of data in each table in your database.
See Row Level Entitlements for more details.
5. Natively define Python User-Defined Analytics (UDAs)
You can now develop your UDAs natively in Python and maintain and deploy these as part of a package. Read the Python API documentation regarding UDAs for more details.
6. Support calling UDAs from Pipelines and the Query Tab
UDAs can now be queried from pipelines using the database reader, or from the Query tab. Read query using UDAs and the UDAs section of the Query APIs documentation for how to take advantage of this feature.
7. Power BI Certified Connector
Together with KX, Microsoft have certified and released the kdb Insights Enterprise Power Query Connector. Built using our REST interface, the connector supports Power BI Import Mode to allow you to import a subset of your kdb+ data from kdb Insights Enterprise to visualize in Power BI. This feature leverages Insights' versatile getData API, allowing you to filter, group by and aggregate your data before importing the results into Power BI for visualization. 
8. New Filtering Options for Streaming to Views
There are now additional filtering capabilities for streaming subscribers in Views, allowing you to:
- Filter on columns with data types other than sym
- Filter on a list of columns
Read the subscriber documentation for more information. This walkthrough also has helpful examples.
If using a streaming data source, there are some limitations to be aware of. Read this walkthrough and the details listed in the Streaming tab.
9. Query the database using the q API
You can now query the database using a q API from both the query tab and the kdb+ VSCode Extension. For more details, read the Query API documentation.
10. Second y-axis in the Query Window
Within the Query window, you can now add a second y-axis on the visualization tab to better display different datasets with differences in scale or different chart types. Refer to the documentation for details.
Improvements
Updates to Package Administration
- 
Packages can now be administered from the kdb Insights Enterprise web interface, providing more flexibility when creating, updating and viewing packages. Read the packaging documentation for more details. 
- 
Additionally, this release introduces an updated set of CLI commands for package management. kxi pmis the new and improved command set for pushing, deploying, and tearing down packages. In the CLI, runkxi pm --helpfor the updated set of commands.
Note that you can still use the kxi package command for building of packages on your local machine, and for remote (on-server) operations as well. However, this is being deprecated as of 1.12.0 and replaced with kxi pm for both types of operations. Read Deprecations below for specifics.
CLI
- The CLI user experience has been streamlined to simplify managing entitlements. Using kxi entitlement manage, you can now easily perform these operations:- Add groups to entitlements
- Remove groups from entitlements
- Setting Access levels to groups
 
Read the CLI entitlements documentation for details.
Audit Logging
The following operations now have audit logging to offer traceability of key system operations:
- CLI - adding, modifying or deleting an entitlement now generates audit logs to indicate the details of the user, time, and specifics of the action.
- Packages - creating, saving, deploying, tearing down or deleting generates audit logs, including the name of the package with a correlator ID.
- Queries - the entirety of the query path now provides an audit-idthat makes tracing your query across processes quick and easy.
- Stream Processor - Correlation IDs are now logged by the audit framework on successful and failed SP upload requests.
Entitlements
- Logs now comply with entitlements and restrict user access to logs they are not entitled to see. In the Diagnostics page of the web interface, users cannot see logs for a deployed database(s)/pipeline(s) unless they are entitled to the related package.
Access to logs is now restricted based on entitlements, but pipelines deployed using UI will still be open to everyone.
New SQL Operators
- SQL2 now supports the following new operators: - reverse
- char_length
- character_length
- bit_length
- length
- octet_length
 
Parquet Reader
- 
A local file watcher has been added for the Parquet reader. Read the q and Python documentation for details. 
- 
The Parquet reader now allows you to specify the file path as a symbol. 
Stream Processor
- The Python API has been updated to include .qsp.trackfunctionality that the q API already supports. Read the track page for details.
Scratchpads
- 
Any running scratchpad pods are now torn down when Insights is uninstalled. 
- 
You may now enable Beta Features in the scratchpad or in Quick Test by simply setting an Environment Variable value. To enable beta features, set the environment variable KXI_SP_BETA_FEATUREStotrue.
Streaming to Views
- 
The Views JSON filter now supports a list of values. For example: {"sym": ["EUR/USD","GBP/USD"]}
Database Column Re-sorting
- It is now possible to change the defined sort column of a table(s) for an existing database. This is an expensive, long-running operation for existing, large-scale databases. This should be considered before execution. For this reason, it is not enabled by default. To use, set the environment variable KXI_SM_ALLOW_CHANGE_SORT_COLS=1in Storage Manager and then follow the steps for modifying a schema.
Fixes
Expand to see the full detail of resolved issues here
Database
- 
Resolved an issue in which Storage Manager's RAM requirements increased for batch ingest operations. This has been returned to resource levels in line with release 1.10. 
- 
Previously, a failed end-of-day writedown (EOD) was not retried by the Storage Manager, causing a misaligned error on the next EOD. 
- 
Fixed an issue when the Database was not being identified as having unsaved changes when primary keys were changed. 
- 
Fixed an issue where DAP code assumed the values of assembly mount names was one of "RDB", "IDB", or "HDB". This has been resolved to allow for mount names of any description. 
- 
Resolved an issue where a SQL2 query would have produced a typeerror when using aGROUP BYstatement with anORDER BYof a subset of the fields with no aggregation. For example,select sym,realTime from trade group by sym, realTime order by sym.
- 
Resolved an issue where a SQL2 query would have produced a typeerror when using aGROUP BYstatement with aDISTINCTand no other aggregation.
- 
Resolved an issue where a query for an empty date could fail when late data is turned on. 
- 
Previously, if a Stream Processor published a message to a subscriber node that contained a null float, and the WebSocket client reads the messages in JSON, the Service Gateway would error with NaN is not a valid double value as per JSON specificationerror. This has been resolved.
Entitlements
- 
The Viewer role was previously unable to run UDAs. This would result in Views using a custom API to fail with a permissions error and not be able to view the data. This has been resolved. 
- 
The Entitlement Service was not starting when a Proxy was enabled. This has been resolved. 
Packages
- 
Previously, when entitlements were turned on, you could not load a package in the scratchpad using Python, or use a Python UDF. This has been resolved. 
- 
Resolved a previously-reported known issue that occurred when you removed a pipeline from a database, and packaging preserved this pipeline in a separate package to ensure it was not permanently deleted. However, the pipeline was still available in the web interface. Any re-pushing of the package from the CLI would cause the pipeline to exist in two packages, with the web interface serving the wrong version. 
Views
- 
Resolved formatting issues that would occur when a user with no write access was on a Views tab. 
- 
On the Views API form, a parameter of type stringwas displayed incorrectly aslist. This has been resolved.
Readers
- 
An issue where the user could not aggregate data as part of the DB Reader in the web interface, and in certain cases when using the API, has been fixed. This also includes that fillis only sent if explicitly specified.
- 
Using a Parquet reader with a glob pattern would error when trying to find or read a file. This has been resolved. 
- 
Fixed an edge-case issue where a length error would occur Failed to initialize worker, worker name=[sample name] error=lengthwhen using glob patterns with file names.
- 
Users will no longer see a warning icon in the web interface when deploying pipelines that involve readers and writers without intra-day write-down support. Instead, an informational message will be logged. This is to be expected in this scenario and there is no action required from the user. 
- 
The discrepancy in how AWS and Azure Cloud readers retained an extra newline character when reading in text mode without chunking, while the Google Cloud reader correctly did not, has now been resolved. 
- 
When establishing a secret used for GCP authentication for a Parquet reader, a pipeline would fail with a Worker failed to start: Unable to locate credentials secreterror.
File Watchers
- Passing in a dictfor thewatchparameter was not working correctly. Furthermore, use of the additional options the web interface provides whenUse Watchingtick box meant adictwas used, and therefore also failed. This has been resolved.
Pipelines
- In the web interface, using the "Copy pipeline" button on the Database Details page would result in the pipeline being copied, but with a default graph pipeline instead of the actual pipeline code. This has been resolved.
Third-party Dependencies
kdb Insights Enterprise 1.12.0 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.12.0 release of the standalone infrastructure installation scripts.
Please consult these pages for important information on supported versions:
Artifacts
KX Nexus
The KX Nexus repository will be sunsetted in the future. Nexus links on this page are provided as a temporary alternative to the KX Downloads Portal for existing users. The KX Downloads Portal is the preferred repository for all use cases and KX Nexus links will be removed once the KX Nexus repository is decommissioned.
| type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.12.0.tgz | insights-1.12.0.tgz | 
| Operator | kxi-operator-1.12.0.tgz | kxi-operator-1.12.0.tgz | 
| CLI | kxicli-1.12.0-py3-none-any.whl | kxicli-1.12.0-py3-none-any.whl | 
| RT C interface | kxi-c-sdk 1.12.0 | kxi-c-sdk 1.12.0 | 
| RT Python interface | kxi-rtpy-1.12.0 | kxi-rtpy-1.12.0 | 
| RT Java interface | kxi-java-sdk 1.12.0 | kxi-java-sdk 1.12.0 | 
| Infrastructure | kxi-terraform-1.12.0.tgz | kxi-terraform-1.12.0.tgz | 
| kxi-management-service | kxi-management-service-0.2.4.tgz | kxi-management-service-0.2.4.tgz | 
| insights-on-k8s | insights-on-k8s-0.2.3.tgz | insights-on-k8s-0.2.3.tgz | 
Upgrading to kdb Insights Enterprise 1.12
Before upgrading to 1.12 it is necessary to upgrade to the 1.12 CLI.
If upgrading to 1.11 from a prior version before to upgrading to 1.12, you would need to upgrade your CLI and ensure an encryption secret has been created first. See below for details.
You can create an encryption secret by running the kxi install create-encryption-key command as follows:
kxi install create-encryption-key
By default a secret called kxi-encryption-secret is created. If you wish to use a different name for the secret you can either:
- Specify the secret name when running the command and update your installation configuration file to use it:- Run the following, replacing dare-secret-valuewith your chosen secret name:kxi install create-encryption-key --database-encryption-secret dare-secret-value
- Merge the text below into your existing installation configuration file, replacing dare-secret-valuewith your chosen secret name:global: encryption: auth: existingSecret: dare-secret-value
 
- Run the following, replacing 
- Use kxi install setupand merge the output with your existing configuration file:- Run kxi install setupwhich will automatically generate an encryption secret if one doesn't already exist, prompting you for a secret name.
- Merge the configuration output file from this command with your existing configuration file by referring to applying configuration changes.
 
- Run 
With either method of generating an encryption secret, if a secret already exists with the name specified, it is not overwritten. To replace a secret, you must delete the existing secret and then a create a new one.
Read ecryption secret for more information on secrets and how to administer them.
Upgrade/Rollback Notes for 1.12
If performing a rollback from 1.12.x to any earlier version, assemblies must not be running prior to initiating the rollback to ensure no data is lost. See Upgrading for how to perform upgrades/rollbacks and the available commands to use. Please see the following specific instructions per version:
For rollback from 1.12.x to 1.12.0:
- Rollback kdb Insights Enterprise per the rollback instructions referenced above.
For rollback from 1.12.x to 1.11.x:
- Teardown your package(s).
- Run the kxi-db-rollback chart with the following command for each package in turn, substituting the desired values:
helm install rollback kx-insights/kxi-db-rollback --version="[current Insights version]" --set rollback.assembly="[your-package-name]" --set rollback.version="[Insights version to rollback to]" -f[your values.yaml file]
Uninstall the rollback chart between each invocation of the kxi-db-rollback chart:
helm uninstall rollback
Repeat this step until all packages have been processed (including any which weren't deployed).
- Rollback kdb Insights Enterprise per the rollback instructions referenced above.
- Redeploy the packages which you tore down.
For rollback from 1.12.x to 1.10.x:
- Teardown your package(s).
- Run the kxi-db-rollback chart with the following command for each package in turn, substituting the desired values:
helm install rollback kx-insights/kxi-db-rollback --version="[current Insights version]" --set rollback.assembly="[your-package-name]" --set rollback.version="[Insights version to rollback to]" --set rollback.currentVersion="[current Insights version]" -f[your values.yaml file] 
Uninstall the rollback chart between each invocation of the kxi-db-rollback chart:
helm uninstall rollback
Repeat this step until all packages have been processed (including any which weren't deployed).
- Rollback kdb Insights Enterprise per the rollback instructions referenced above.
- Redeploy the packages which you tore down.
Additional Upgrade Notes
Draft Databases & Pipelines
- As of 1.11, draft databases and pipelines that have never been saved will not be available for use. If you have draft databases or pipelines stored in your browser, they will need to be deleted. Alternatively, save your draft databases and pipelines prior to upgrade. Please be aware of this if you are upgrading to 1.11 before moving to 1.12.
Known Issues
Expand to see the list of known issues here
Cleaning up entities
- WARNING: When tearing down a package in the web interface, the option to Clean up entities after teardown WILL DELETE ALL DATA, despite the note in the pop-up window stating the opposite: Data that has already been written down will NOT be affected. To avoid data deletion, DO NOT select the Clean up entities option. If a partial clean-up is required, use the relevantkubectlCLI commands instead.
PostGreSQL & Keycloak Resiliency
- A transient issue can occur in which Keycloak is unable to re-establish a connection to PostgreSQL after it recovers from an outage. This can result in getDatabeing unable to serve queries. To work around this, restart PostgreSQL.
Upgrades & Rollbacks
- Users are prompted to tear down assemblies upon rollback. The rollback should exit if the user responds ‘n' to this prompt. Instead, the rollback continues.
Deprecations
- 
The kxi packagecommands for remote operations has been deprecated as of the 1.12 release.kxi pmoffers full functional equivalency.- pull
- push
- remote-list
- remote-remove
- remote-convert
- remote-config
- deploy
- teardown
 
- 
The RT Bridge has been deprecated as of the 1.12 release. The rt.qpk now offers full functional equivalency to the RT bridge so it is recommended to migrate to it prior to RT Bridge being removed. 
Summary
We hope you find some useful features that optimize your kdb Insights Enterprise experience. Try them out and email our Support Team if you need any help.
We look forward to bring you even bigger features in kdb Insights Enterprise 1.13 coming soon!
1.11.2
Release Date 2025-02-19
Fixes
Expand to see the full detail of resolved issues here
Database
- 
Manually set the wait time between attempts to perform mkhlinkoperations during database conversion.
- 
kdb Insights Enterprise 1.11 introduced an increase in memory allocation for batch ingest. This has been reverted. 
Query
- The Viewer role did not have permissions to run UDAs. This has been resolved.
Security
- Various CVEs were remediated as part of this release.
Third-party Dependencies
kdb Insights Enterprise 1.11.2 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.11.2 release of the standalone infrastructure installation scripts.
Artifacts
KX Nexus
The KX Downloads Portal is the preferred repository for all use cases and KX Nexus links will be removed once the KX Nexus repository is decommissioned. Nexus links on this page are provided as a temporary alternative to the KX Downloads Portal for existing users.
| type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.11.1.tgz | insights-1.11.1.tgz | 
| Operator | kxi-operator-1.11.0.tgz | kxi-operator-1.11.1.tgz | 
| CLI | kxicli-1.11.1-py3-none-any.whl | kxicli-1.11.1-py3-none-any.whl | 
| RT C interface | kxi-c-sdk 1.11.0 | kxi-c-sdk 1.11.0 | 
| RT Python interface | kxi-rtpy-1.11.0 | kxi-rtpy-1.11.0 | 
| RT Java interface | kxi-java-sdk 1.11.0 | kxi-java-sdk 1.11.0 | 
| Infrastructure | kxi-terraform-1.11.0.tgz | kxi-terraform-1.11.0.tgz | 
| kxi-management-service | kxi-management-service-0.2.3.tgz | kxi-management-service-0.2.3.tgz | 
| insights-on-k8s | insights-on-k8s-0.1.6.tgz | insights-on-k8s-0.1.6.tgz | 
1.11.1
Release Date 2024-11-04
Improvements
Parquet Reader
- 
A local file watcher has been added for the Parquet reader. See q and Python readers documentation for details. 
- 
The Parquet reader now supports specifying the file path as a symbol. 
Fixes
Expand to see the full detail of resolved issues here
Database
- 
Resolved an issue where a query for an empty date could fail when late data is turned on. 
- 
Previously, a failed end-of-day writedown (EOD) was not retried by the Storage Manager, causing a misalignederror on the next EOD.
Views
- 
When using user-defined analytics in Views, the parameter of type string (10h)was displayed as a list. This has been resolved to display properly as a string.
- 
When binding a viewstate to a string parameter, the binding was incorrectly removed after saving the data source. 
Pipelines
- The health status of a pipeline is now displayed on the Running Pipelines section of the homepage, in addition to the Pipelines page. Previously, these were displaying different types of information about pipeline status which was not clear.
Packaging
- 
Resolved an issue where filtering by name,id, etc. was not working correctly when listing pipelines or databases in the CLI (kxi package remote-list). This has been resolved.
- 
Resolved an issue where a package containing Patch objects could not be deployable. 
- 
Fixed a bug with kxi package packitwith--package-nameand/or--package-version. The original package will remain unmodified and the artifact will contain the source code.
- 
Fixed unresponsive package manager server (and UI). The connection between packagemanagerand Kubernetes now has a timeout, meaning that any stale connections will be dropped after 15 seconds, limiting any unresponsiveness to this timeframe.
Scratchpad
- The scratchpad manager was not setting the no proxyenvironment variable during install, as well as when any new pod was created as part of user login. This was manifesting asautherrors in the web interface when using the scratchpad.
Entitlements
- On the Pipeline screen, if you do not have the entitlements to both save and deploy a pipeline the "Save and Deploy" button has been separated into two distinct buttons. This addresses an issue in which users without write access permissions were unable to deploy a pipeline because they did not have permissions to save it.
Permissions
- Users with the Viewer composite role were unable to use qsql without adding the insights.query.custompermission. This caused views to appear broken after upgrading to 1.11.
Reliable Transport
- In the getLatestPositionAPI in thert.qpk, the dictionary keypeerswas not functional in 1.11.0. This has been resolved.
Readers
- 
Fixed an edge-case issue where an error occurred when using glob patterns with file names. 
- 
When establishing a secret used for GCP authentication for a Parquet reader, a pipeline would fail with a Worker failed to start: Unable to locate credentials secreterror.
- 
Using a Parquet reader with a glob pattern would error when trying to find or read a file. This has been resolved. 
Security
- Various CVEs were remediated as part of this release.
Third-party Dependencies
kdb Insights Enterprise 1.11.0 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.11.0 release of the standalone infrastructure installation scripts.
Artifacts
KX Nexus
The KX Downloads Portal is the preferred repository for all use cases and KX Nexus links will be removed once the KX Nexus repository is decommissioned. Nexus links on this page are provided as a temporary alternative to the KX Downloads Portal for existing users.
| type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.11.1.tgz | insights-1.11.1.tgz | 
| Operator | kxi-operator-1.11.0.tgz | kxi-operator-1.11.1.tgz | 
| CLI | kxicli-1.11.1-py3-none-any.whl | kxicli-1.11.1-py3-none-any.whl | 
| RT C interface | kxi-c-sdk 1.11.0 | kxi-c-sdk 1.11.0 | 
| RT Python interface | kxi-rtpy-1.11.0 | kxi-rtpy-1.11.0 | 
| RT Java interface | kxi-java-sdk 1.11.0 | kxi-java-sdk 1.11.0 | 
| Infrastructure | kxi-terraform-1.11.0.tgz | kxi-terraform-1.11.0.tgz | 
| kxi-management-service | kxi-management-service-0.2.3.tgz | kxi-management-service-0.2.3.tgz | 
| insights-on-k8s | insights-on-k8s-0.1.6.tgz | insights-on-k8s-0.1.6.tgz | 
1.11.0
Release Date 2024-09-20
kdb Insights Enterprise 1.11 brings increased security measures with data at rest encryption, continued improvements to the user experience with better visibility into service health, enhancements to stability and performance and so much more! See below for the full details.
New Features
- Data At Rest Encryption (DARE)
- Scratchpad optimizations
- Service health observability
- HTTP proxy support
- Reliable Transport's (RT) client replica size discovery
- Improvements to user-defined analytics
- PDF generation for Views
- LIMITsupport in- getData
- Live rolling View States
1. Data At Rest Encryption (DARE)
Encrypt all tables in your database using kdb+'s native DARE capability. When enabled, all on-disk data is encrypted using AES256CBC. DARE enables you to comply with your data security requirements. Read the encryption at rest section for details.
2. Scratchpad optimizations
Scratchpad optimizations provide a seamless scratchpad experience, ensuring responsiveness and minimizes the need for restarts. It addresses potential connectivity issues, CPU saturation, and memory constraints, while maintaining performance for uninterrupted service. Additionally, it provides scalable capacity to support user growth, significantly enhancing reliability and overall user satisfaction. Read the query docs for details on scratchpads. Note that previously, the default allocation for scratchpad resourcing was 8GB shared across all users - this has been updated to a default of 500MB per user. As a result, it is recommended you assess your workloads and user counts and then set your Scratchpad resourcing appropriately.
3. Service health observability
Enhancements to observability provide clearer visibility into the health of the underlying services, particularly where data flows through the system. You can now quickly identify and trace problems in your system without interrogating multiple service logs. This improvement speeds up root cause analysis and resolution, significantly reducing troubleshooting time. Read the health section for details.
4. HTTP proxy support
Configure seamless integration with customer proxies. Global environment variables (http_proxy, https_proxy, and no_proxy) are propagated to sub-components and third-party services, ensuring correct traffic routing and reliable pipeline deployment. Note this feature is only supported for Azure-based deployments, as only Azure Kubernetes Service supports kubelet services behind a proxy. Refer to deploying behind a proxy server for details.
5. Reliable Transport's (RT) Client Replica Size Discovery
Enhancements to RT simplify client connection and configuration setup. This includes automatic discovery of the cluster size, eliminating the need for clients to specify sizing manually and allowing for seamless resizing of the RT cluster. This change enhances the user experience by reducing the configuration needed and streamlining setup across all interfaces (C, q, Python, and Java). Explore the enhancements in Getting started.
6. Improvements to User Defined Analytics (UDAs)
We have enhanced the documentation and consolidated User Defined Analytics (UDAs) development into a single, unified API. This update simplifies the process for developers by eliminating the need for detailed internal system knowledge and streamlines API functionality across various components. This release also introduces the ability for a UDA to call another UDA. Read the UDA introduction for an overview of UDAs and details on how to use the new functions. In addition, please read the Deprecations section below, which outlines name changes to important functions.
7. PDF generation for Views
A PDF can now be created from your View(s) in kdb Insights Enterprise. This supports single and multiple tabs. Additionally, the Share Link View now supports dark mode and aligns with the dashboard design for a unified appearance. To learn how to use these new features, read the new docs.
8. limit support in getData
The getData API now supports a limit clause, allowing you to retrieve a subset of data (for example, the top 100 rows). This enhancement increases the reliability of queries on large datasets and offers more efficient data handling. It improves the user experience when running large queries, reducing the risk of the query failing. Read limit for details on how to use limit in getData. Refer to row limit for guidance on setting limits in the Query builder. You can also take advantage of this when using Views.
9. Live Rolling View States
View States have been enhanced to support rolling syntax to execute at times other than load time. Rolling syntax applies to temporal data and allows you to provide relative timestamps to be used in data source queries. Rolling view state can now be configured to run at dashboard load and at the data source’s polling interval. View the docs for details.
New Beta Features
Entitlements for Packages
Secure package creation and deployment, provides entitlements for user-created packages via the CLI. This ensures secure collaboration by protecting deployments and analytics from unauthorized access or changes. Read package entitlements for details. For reference, a full overview of packages can be found here and an overview of entitlements can be found here.
Improvements
Performance improvements for Storage Manager operations
- 
Optimizations in the Storage Manager have been made to improve the efficiency of schema conversions, including the introduction of multi-threading. This significantly reductes the time taken to perform a schema change operation. Read multi-threading for more details. 
- 
Reduction in the RAM required for re-enumeration when carrying out a batch ingest. 
- 
Adding/removing an object storage tier to existing databases is now supported. See here for details. 
Technology Migration for 3D Charts and Dashboards
jQuery and jQueryUI have been removed from 3D charts, and various Dashboard components have been migrated to newer technologies. This update addresses potential vulnerabilities related to cross-site scripting (XSS) and DOM manipulation, ensuring a more secure environment.
SQL
We have introduced support in SQL2 for the following:
- 
a new keyword OFFSET
- 
multi-directional ORDER BY. An example is seen below.select * from trade order by sym asc, price desc
getData API
The following improvements have been introduced in 1.11:
- support for descending and mixed sorting in getDatahas been added.
- getDatanow supports- OFFSETas part of its- limitimplementation. Read getData limits for details.
- getDatanow validates that functions are called with the correct number of parameters.
- the ability to bind view state variables easily into filter statements in getData. Refer to using-view-states for details.
File Watchers
- The local file reader now supports file watching. See the documentation for q and Python for details.
Pipelines
- 
Parallel operator nodes have been added to the web interface node library. With this, users can add multiple functions to run in parallel and define merge functions to merge their outputs. 
- 
The Pipeline editor now supports using the Ctrl+D/⌘D hotkey for executing code (in both Windows and Mac). 
Scratchpads
- 
The Stream Reader can now be used in a scratchpad by simply calling the API as documented. There is no longer the need to set environment variables KXI_SP_CHECKPOINT_DIRandRT_TOPIC_PREFIX.
- 
The Query window now supports specifying Ascending/Descending option for Sort filters. 
- 
Scratchpad now supports using the Ctrl+D/⌘D hotkeys for executing code (in both Windows and Mac). 
Accessibility
- Improvements have been made to the screen reader and keyboard accessibility:- On the Overview pages, the table listing pages now have a hidden element for screen readers that reads: “This table has no data" when no data is available for a table
- Elements are read in the order they appear on screen (Asc or Desc)
- The 'i' information icon on the Database setting screen is now reachable with the keyboard using the tab key
- In Database settings → Tier settings, the clock icon now displays a gray background when it is selected with the keyboard
 
CLI
- Improvements have been made to how the kxiclihandles failures in installation or upgrade in the following ways:- failure reasons are now printed after each retry
- default number of retries has been updated to 2
- timeouts are now exponentially increasing e.g. to 5m on the first try, increasing to 10m on the second try
- wait times are also expontentially increasing between retries
- provide additional options:- set the number of retries using the --retry-limitcommand
- set the initial wait between retries using the --retry-waitcommand
 
- set the number of retries using the 
 
Packages
- 
Packaging now allows the pushing of later versions of deployed packages, even while old versions are running. Previously, all pushes were blocked when a package was deployed. 
- 
Error messages are now clearer when an error is encountered during package load, showing the offending filename, line number and line contents if there is a syntax error in the schema definition. 
- 
kxi packagenow provides a straightforward way to view and set configuration parameters:For more information, run the commandkxi package config get Get local package manager configuration. kxi package config set Set local package manager configuration values.kxi package config --help.
- 
The command kxi package teardownnow takes a list. This allows you to provide more than one package to be torn down in a single command, and also supports use of regex strings to specify the targeted packages. See here for details.
- 
The details and readability of the kxi package field infocommand has been improved with the following:- Better descriptions of each type
- Color highlighting
- Helpful messages
- Improved error messages when package definitions are incorrect
 
- IDE Package files now include autocomplete and validation when modifying packages.
Fixes
Expand to see the full detail of resolved issues here
Database
- 
Fixed an issue where getData queries failed with a type error if the time range of the request landed completely between two IDB partitions. 
- 
Fixed an issue where getDatawas not correctly enlisting the target symbol when using<>like it does when using=.
- 
getDatanow validates that functions are called with the correct number of parameters.
- 
getDatafilters of the form["like", "col", x]wherecolis a string/symbol column andxis astring,symbol, orchar, now work without throwing a type error.
- 
Fixed an issue where getDataREST queries would produceinfinstead of a null.
- 
Batch ingest direct write pipelines now correctly honor compression and encryption settings of an HDB tier. 
- 
In the Advanced settings page on the Database configuration screen, it was possible to set the retention time for the HDB to a value less than one day using hours/minutes/seconds. This is not supported, and has been corrected so values less than one day are rounded up to a day upon loading. 
- 
Previously, there was no way for a user to specify the inventory path for the object storage tier of their HDB from the web interface. This is now possible to configure using the Tier Settings in the web interface. Providing an inventory path allows faster subsequent reloads for the SM and DAPs. 
Pipelines
- 
When configuring a pipeline in the web interface, setting additional workerThreadsdid not correctly apply the specified configuration. This has been resolved.
- 
Custom component fields were not being disabled correctly on deploy. This affected the Use Watchingfunctionality, and theDictionary,Apply Schema, andCSV Decoder Delimiterfields on the Pipelines screen. This has been resolved.
- 
Fixed issues with undo/redo options in the pipeline editor. 
- 
Pipelines were erroneously showing that they had unsaved changed in the tab bar and entity tree on the Pipelines page, even when no changes had been made. This has been resolved. 
- 
Previously, pipelines were allowed to be removed from a running databases. This has been resolved to block this action. 
Readers
- Resolved an issue where the Database reader was throwing type errors when filters were applied. These queries now function correctly, including in the Scratchpad UI.
UI
- 
Previously, different entity types (pipelines, views, queries, etc) could not have duplicate names. This has been corrected such that entities of different types can have the same name, but entities of the same type cannot. 
- 
A differentiator has been added to the tab menu to distinguish between a tab focused on a pipeline and a tab focused on the diagnostics of either a database or pipeline. This reduces confusion of multiple tabs with the same name. 
Packages
- The packaging CLI will now print a warning when its version doesn’t align with the package-managerserver.
Scratchpads
- If using Mozilla Firefox, the scratchpad in the web interface was accidentally switching tabs when selecting text. This has been resolved.
CLI
- 
When using the debug option in the CLI, kxi --debug installwas not being propagated throughout the install process. This has been resolved.
- 
Users were not being notified of issues when removing an enrolled client. This has been resolved. 
Security
- Various CVEs have been remediated as part of this release.
Third-party Dependencies
kdb Insights Enterprise 1.11.0 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.11.0 release of the standalone infrastructure installation scripts.
Artifacts
KX Nexus
The KX Nexus repository will be sunsetted in the future. Nexus links on this page are provided as a temporary alternative to the KX Downloads Portal for existing users. The KX Downloads Portal is the preferred repository for all use cases and KX Nexus links will be removed once the KX Nexus repository is decommissioned.
| type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.11.0.tgz | insights-1.11.0.tgz | 
| Operator | kxi-operator-1.11.0.tgz | kxi-operator-1.11.0.tgz | 
| CLI | kxicli-1.11.0-py3-none-any.whl | kxicli-1.11.0-py3-none-any.whl | 
| RT C interface | kxi-c-sdk 1.11.0 | kxi-c-sdk 1.11.0 | 
| RT Python interface | kxi-rtpy-1.11.0 | kxi-rtpy-1.11.0 | 
| RT Java interface | kxi-java-sdk 1.11.0 | kxi-java-sdk 1.11.0 | 
| RT Bridge | rt-bridge 1.7.0 | rt-bridge 1.7.0 | 
| Infrastructure | kxi-terraform-1.11.0.tgz | kxi-terraform-1.11.0.tgz | 
| kxi-management-service | kxi-management-service-0.2.3.tgz | kxi-management-service-0.2.3.tgz | 
| insights-on-k8s | insights-on-k8s-0.1.6.tgz | insights-on-k8s-0.1.6.tgz | 
Upgrading to kdb Insights Enterprise 1.11
Before upgrading to 1.11 it is necessary to upgrade to the 1.11 CLI and ensure an encryption secret has been created.
You can create an encryption secret by running the kxi install create-encryption-key command as follows:
kxi install create-encryption-key
By default a secret called kxi-encryption-secret is created. If you wish to use a different name for the secret you can either:
- Specify the secret name when running the command and update your installation configuration file to use it:- Run the following, replacing dare-secret-valuewith your chosen secret name:kxi install create-encryption-key --database-encryption-secret dare-secret-value
- Merge the text below into your existing installation configuration file, replacing dare-secret-valuewith your chosen secret name:global: encryption: auth: existingSecret: dare-secret-value
 
- Run the following, replacing 
- Use kxi install setupand merge the output with your existing configuration file:- Run kxi install setupwhich will automatically generate an encryption secret if one doesn't already exist, prompting you for a secret name.
- Merge the configuration output file from this command with your existing configuration file by referring to applying configuration changes.
 
- Run 
With either method of generating an encryption secret, if a secret already exists with the name specified, it is not overwritten. If you want to replace one, you must delete the existing secret and then a create a new one.
See here for more information on secrets and how to administer them.
Additional Upgrade Notes
Draft Databases & Pipelines
- As of 1.11, draft databases and pipelines that have never been saved will not be available for use. If you have draft databases or pipelines stored in your browser, they will need to be deleted. Alternatively, save your draft databases and pipelines prior to upgrade.
Known Issues
Expand to see the list of known issues here
PostGreSQL & Keycloak Resiliency
- A transient issue can occur in which Keycloak is unable to re-establish a connection to PostgreSQL after it recovers from an outage. This can result in getDatabeing unable to serve queries. To work around this, restart PostgreSQL.
Pipelines
- 
Pipelines that use Apply nodes from releases older than 1.9 will fail on deployment after upgrading. To work around this, after performing your upgrade, open the pipeline, click on Apply node, click the gear icon in the top corner of the node-config area, and then set the parameters manually (for most apply nodes this will be operator, metadata, data). 
- 
Deploying a pipeline from the web interface marks it as having unsaved changes even when none exist. Clicking Save again resolves this issue. 
Upgrades & Rollbacks
- Users are prompted to tear down assemblies upon rollback. The rollback should exit if the user responds ‘n' to this prompt. Instead, the rollback continues.
Packaging
- 
If using entitlements (currently in BETA), you cannot load a package in the scratchpad using Python or using a Python UDF. 
- 
In the web interface, when you remove a pipeline from a database, packaging preserves this pipeline in a separate package to ensure it is not permanently deleted. This means the pipeline is still available in the web interface. However, if you re-push the package from the CLI that still contains the pipeline, the pipeline now exists in two packages, and the latest version of the pipeline is not being served to the web interface. The workaround is to remove the pipeline-only package that has been created. 
New Requirements for Hostnames & kxi package
- When you run a kxi packagecommand, thekxi clifirst authenticates against kdb Insights Enterprise. In 1.9, running akxi packagecommand would look up the cached hostname that had been previously authenticated against in the~/.insights/credentialsfile. In 1.10.0, the hostname previously authenticated against is no longer used. Instead, you must set the hostname in your~/.insights/cli-config.
Deprecations
- 
As a result of the improvements to how user-defined analytics work, the following functions are being deprecated, but are still be available to use: - .kxi.selectTablehas gone from a 6-parameter function to a single function that takes a single dictionary argument.
- .da.getTableMemreplaced by- .kxi.getTableBuffer
- .da.getTableDeltareplaced by- .kxi.getTableOverflow
- .da.i.dapType(variable) replaced by- .kxi.getDapType function
- .sapi.{ok,hok}replaced by- .kxi.response.{ok,hok}
- .sapi.responsereplaced by- .kxi.response.make
- .sapi.deferreplaced by- .kxi.response.callAPI
- DAP UDAs must return a response with one of the .kxi.response.{*}functions, e.g..kxi.response.ok
- .da.registerAPIand- .sgagg.registerAggFnreplaced by- .kxi.registerUDA
- .sapi.meta{Param,Return,Description,Misc}replaced by- .kxi.meta{Param,Return,Description,Misc}
- .kxi.getMetav2 replaced by v3.
- KXI_SAPI_HB_{FREQ,TOL}replaced by- KXI_HB_{FREQ,TOL}
 
- 
When configuring a process (Aggregator, DAP, RC) , the environment variable KXI_SAPI_HB_FREQset the time in milliseconds to run the heartbeat to connected processes, andKXI_SAPI_HB_TOLto set the number of heartbeat intervals a process can miss before being disconnected (default: 2). These variables have been updated to remove the deprecated reference to SAPI (see above). These configurations are nowKXI_HB_FREQandKXI_HB_TOLrespectively. The old values will be supported but are deprecated, and will be sunsetted in future.
Summary
We hope you find some useful features that optimize your kdb Insights Enterprise experience. Try them out and email our Support Team if you need any help.
We look forward to bring you even bigger features in kdb Insights Enterprise 1.12 coming soon!
1.10.3
Release Date 2025-02-17
Fixes
Expand to see the full detail of resolved issues here
Database
- 
EOI process used wrong date field for deduplicating EOD signals. 
- 
Removed calls to mount and run .Q.cnon EOI events in the HDB. These calls were redundant as the underlying historical database does not change on EOI. Retaining them potentially impacted performance.
- 
Resolved an issue where the IDB could return out-of-purview records, potentially causing duplicates in the response to the caller. 
Reliable Transport
- If publishers to RT have been restarting regularly over a prolonged period (over 15k restarts) then the replicators will fail to start due to a build up of log files. This issue has been resolved. .
Third-party Dependencies
kdb Insights Enterprise 1.10.3 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.10.3 release of the standalone infrastructure installation scripts.
Artifacts
KX Nexus
The KX Nexus repository will be sunsetted in the future. Nexus links on this page are provided as a temporary alternative to the KX Downloads Portal for existing users. The KX Downloads Portal is the preferred repository for all use cases and KX Nexus links will be removed once the KX Nexus repository is decommissioned.
| type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.10.3.tgz | insights-1.10.3.tgz | 
| Operator | kxi-operator-1.10.1.tgz | kxi-operator-1.10.1.tgz | 
| CLI | kxicli-1.10.1-py3-none-any.whl | kxicli-1.10.1-py3-none-any.whl | 
| RT C interface | kxi-c-sdk 1.10.0 | kxi-c-sdk 1.10.0 | 
| RT Python interface | kxi-rtpy-1.10.0 | kxi-rtpy-1.10.0 | 
| RT Java interface | kxi-java-sdk 1.10.0 | kxi-java-sdk 1.10.0 | 
| RT Bridge | rt-bridge 1.7.0 | rt-bridge 1.7.0 | 
| Infrastructure | kxi-terraform-1.10.1.tgz | kxi-terraform-1.10.1.tgz | 
| kxi-management-service | kxi-management-service-0.2.4.tgz | kxi-management-service-0.2.4.tgz | 
| insights-on-k8s | insights-on-k8s-0.1.6.tgz | insights-on-k8s-0.1.6.tgz | 
1.10.2
Release Date 2024-10-18
Fixes
Expand to see the full detail of resolved issues here
Database
- 
Fixed a getDataissue where joining reference data to a partitioned table returned incorrect reference data values.
- 
Performance improvements have been made to partition column filtering operations in the getDataAPI.
- 
Removed unnecessary calls to mount and run .Q.cnon EOI events in the HDB, which impacted performance.
- 
Resolved an issue with the directWritemethod where batch data ingestion failed when not sorted according to IDB sort configuration.
- 
Resolved a crash issue caused by compressed data in websocket streams. 
Reliable Transport
- Enhanced Reliable Transport (RT) stability by resolving SIGSEGV: Fault addresserrors in RT q subscribers. These events could result in a subscriber being unable to receive and process data, and service subsequent queries.
User Interface
- Corrected the "Production Replicas" and "Exploratory Replicas" summary information in the Save & Deploy preview during database deployment.
Readers
- Resolved an issue with the s3 reader in which a lengtherror occurred in the Stream Processor when using glob patterns with file names.
Security
- Various CVEs were remediated as part of this release.
Third-party Dependencies
kdb Insights Enterprise 1.10.2 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.10.0 release of the standalone infrastructure installation scripts.
Artifacts
KX Nexus
The KX Nexus repository will be sunsetted in the future. Nexus links on this page are provided as a temporary alternative to the KX Downloads Portal for existing users. The KX Downloads Portal is the preferred repository for all use cases and KX Nexus links will be removed once the KX Nexus repository is decommissioned.
| type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.10.2.tgz | insights-1.10.2.tgz | 
| Operator | kxi-operator-1.10.1.tgz | kxi-operator-1.10.1.tgz | 
| CLI | kxicli-1.10.1-py3-none-any.whl | kxicli-1.10.1-py3-none-any.whl | 
| RT C interface | kxi-c-sdk 1.10.0 | kxi-c-sdk 1.10.0 | 
| RT Python interface | kxi-rtpy-1.10.0 | kxi-rtpy-1.10.0 | 
| RT Java interface | kxi-java-sdk 1.10.0 | kxi-java-sdk 1.10.0 | 
| RT Bridge | rt-bridge 1.7.0 | rt-bridge 1.7.0 | 
| Infrastructure | kxi-terraform-1.10.1.tgz | kxi-terraform-1.10.1.tgz | 
| kxi-management-service | kxi-management-service-0.2.4.tgz | kxi-management-service-0.2.4.tgz | 
| insights-on-k8s | insights-on-k8s-0.1.6.tgz | insights-on-k8s-0.1.6.tgz | 
1.10.1
Release Date 2024-07-24
Fixes
Expand to see the full detail of resolved issues here
Packaging
- 
Resolved an issue in version 1.10.0 where, when removing a pipeline from a package using the UI, the pipeline would revert to a default pipeline specification instead of being removed. 
- 
Resolved an issue where adding a pipeline into two databases caused the UI to not behave correctly. 
Database
- 
Fixed an issue where getDataqueries would fail with a type error if the time range of the request landed completely between two IDB partitions.
- 
An embedded assembly Resource Coordinator could become unreachable if its connection with the Service Gateway dropped. 
- 
Batch ingest has been modified to reduce the amount of RAM required for re-enumeration and sorting during a batch ingest operation. 
- 
Fixed an issue where batch ingest in directWritemode did not properly applyprimaryKeysto the data. Prior to this release, the data would not be properly collapsed, resulting in multiple rows for each primary key being persisted to disk. See the following example:
The data was ingested using batch ingest with `directWrite` mode enabled into table `t` that has primary keys configured as `pk1`, `pk2`
pk1 pk2 val
-----------
a   1   0
a   1   1
b   1   2
b   2   3
b   1   4
c   4   5
Prior to this release, the below data would be persisted to disk in the HDB:
pk1 pk2 val
-----------
a   1   0
a   1   1
b   1   2
b   2   3
b   1   4
c   4   5
The behavior has been fixed to correctly apply the primary keys to the data, meaning that the below rows would now be persisted to the HDB:
pk1 pk2 val
-----------
a   1   1
b   1   4
b   2   3
c   4   5
If tables are configured with primary keys, then after upgrading to 1.10.1, you may notice a decrease in the number of records being persisted when compared to data in older partitions. This is due to the corrected behavior.
If you have data from a prior release that was ingested via batch ingest with directWrite mode enabled, it is possible to correct it. For assistance with this, contact KX Support.
Readers
- Fixed an issue where the Stream Processor database reader would throw an error when any filters were specified.
Pipelines
- In version 1.10.0, pipelines with an Applynode(s) from releases older than version 1.9 would fail on deployment. This has been resolved, and older pipelines that useApplynodes now work as expected without any user action required.
Third-party Dependencies
kdb Insights Enterprise 1.10.1 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.10.0 release of the standalone infrastructure installation scripts.
Artifacts
KX Nexus
The KX Nexus repository will be sunsetted in the future. Nexus links on this page are provided as a temporary alternative to the KX Downloads Portal for existing users. The KX Downloads Portal is the preferred repository for all use cases and KX Nexus links will be removed once the KX Nexus repository is decommissioned.
| type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.10.1.tgz | insights-1.10.1.tgz | 
| Operator | kxi-operator-1.10.1.tgz | kxi-operator-1.10.1.tgz | 
| CLI | kxicli-1.10.1-py3-none-any.whl | kxicli-1.10.1-py3-none-any.whl | 
| RT C interface | kxi-c-sdk 1.10.0 | kxi-c-sdk 1.10.0 | 
| RT Python interface | kxi-rtpy-1.10.0 | kxi-rtpy-1.10.0 | 
| RT Java interface | kxi-java-sdk 1.10.0 | kxi-java-sdk 1.10.0 | 
| RT Bridge | rt-bridge 1.7.0 | rt-bridge 1.7.0 | 
| Infrastructure | kxi-terraform-1.10.1.tgz | kxi-terraform-1.10.1.tgz | 
| kxi-management-service | kxi-management-service-0.2.4.tgz | kxi-management-service-0.2.4.tgz | 
| insights-on-k8s | insights-on-k8s-0.1.6.tgz | insights-on-k8s-0.1.6.tgz | 
1.10.0
Release Date 2024-06-20
The main focus of this kdb Insights 1.10 release is a set of incremental updates designed to simplify system administration and streamline user experience.
New Features
- SQL2 now supports joins
- Standardized Auditing
- Environment Variables in Packages
- kxi-pythonnow supports publish, query and execution of custom APIs
- Publishing to Reliable Transport (RT) using the CLI
- Stream Processor supports subscribing to the end of an RT stream
- Schema Conversion Progress Indicator
- Natural language descriptions included in getMeta descriptions
- Cost Reduction Options for Reliable Transport
1. SQL2 now supports joins
Joins support in SQL2 enables you to combine multiple tables and/or dictionaries in your workflows using either INNER, LEFT, RIGHT, FULL, or CROSS joins. To find out more about streamlining your data connectivity across datasets, refer to the joins documentation.
2. Standardized Auditing
Standardized auditing provides reliable and consistent event logging, bolstering system security, and event accountability. The new structured framework introduced in this release adapts to current and future auditing needs aligned with specific services, to ensure comprehensive monitoring and robust accountability. Find out more about the audit framework in the Logging documentation.
3. Environment Variables in Packages
Environment Variables in Packages enables administrators to inject environment variables at runtime and dynamically pass values to both the database and pipelines. Variables can be set globally or per component and are applicable for custom analytics through global settings. Learn how to implement environment variables in the Package deployment documentation.
4. kxi-python now supports publish, query and execution of custom APIs
The Python interface to kdb Insights Enterprise, kxi-python, has been extended to allow for publishing to your kdb Insights Enterprise deployment. Refer to the documentation as a guide for how to both publish and query data using it. kxi-python also now supports the execution of custom APIs against your deployment, as shown in this example. These enhancements promote a stronger developer experience by significantly improving efficiency and streamlining workflows.
5. Publishing to Reliable Transport (RT) using the CLI
You can now use KXI CLI to publish ad-hoc messages to kdb Insights Enterprise using Reliable Transport. This change empowers you to use tools such as VS Code to publish data directly to the database, simplifying integration and real-time insights. This documentation demonstrates how to publish data using the CLI to kdb Insights Enterprise.
6. Stream Processor supports subscribing to the end of an RT stream
This release introduces the ability to subscribe to the end of an RT Stream. When configuring the kdb Insights Stream reader, it now provides an end parameter which will subscribe to the latest position in the stream instead of the beginning. This enables late joiners to reduce consumption and enhancing operational efficiency. Refer to the documentation links to learn more:
7. Schema Conversion Progress Indicator
A new schema conversion progress indicator provides data engineers and developers with visibility of the schema conversion process, including progress and error reporting.
This is a useful tool for monitoring the progress of schema conversions, especially for large data sets which require a significant amount of time.
8. Natural language descriptions included in getMeta descriptions
getMeta descriptions now include natural language descriptions of tables and columns in its result, enabling you to attach and retrieve detailed descriptions of database structures. Read more in our documentation.
9. Cost Reduction Options for Reliable Transport
An alternative topology for a publisher to choose when sending data to RT has been added. This alternative has the advantage of reducing the ingress bandwidth to a third of what the default topology requires. This could offer significant cost savings where ingress data incurs charges. Refer to the documentation for details.
Improvements
Performance Improvements in getData
For queries that span multiple partitions, getData has been optimized to improve the query execution times.
End-of-Interval Memory Optimization
End-of-Interval (EOI) Memory Optimization ensures that large, splayed tables are automatically cleared at EOI. This enhances memory efficiency and reduces RAM dependency, resulting in accelerated system performance and smoother system operations. There is no user configuration required to take advantage of this enhancement. See the documentation for information on splayed tables.
Updated Entitlement Administration
The commands to use entitlements with the CLI have changed. Refer to Configuring data entitlements for details.
getData REST Request Filtering
REST requests in getData now support filtering on time, minute, and timespan data type fields. 
Streaming JSON responses over HTTP in the Service Gateway
The Service Gateway (SG) now supports returning JSON responses in a streaming fashion without the need to compress the result. This helps reduce the necessary amount of RAM the SG needs in order to handle larger payloads. The environment variable KXI_SG_STREAM_THRESHOLD will allow you to configure your chosen chunk size for splitting up the overall response. This capability is automatic in the Service Gateway and does not require any user configuration. See the documentation here for more details. 
Customizable Polling Frequency in File Watchers
Cloud-polling file watchers now support the ability to configure the frequency in which polling for new files is done. When configuring a pipeline, the Use Watching checkbox provides a Timer option for selecting a frequency to poll by. See the documentation describing the optional parameter. 
Stream Processor Kafka Writer
The SP Kafka Writer now supports an options parameter for specifying advanced configuration on the Kafka broker connection. Previously, it only supported advanced configuration on the topic via the topicConfig parameter. See the documentation for information. 
Filtering Rows in Views
Data sources in Views now support the Max Rows option that limits the maximum number values displayed.
Select Columns
In the UI Query screen, it is now possible to filter a query by a selected column(s) to refine the data returned by the query. This allows users to reduce payload sizes and avoid potentially running out of RAM.
Streaming to Views
Streaming data sources now include a Max Rows option which facilitates the use of a rolling window chart that shows the last x number of points.
The Streaming to Views walkthrough has been updated with a new section Filtering based on a dropdown to show how to filter a Data Grid to a specific value from a list.
Fixes
Expand to see the full detail of resolved issues here
Database
- 
For a new system with an empty database, queries would not work after the first end-of-day data writedown if no data had been ingested yet. This issue has been resolved. 
- 
Previously, a user would need to manually edit their par.txtfile if the object storage location information was changed. This has been resolved so thatpar.txtis updated automatically after completing the required restart.
- 
The UI was erroneously reporting that a schema change was in progress in cases where an error in conversion had occurred. This issue has been resolved. 
- 
When using nested filters in getDataon keyed partitioned tables with late data, updates to on-disk data were not being reflected in the output ofgetData, if the data had not yet been written to disk. This issue has been resolved.
- 
Importing a database from object storage is now correctly sourcing the database's sym file upon initialization of the Storage Manager. 
- 
Previously, getDataREST queries would produceinfinstead of a null. Thisinfresponse would break most JSON parsers. This issue has been resolved.
- 
Prior to 1.10.0, the Service Gateway was configuring the minimum heap size to retain equal to the container requests. This could result in the container holding onto unused memory and not releasing it back to the OS. Additionally, the gateway was not setting an explicit size for off-heap memory used by IO messages, which could result in using a combined total of heap and off heap memory exceeding the container limit. To avoid both of these issues, set JAVA_OPTSexplicitly. Use-Xmsto set the minimum heap size to always retain,-Xmxto set the maximum heap size, and-XX:MaxDirectMemorySizeto set the maximum size used for IO messages off heap. We recommend splitting the container limits equally between heap and IO.Example configuration of 256Mb minimum reserved heap and 2G limit, split into 1g for heap and direct memory: `JAVA_OPTS="-Xms256M -Xms1G -XX:MaxDirectMemorySize=1G"`
Reliable Transport
- Previously, the RT client could fail to recognize a new log file, forcing downstream subscribers into a hung state. This has been resolved.
UI
- 
On the Resource tab, incorrect database resource summary values were displayed when no limits were specified. Now, if the limit value is empty, the request value is used to calculate summary values. 
- 
Previously, the /detailsAPI didn't always show pipelines that were still in aTEARING_DOWNstatus.
- 
When configuring a pipeline in the UI, setting additional workerThreads did not correctly apply the specified configuration. However, setting the environment variable KXI_DEFAULT_SP_WORKER_THREADSdid work. This has been resolved so either method can be used.
Cloud Readers
- 
A file watcher in Azure reader did not work for test or full deploys. 
- 
An issue has been resolved where, when administering a pipeline, a cloud reader node (s3, ms, and gs) could prompt you that there were unsaved changes even when no changes have been made. 
Packages
- 
Package names created in the CLI are now restricted to only use lower case letters and limited to 24 characters, inline with the GUI and Kubernetes restrictions. Previously, the deployment would fail because Kubernetes was unable to deploy an assembly with capital letters in its name. 
- 
Previously, exporting a pipeline did not complete successfully. This is now fixed. 
Kubernetes Discovery
- Previously, the KXI_RC_LABEL_SELECTORfield was not being correctly honored, causing Kubernetes discovery to become non-functional.
Scratchpads
- Using a file watcher (ex. await pending file) was not working in a Scratchpad session.
Security
- Various CVEs have been remediated as part of this release.
Third-party Dependencies
kdb Insights Enterprise 1.10.0 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.10.0 release of the standalone infrastructure installation scripts.
Artifacts
KX Nexus
The KX Nexus repository will be sunsetted in the future. Nexus links on this page are provided as a temporary alternative to the KX Downloads Portal for existing users. The KX Downloads Portal is the preferred repository for all use cases and KX Nexus links will be removed once the KX Nexus repository is decommissioned.
| type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.10.0.tgz | insights-1.10.0.tgz | 
| Operator | kxi-operator-1.10.0.tgz | kxi-operator-1.10.0.tgz | 
| CLI | kxicli-1.10.0-py3-none-any.whl | kxicli-1.10.0-py3-none-any.whl | 
| RT C interface | kxi-c-sdk 1.10.0 | kxi-c-sdk 1.10.0 | 
| RT Python interface | kxi-rtpy-1.10.0 | kxi-rtpy-1.10.0 | 
| RT Java interface | kxi-java-sdk 1.10.0 | kxi-java-sdk 1.10.0 | 
| RT Bridge | rt-bridge 1.7.0 | rt-bridge 1.7.0 | 
| Infrastructure | kxi-terraform-1.10.0.tgz | kxi-terraform-1.10.0.tgz | 
| kxi-management-service | kxi-management-service-0.2.3.tgz | kxi-management-service-0.2.3.tgz | 
| insights-on-k8s | insights-on-k8s-0.1.6.tgz | insights-on-k8s-0.1.6.tgz | 
Upgrade/Rollback Notes
New Requirements for Hostnames & kxi package
When you run a kxi package command, the kxi cli first authenticates against kdb Insights Enterprise. In 1.9, running a kxi package command would look up the cached hostname that had been previously authenticated against in the ~/.insights/credentials file. In 1.10.0, the hostname previously authenticated against is no longer used. Instead, you must set the hostname in your ~/.insights/cli-config. 
Views Impacted On Rollback
If you perform a rollback from version 1.10 to 1.9.x, all Views disappear from the UI due to the package manifest file being changed from 'reports' to 'views' in 1.10. The workaround is to pull the package from the package-manager server, manually change 'views' to 'reports' and push the package back to the server.
kxi package pull <package>/<version>
kxi package unpack <package>-<version>.kxi
mv <package>/views <package>/reports
sed -i 's/views:/reports:/g' <package>/manifest.yaml # Can do this step manually in editor
sed -i 's/views\//reports\//g' <package>/manifest.yaml # Can do this step manually in editor
kxi package packit <package> --tag
kxi package push <package>-<version>.kxi
The operational procedure described below is no longer required for an upgrade to 1.10.0. However, it is still true for upgrading from 1.8 to 1.9.
- 
Before you upgrade to 1.9.x, if you have any running databases, it is advised to manually stop them before upgrading, otherwise you may become unable to edit them in the UI. If this happens, you can recover the editable state by considering the following options: - If possible, back up the running assembly yaml file with kubectl get asm
- Tear down the running assembly manually with kubectl delete asm
- Optionally, use the kxi package deploycommand in the CLI, specifying the name and version of the package. The package appears underkxi package remote-list. Refer to Package deployment documentation for more information.
 If the package doesn't reappear as editable after tearing down, you need to use the KXI CLI to perform the following operations: - Convert the assembly yaml to a package. Refer to Converting assemblies to packages.
- Upload the package to kdb Insights Enterprise. Refer to Uploading a package.
- Deploy the package from the UI. Refer to Package deployment.
 
- If possible, back up the running assembly yaml file with 
Known Issues
Expand to see the list of known issues here
Resiliency With Resource Coordinators Deployed via kxi package
- If the Resource Coordinator (RC) is deployed using kxi package, and a connection is lost between the Service Gateway (SG) and the RC, queries routed to said RC will stop being serviced. This does not occur in cases where the deployment was done with the base Insights Enterprise install.
If the connection is lost and queries are failing, this can be resolved by restarting the Service Gateway.
PostGreSQL & Keycloak Resiliency
- A transient issue can occur in which Keycloak is unable to re-establish a connection to PostgreSQL after it recovers from an outage. This can result in getDatabeing unable to serve queries. To work around this, restart PostgreSQL.
Pipelines
- 
Pipelines that use Apply nodes from releases older than 1.9 will fail on deployment after upgrading. To work around this, after performing your upgrade, open the pipeline, click on Apply node, click the gear icon in the top corner of the node-config area, and then set the parameters manually (for most apply nodes this will be operator, metadata, data). 
- 
Deploying a pipeline from the UI will mark it as having unsaved changes even when none exist. Clicking Save again will make this go away. 
Upgrades & Rollbacks
- 
Users are prompted to tear down assemblies upon rollback. The rollback should exit if the user responds ‘n' to this prompt. Instead, the rollback continues. 
- 
During upgrade, the postgresqlprocess may log errors similar to the below. These can be safely ignored.`FATAL: database `[database name]` does not exist`
UI
- Changing the system log level in the UI does not get actioned.
Packaging
- In the UI, when you remove a pipeline from a database, packaging preserves this pipeline in a separate package to ensure it is not permanently deleted. This means the pipeline is still available in the UI. However, if you re-push the package from the CLI that still contains the pipeline, the pipeline now exists in two packages, and the latest version of the pipeline is not being served to the UI. The workaround is to remove the pipeline-only package that has been created.
Beta Features
- Streaming to Views has transitioned out of Beta and into general availability.
Summary
We hope you find some useful features that optimize your kdb Insights Enterprise experience. Try them out and email our Support Team if you need any help.
We look forward to bring you even bigger features in kdb Insights Enterprise 1.11 coming soon!
1.9.4
Release Date
2024-06-14
Fixes
Expand to see the full detail of resolved issues here
Security
- Multiple CVEs have been resolved as part of this patch.
Cloud Readers
- 
When administering a pipeline, a cloud reader node (s3, ms, and gs) could prompt you that there were unsaved changes even when no changes have been made. 
- 
The Azure reader file watcher was returning an error that a file(s) did not exist despite the file(s) being present. 
Reliable Transport
- RT's replicator was emitting an Invalid publishing directory, was it deleted by mistake? Please enrol a different client and restart the SDK with the new clienterror after recovering from a power outage of a q publisher server. This has been resolved to handle the recovery cleanly after such an outage.
UI
- 
On the Pipeline page, an intermittent issue could cause performance degradation or unresponsiveness in the UI for extended periods. 
- 
When configuring a pipeline in the UI, setting additional workerThreadswas not correctly applying the specified configuration. However, setting the environment variableKXI_DEFAULT_SP_WORKER_THREADSdid work. This has been resolved so either method can be used.
- 
The default setting for retries for database reader/writers in the UI did not match the backend defaults. This has been corrected to be consistent, with the default setting of 60 seconds for retries, and a retry wait time of 3 seconds. 
- 
When performing a rollback, the CLI was deploying the rollback task with a hard-coded timeout. This has been changed to a configurable value for use when rollbacks are expected to take longer. 
- 
When deploying a database, the Deploy popup was displaying totals that did not match the selected CPU, RAM and disk settings. The same issue was present in the Resource Summary box on the main page. These calculation errors have been resolved to display correct totals. Database 
- 
For a new system with an empty database, queries would not work after the first end-of-day data writedown if no data had been ingested yet. 
Third-party Dependencies
kdb Insights Enterprise 1.9.4 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.9.1 release of the standalone infrastructure installation scripts.
Artifacts
KX Nexus
The KX Nexus repository will be sunsetted in the future. Nexus links on this page are provided as a temporary alternative to the KX Downloads Portal for existing users. The KX Downloads Portal is the preferred repository for all use cases and KX Nexus links will be removed once the KX Nexus repository is decommissioned.
| type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.9.4.tgz | insights-1.9.2.tgz | 
| Operator | kxi-operator-1.9.1.tgz | kxi-operator-1.9.1.tgz | 
| CLI | kxicli-1.9.0-py3-none-any.whl | kxicli-1.9.0-py3-none-any.whl | 
| RT C interface | kxi-c-sdk 1.9.0 | kxi-c-sdk 1.9.0 | 
| RT Python interface | kxi-rtpy-1.9.0 | kxi-rtpy-1.9.0 | 
| RT Java interface | kxi-java-sdk 1.9.0 | kxi-java-sdk 1.9.0 | 
| RT Bridge | rt-bridge 1.7.0 | rt-bridge 1.7.0 | 
| Infrastructure | kxi-terraform-1.9.1.tgz | kxi-terraform-1.9.1.tgz | 
1.9.3
Release Date
2024-05-21
Fixes
Expand to see the full detail of resolved issues here
Reliable Transport
- RT's replicator was emitting an Invalid publishing directory, was it deleted by mistake? Please enrol a different client and restart the SDK with the new clienterror after recovering from a power outage of a q publisher server. An intermittent issue with truncated log files when the publisher restarts has been resolved.
Third-party Dependencies
kdb Insights Enterprise 1.9.3 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.9.1 release of the standalone infrastructure installation scripts.
Artifacts
KX Nexus
The KX Nexus repository will be sunsetted in the future. Nexus links on this page are provided as a temporary alternative to the KX Downloads Portal for existing users. The KX Downloads Portal is the preferred repository for all use cases and KX Nexus links will be removed once the KX Nexus repository is decommissioned.
| type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.9.3.tgz | insights-1.9.3.tgz | 
| Operator | kxi-operator-1.9.1.tgz | kxi-operator-1.9.1.tgz | 
| CLI | kxicli-1.9.1-py3-none-any.whl | kxicli-1.9.1-py3-none-any.whl | 
| RT C interface | kxi-c-sdk 1.9.0 | kxi-c-sdk 1.9.0 | 
| RT Python interface | kxi-rtpy-1.9.0 | kxi-rtpy-1.9.0 | 
| RT Java interface | kxi-java-sdk 1.9.0 | kxi-java-sdk 1.9.0 | 
| RT Bridge | rt-bridge 1.7.0 | rt-bridge 1.7.0 | 
| Infrastructure | kxi-terraform-1.9.1.tgz | kxi-terraform-1.9.1.tgz | 
| kxi-management-service | kxi-management-service-0.2.1.tgz | kxi-management-service-0.2.1.tgz | 
| insights-on-k8s | insights-on-k8s-0.0.16.tgz | insights-on-k8s-0.0.16.tgz | 
1.9.2
Release Date
2024-05-07
Fixes
Expand to see the full detail of resolved issues here
Reliable Transport
- The RT client was failing to recognize a new log file, putting downstream subscribers into a hung state. This has been resolved.
Third-party Dependencies
kdb Insights Enterprise 1.9.2 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.9.1 release of the standalone infrastructure installation scripts.
Artifacts
KX Nexus
The KX Nexus repository will be sunsetted in the future. Nexus links on this page are provided as a temporary alternative to the KX Downloads Portal for existing users. The KX Downloads Portal is the preferred repository for all use cases and KX Nexus links will be removed once the KX Nexus repository is decommissioned.
| type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.9.2.tgz | insights-1.9.2.tgz | 
| Operator | kxi-operator-1.9.1.tgz | kxi-operator-1.9.1.tgz | 
| CLI | kxicli-1.9.0-py3-none-any.whl | kxicli-1.9.0-py3-none-any.whl | 
| RT C interface | kxi-c-sdk 1.9.0 | kxi-c-sdk 1.9.0 | 
| RT Python interface | kxi-rtpy-1.9.0 | kxi-rtpy-1.9.0 | 
| RT Java interface | kxi-java-sdk 1.9.0 | kxi-java-sdk 1.9.0 | 
| RT Bridge | rt-bridge 1.7.0 | rt-bridge 1.7.0 | 
| Infrastructure | kxi-terraform-1.9.1.tgz | kxi-terraform-1.9.1.tgz | 
1.9.1
Release Date
2024-04-30
Improvements
- 
The fromParquetReader is now supported for AWS-based deployments. For more information, refer to Readers.
- 
Streams can now be removed from packages using the rmcommand from the CLI. Runkxi package rm --helpin the CLI for details.
Fixes
Expand to see the full detail of resolved issues here
Database
- Client requests using compressed IPC messages are now properly serviced. Previously, if the first request from a client was using compressed IPC, that and any future requests would fail.
Terraform Scripts
- Previously, in the kdb Insights Enterprise Terraform sample client scripts, the package-manager-migrationcommand failed when used in Azure deployments using the sharefiles storage class. This has been resolved. New sample scripts are available as part of this release. See the Artifacts section below.
Stream Processor
- Pipelines now throw an error when writing to a non-existent table. Previously, no errors were present in the pipeline or database logging. This was most commonly experienced when renaming a table in the database without updating the pipeline as well.
Reliable Transport
- Reliable Transport pods now use Kubernetes liveness probes to automatically bounce pods if unresponsive. This resolves a known issue in 1.9.0 in which RT pods were required to be manually restarted if an upgrade erroneously left them in a non-ready state.
Packaging
- 
The UI now displays the running version of a package as opposed to the latest package that may be available. 
- 
subTopichas been added as a mandatory field when adding external streams to a package. Previously, this was not present and caused a package to be undeployable.
- 
In the UI, it is no longer possible to create pipelines with the duplicate names. 
- 
The CLI now errors when trying to create and save a package that contains duplicate UUIDs, or when trying to save entities within a package that have duplicate UUIDs. 
UI
- Resource allocations are no longer mandatory input fields on the Resources tab. It is now possible to leave them empty and submit your resource configuration. For more information, refer to Adjust resources.
Third-party Dependencies
kdb Insights Enterprise 1.9.1 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.9.1 release of the standalone infrastructure installation scripts.
Artifacts
KX Nexus
The KX Nexus repository will be sunsetted in the future. Nexus links on this page are provided as a temporary alternative to the KX Downloads Portal for existing users. The KX Downloads Portal is the preferred repository for all use cases and KX Nexus links will be removed once the KX Nexus repository is decommissioned.
| type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.9.1.tgz | insights-1.9.1.tgz | 
| Operator | kxi-operator-1.9.1.tgz | kxi-operator-1.9.1.tgz | 
| CLI | kxicli-1.9.0-py3-none-any.whl | kxicli-1.9.0-py3-none-any.whl | 
| RT C interface | kxi-c-sdk 1.9.0 | kxi-c-sdk 1.9.0 | 
| RT Python interface | kxi-rtpy-1.9.0 | kxi-rtpy-1.9.0 | 
| RT Java interface | kxi-java-sdk 1.9.0 | kxi-java-sdk 1.9.0 | 
| RT Bridge | rt-bridge 1.7.0 | rt-bridge 1.7.0 | 
| Infrastructure | kxi-terraform-1.9.1.tgz | kxi-terraform-1.9.1.tgz | 
Upgrade Notes
Upgrading to 1.9.x
- 
Before you upgrade to 1.9.x, if you have any running databases, it is advised to manually stop them before upgrading, otherwise you may become unable to edit them in the UI. If this happens, you can recover the editable state by considering the following options: - If possible, back up the running assembly yaml file with kubectl get asm
- Tear down the running assembly manually with kubectl delete asm
- Optional: use the kxi package deploycommand in the CLI, specifying the name and version of the package. The package should appear underkxi package remote-list. Refer to Package deployment for more information.
 If the package doesn't reappear as editable after tearing down, you need to use the KXI CLI to perform the following operations: - Convert the assembly yaml to a package. Refer to Converting assemblies to packages.
- Upload the package to kdb Insights Enterprise. Refer to Uploading a package.
- Deploy the package from the UI. Refer to Package deployment.
 
- If possible, back up the running assembly yaml file with 
Known Issues
Expand to see the list of known issues here
Custom Tier Names
- Existing assemblies that have non-default tier names (i.e. names other than "rdb","idb","hdb") that are converted to packages will need to be updated to use those defaults. Presently, the UI expects the default names and is unable to differentiate between hdb and additional tiers.
1.9.0
Release Date
2024-03-26
New Features
- 
Developer Experience Improvements for Packaging kdb Insights Enterprise packaging now allows clients to manage database and pipeline configuration as well as custom code within a single package. This greatly simplifies developer and operational workflows, as users can maintain and administer databases and pipelines within a single package and with specific configuration for each pipeline. Packaging has also been integrated with the UI so that any databases and pipeline created using the CLI using the kxi packagecommand can be viewed and maintained by the UI and vice versa. Refer to Packaging for more details.
- 
SQL Enhancements SQL in kdb Insights Enterprise now includes support for ORDER BY and LIMIT clauses, in addition to other functions. Changes to how SQL statements are parsed also significantly improves SQL query performance in this release. Query performance, on average, is up to 3x faster than before. Refer to SQL 2 for more information on the new SQL implementation and its current Known Limitations. 
- 
Streaming to Views In the kdb Insights Enterprise UI, Views can now subscribe to real-time data from a pipeline, rather than relying on intermittent polling. This gives you the ability to visualize and analyze your data immediately. Refer to the streaming guided tour for details on configuring pipelines and views for this feature. Streaming to KX Views is a BETA feature in kdb Insights Enterprise 1.9.0. · Refer here to the Standard Terms related to Beta features. · We invite you to use this Beta feature and to provide feedback using the portal. 
- 
Snapshots & Majority Archival for Reliable Transport Reliable Transport now supports taking snapshots allowing for majority archival of logs files. Previously, all nodes needed to be healthy before RT logs could be archived. 
- 
Configurable Connections for Reliable Transport Reliable Transport now supports subscribers and publishers setting customized parameters when they register with their respective sequencer cluster. This gives you greater configurability in how you deploy and orchestrate components of RT. See rt.qpk for more details. 
Improvements
- 
System Resources Configuration Defining system resources has been streamlined, enabling you to set all aspects of resource allocation from a single configuration page in the kdb Insights Enterprise UI. See Adjust Resources for more information on this new tab. 
- 
Batch Delete Batch delete now allows you to delete from all tiers of your HDB. Previously, this was only possible for the tier with the most recent HDB data. See Database Delete for details on how to perform a delete. 
- 
Python Cloud Readers Python cloud readers now support polling for new matches to a glob pattern with the watchparameter. See Readers for details.
- 
Upgrade to Insights Core 4.1.1 kdb Insights Enterprise images have been upgraded to run Insights Core 4.1.1, which runs kdb+ 4.1 2024.03.12. 
- 
Upgrade to RockyLinux 9 kdb Insights Enterprise images have been upgraded to run on Rocky Linux version 9 as their base operating system. This addresses security vulnerabilities present in version 8. 
- 
Stream Processor Troubleshooting Guide There is now a troubleshooting guide{:target="blank"} available to help users better understand how to debug their pipelines running in _kdb Insights Enterprise. 
Fixes
Expand to see the full detail of resolved issues here
Database
- 
If EOD failed while in the middle of an HDB transaction, the aborted transaction was not properly cleaned up after the failure and could result in data inconsistency after reconnection. 
- 
The EOD process was not performing a garbage collection after a batch ingest. 
- 
Data was unqueryable after a batch ingest if no additional streaming data was loaded after the initial batch ingest. 
Reliable Transport
- In deployments with a one-node RT configuration, RT has been updated to roll its log file after a restart. This prevents data flow from being paused. The RT log file will roll from log.x.ytolog.x.y+1.
UI
- 
The Subscriber node was limited to only specifying one keyed column. This has been resolved to allow one or more keyed columns, ensuring that streaming supports a record being streamed per unique combination of all specified keyed columns and to allow filtering on any one of the keyed columns. 
- 
When configuring a Schema node, the regular expression pattern for table validation has been updated to allow single character column names. 
- 
For Function nodes, users can now customize their function parameters to accept the metadata and operator, in addition to data, in the Pipeline UI. See here for details. 
- 
The Error Modein the Pipeline Settings section of the Pipeline editor has been removed as it is no longer required, due to a stack trace now being logged when user code errors.
- 
The logging level within the Runtime Pipeline Settings section of the Pipeline editor was not correctly displaying or setting the log level of the SP worker. This has been resolved. 
- 
There was no way to specify \tas the delimiter in a CSV decoder in the UI. This has been corrected in the CSV Decoder node to allow for any delimiter to be used.
- 
After a pipeline has been deployed, when the status is either “Running” or “Finished”, a user is able to delete the pipeline. When the pipeline is deleted, the Overview page was still displaying it under “Running Pipelines”. This has been resolved to not display deleted pipelines. 
- 
Disk sizes for IDB and HDB tiers can now be set to any value greater than 0. 
- 
Users without the permission to create a pipeline should not be able to use the Import Data button on Database Page. This has been resolved. 
- 
Deleting running databases is now allowed. 
Views
- 
Notifications in Views were not reporting correctly. This has been resolved. 
- 
Under certain circumstances when you had a particular data source selected in the Data Source window and clicked New the existing values remained visible, however they were all ignored. This has been resolved. 
- 
When using the getDataAPI withaggset tosym;distinct;sym, the UI was ignoring this request and not sending any aggregation. This has been resolved.
- 
Switching between tabs caused the user-selected date to switch back to the default setting. This caused the View to constantly reload. This has been resolved. 
Stream Processor
- 
When using Python, 'sp.decode.csv' did not support reading columns as strings. This has been updated to enhance flexibility when reading table columns. It now accepts an empty string "" in lieu of a schema to read in all table columns as strings. 
- 
Sidecar containers no longer log at a TRACElevel by default and now adhere to the log level that is set by the user.
- 
The SP controller now adheres to the log level set by the user. 
- 
The CSV decoder did not support decoding csvs which had line-returns (i.e. \n’s) embedded in strings. This functionality can now be turned on with a new optional parameter called Strings Contain Newlines in the UI and newlinesin the q and Python APIs.
- 
When running a large import from a static source (file, Azure, AWS, GCP), there was no indication of progress in the logs. The SP logs now displays the file offset periodically while processing to indicate on-going progress of the import. 
- 
The SP’s status APIs will now return TEARING_DOWNrather thanNOTEXISTwhen a pipeline has PVCs that are still in a terminating state.
- 
Under certain circumstances when you added an additional stream to your database it could become orphaned after you renamed the database. This has been resolved. 
- 
Under certain circumstances when creating a pipeline using the Import feature the Parse Strings column was missing from the Apply Schema page, causing the pipeline to fail when deployed. This has been resolved. 
- 
The running pipelines section displays a count of warnings and errors that have occurred in the last 10 minutes. Not all of these warnings were being displayed in the Diagnostics page. This has been resolved. 
CLI
- 
When trying to enroll a client with a topic, the client was enrolled but the specified topic was not being set. This has been resolved. 
- 
When a user tried to authenticate but did not have a local browser installed on their machine, the redirect URL was localhostinstead of the value specified. This has been resolved such that users with a local browser installed can still successfully authenticate.
- 
Installation with a kc.liclicense using the--license-filepathcommand-line parameter was generating an incorrectvalues.yamlfile. This has been resolved so the license values correspond to the license name.
- 
Specifying a different hostname as part of a kxicommand is ignored after authentication, as you can only be authenticated to one kdb Insights Enterprise host at a time. For example, if you authenticate to HOSTNAME1 by callingkxi --hostname HOSTNAME1 auth loginyou are free to make calls against this host. If you attempt to specify a different hostname in subsequent callskxi --hostname HOSTNAME2, the--hostnameparameter will be ignored and the command executed against HOSTNAME1. You must re-authenticate against HOSTNAME2 before running commands against it.
- 
The function .kxi.udfs.list.all[]was failing with a length error. This has been resolved.
- 
Global environment variables set within your values.yamlwill now be set by all database and assembly deployments.global: env: env: var
Query Environments
- Query environments with entitlements enabled required the creation of separate entitlement for the -qeassembly in order for queries to work. This has been resolved.
Upgrades
- Fixed an issue where it was possible for pods to be unscheduled after an upgrade or rollback due to a volume node affinity conflict. Please note that this is still possible when rolling back from 1.9 to earlier versions. Please check the release notes of the target rollback version to address.
Security
- Various CVEs have been remediated as part of this release.
Third-party Dependencies
kdb Insights Enterprise 1.9.0 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.9.0 release of the standalone infrastructure installation scripts.
Deprecation
- 
The CLI kxi assemblycommand is being deprecated in 1.9.0 in favor ofkxi packageand will be removed in a future version. See kdb Insights CLI Reference for more information on thekxi assemblycommand.
- 
prtnEndCBandreloadCBcallback functions are being deprecated in 1.9.0 and may be removed from future releases. They have been replaced bylifecycle.partition.endandlifecycle.reload.postrespectively. Their usage can be seen below.
.custom.da.prtnEndCB:{[event;data]
  log.info("lifecycle.partition.end invoked.")
 }
.custom.da.reloadCB:{[event;data]
  log.info("lifecycle.reload.post invoked.")
 }
.ev.add[`lifecycle.partition.end ;`.custom.da.prtnEndCB];
.ev.add[`lifecycle.reload.post ;`.custom.da.reloadCB];
- RT maxLogSizeis no longer used in configuration and will be ignored from older configurations. RT will now utilize all disk available to it.
Artifacts
KX Nexus
The KX Nexus repository will be sunsetted in the future. Nexus links on this page are provided as a temporary alternative to the KX Downloads Portal for existing users. The KX Downloads Portal is the preferred repository for all use cases and KX Nexus links will be removed once the KX Nexus repository is decommissioned.
| type | Nexus location | Downloads Portal location | 
|---|---|---|
| Enterprise | insights-1.9.0.tgz | insights-1.9.0.tgz | 
| Operator | kxi-operator-1.9.0.tgz | kxi-operator-1.9.0.tgz | 
| CLI | kxicli-1.9.0-py3-none-any.whl | kxicli-1.9.0-py3-none-any.whl | 
| RT C interface | kxi-c-sdk 1.9.0 | kxi-c-sdk 1.9.0 | 
| RT Python interface | kxi-rtpy-1.9.0 | kxi-rtpy-1.9.0 | 
| RT Java interface | kxi-java-sdk 1.9.0 | kxi-java-sdk 1.9.0 | 
| RT Bridge | rt-bridge 1.7.0 | rt-bridge 1.7.0 | 
| Infrastructure | kxi-terraform-1.9.0.tgz | kxi-terraform-1.9.0.tgz | 
Upgrade Notes
- 
Keycloak and Postgres Values Changes The values file settings for the Keycloak and Postgres components have changed for 1.9. The panels below describe the modifications you need to make to this file for all standard or shared Keycloak deployments before upgrading to 1.9. Merging install values The values below are a partial extract of your deployment values. These should be merged with your existing values file. For more information, refer to Applying configuration changes. A standard deployment deploys Keycloak as part of the application. If you're using this configuration, you should ensure your values file includes the details shown below. The names kxi-keycloakandkxi-postgresqlare the default values, update these as appropriate.global: keycloak: auth: existingSecret: kxi-keycloak postgresql: auth: existingSecret: kxi-postgresql .. keycloak: auth: existingSecret: kxi-keycloak postgresql: auth: existingSecret: kxi-postgresql ..Keycloak values Please note there are two sets of keycloakandpostgresobjects;global.keycloak,global.postgresql,keycloak,keycloak.postgresql.Both sets of these are required as shown above. If deploying using the shared Keycloak mode, configure the values file as described below. The KEYCLOAK_RELEASE_NAMEandKEYCLOAK_NAMESPACEvariables should be updated to match those of your Keycloak deployment. The shared Keycloak docs explain each of these values.global: keycloak: authURL: http://${KEYCLOAK_RELEASE_NAME}.${KEYCLOAK_NAMESPACE}.svc.cluster.local/auth/ auth: existingSecret: kxi-keycloak postgresql: auth: existingSecret: kxi-postgresql ..
- 
If a user has an existing kxi-licensesecret created from akc.licork4.lic,kxi install setupwill re-use this secret, but will not set the appropriate values in the resultingvalues.yamlfile. See available license types Setup - kdb products.
- 
The default image repository used for new 1.9 installations will be the KX Downloads Portal. The credentials to access this are stored in a docker config json secret named kxi-image-pull-secret. If you are upgrading from an earlier version that used the KX Nexus image repository with an exiting secretkxi-nexus-pull-secret, this existing repository and secret will be used.
- 
After executing an upgrade, if an RT pod does not appear as ‘Ready’, the pod should be deleted/killed so that it is restarted. 
- 
During an upgrade, the RT pods attempt to delete a Kubernetes configmap. Since there were 3 RT pods, only one of the pods will be successful in deleting the config map. This means that the other pods will receive ERRORs back indicating that their delete attempt failed. These Failed to delete snapshot: tmperrors are benign and will be set to WARN messages in future.
- 
Query Labels Style KXI_ALLOW_OLD_LABEL_STYLEnow defaults to "false". It must be explicitly set to "true" in the RC to allow the "old label style". For example, in a system with labelsregion, andclass:- 
Labels in queries (such as .kxi.getData) must be defined in thelabelsparameter.- old style: --data '{"table": "trade", "region": "usa", "class": "equities"}'
- new style (new default): --data {"table": "trade", "labels": {"region": "usa", "class": "equities"} }'
 
- old style: 
- 
Labels in SQL queries must be prefixed with label_.- old style: SELECT * FROM trade WHERE region='usa', class='equities'
- new style (new default): SELECT * FROM trade WHERE label_region='usa', label_class='equities'
 
- old style: 
 
- 
Rollback
- 
If performing a rollback from 1.9.0 to any earlier version, assemblies must be running prior to initiating the rollback to ensure no data is lost. See Upgrading for how to perform upgrades/rollbacks and the available commands to use. Please see the following specific instructions per version: Rollback from 1.9 to a version less than 1.7 is not possible. For rollback from 1.9 to a prior version: - Confirm all assemblies are running before initiating rollback.
- Execute the rollback operation. Note that the kxi-rt-rollbackandkxi-sp-rollbackcharts are run automatically as part of the rollback operation as of 1.9.0.
 For rollback from 1.8, the following instructions should be followed: - Teardown your assemblies.
- Run the kxi-sp-rollbackchart. If the target version for rollback is less than 1.7, also run thekxi-db-rollbackchart.
- Rollback kdb Insights Enterprise per the rollback instructions referenced above.
- Redeploy assemblies.
 
Known Issues
Expand to see the list of known issues here
Upgrades & Rollbacks
- 
Users are prompted to tear down assemblies upon rollback. The rollback should exit if the user responds ‘n' to this prompt. Instead, the rollback continues. 
- 
Occasionally, rollbacks may fail with an error when running kxi install rollback. This is due to timeouts with the Helm rollback, resulting in errors such as the following:timed out waiting for the condition context deadline exceededTo resolve this issue, re-run the rollback. 
Pipelines
- 
It is currently possible to rename a pipeline in the UI to a pipeline name that is already in use. Until this is resolved, ensure your pipeline names are unique. 
- 
When deploying a pipeline that writes to a table that does not exist, no error will be thrown. 
Packaging
- kxi.package.load_filedoes not work properly for Python files. For a Python module, use- importinstead.
Query Tab
- There is presently no way to select a subset of the available columns during the getdataphase in the Query tab of the UI. Conversely, thegetDataAPI allows this in theaggparameter where you can pass in the list of columns you want with no aggregation function.
UI
- 
Changing the system log level in the UI does not get actioned. 
- 
On Mozilla Firefox, when clicking Deployin aDatabasescreen, the scroll wheels do not render properly in the pop-up.
Views
- 
When displaying streaming data in Views and using the Map component, the map may take some time before the streaming data is displayed. A page reload may be required. 
- 
When working with a View then temporarily navigating away to a different tab, any changes made will be saved despite the user not requesting this. If multiple users are editing the same view, any time one switches away from the tab (even if they haven’t made any changes), the current version of their view will be saved, which may not include changes made other users. To resolve this, use the Undo action to return the last desired saved state. 
- 
A popup may be shown indicating there may be unsaved changes when no changes have been made. 
Scratchpads
- 
Certain Python expressions cause internal errors in Python scratchpads: lambda x: x * 2 memoryview(bytearray("myTest", encoding='utf-8')) {1,2,3}
Reliable Transport
- RT clients output certain logs to a folder determined by theKXI_C_SDK_APP_LOG_PATHenvironment variable ($KXI_C_SDK_APP_LOG_PATH/kxi_c_sdk_logs/rt_helper.VMC7AW/rt_helper.log). This variable uses a default location of/tmp. When there are recurring errors, these logs can fill the/tmpdirectory which is only 5MB in size. To overcome this issue, you can change this environment variable. See Environment variables for steps on how to change this.
Deprecation
- 
The CLI kxi assemblycommand is being deprecated in 1.9.0 in favor ofkxi packageand may be removed from future releases. See kdb Insights CLI Reference for more information on thekxi assemblycommand.
- 
prtnEndCBandreloadCBcallback functions are being deprecated in 1.9.0 and may be removed from future releases.
- 
RT maxLogSizeis no longer used in configuration and will be ignored from older configurations. RT will now utilize all disk available to it.
1.8.2
Release Date
2024-01-23
Fixes
Expand to see the full detail of resolved issues here
Database
- An issue has been resolved in relation to Batch Ingest. Previously, some data in the Historical Database (HDB) was persisted to disk but it was unqueryable. This has been fixed, and all data ingested into the HDB is now queryable.
Third-party Dependencies
kdb Insights Enterprise 1.8.2 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.8.2 release of the standalone infrastructure installation scripts.
Artifacts
| Type | Location | 
|---|---|
| Enterprise | insights-1.8.2.tgz | 
| Operator | kxi-operator-1.8.1.tgz | 
| CLI | kxicli-1.8.0-py3-none-any.whl | 
| C interface | kxi-c-sdk 1.8.0 | 
| RT Python interface | kxi-rtpy-1.8.0 | 
| Java interface | kxi-java-sdk 1.6.0 | 
| RT Bridge | rt-bridge 1.7.0 | 
| Infrastructure | kxi-terraform-1.8.0.tgz | 
1.8.1
Release Date
2024-01-16
Improvements
- 
Encryption of data in transit with OpenShift The encryption of data in transit is now supported when deploying kdb Insights Enterprise using OpenShift. 
- 
Stream Processor CSV Decoder Improvements The Python CSV decoder now supports the firstheader option. This should be used when only the first batch of your dataset contains a header in the CSV file. See Decoders for information on the CSV decoder configuration.
Fixes
Expand to see the full detail of resolved issues here
Packaging
- Resolved an issue where .kxignorefiles were incorrectly read as bytes instead of strings when compressed on Ubuntu for Windows.
Stream Processor
- 
Stream Processor Beta features configuration has been fixed. When deploying the SP Helm chart, setting betaFeatures: truewasn't correctly enabling Beta features.
- 
A fix has been introduced in the UI to ensure changes to the position of an SP node in a pipeline are now correctly saved. 
- 
When creating a pipeline in the UI, the Stream Processor S3 writer now allows for proper writing to an object storage bucket. Previously, this could error with Some nodes have errors, fix them before trying to deploy this pipeline.
- 
Previously, the CSV decoder could drop messages when paired with a file reader (Amazon S3, Google Storage, Azure Storage) where chunking was enabled and the CSV decoder header was set to always. This issue has been resolved. See Decoders for information on the CSV decoder configuration.
- 
SP Cloud Readers no longer error when there are no files matching the expected pattern. Previously, a cloud reader using glob pattern matching would prevent the pipeline from starting if no files matched. In particular, this would occur when trying to use the file watcher feature and no files matched as of the pipeline starting. 
- 
The delimiter select field in the Stream Processor CSV node has been updated to allow any delimiter to be used. Previously, there was a restriction on the number of characters that could be submitted, preventing entry of \tor any other delimiter.
- 
Resolved the problem of all window nodes triggering their jobs at the same time, despite their configuration settings. This would occur in setups with pipelines with multiple window nodes, or separate pipelines that read and write to the same RT stream. See Windows nodes for more details. 
Security
- Various CVEs were remediated as part of this release.
Third-party Dependencies
kdb Insights Enterprise 1.8.1 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.8.1 release of the standalone infrastructure installation scripts.
Artifacts
| type | location | 
|---|---|
| Enterprise | insights-1.8.1.tgz | 
| Operator | kxi-operator-1.8.1.tgz | 
| CLI | kxicli-1.8.0-py3-none-any.whl | 
| C interface | kxi-c-sdk 1.8.0 | 
| RT Python interface | kxi-rtpy-1.8.0 | 
| Java interface | kxi-java-sdk 1.6.0 | 
| RT Bridge | rt-bridge 1.7.0 | 
| Infrastructure | kxi-terraform-1.8.0.tgz | 
1.8.0
Release Date
2023-12-11
New Features
- 
Data Encryption Data in transit within kdb Insights Enterprise can now be encrypted, providing enhanced security. This feature meets compliance and regulatory requirements and protects against cyber-security attacks. For further details on how to enable encryption via the CLI, see Encryption of data in transit. 
- 
OpenShift Container Platform (OCP) Support kdb Insights Enterprise can now be deployed on premise using the OpenShift Container Platform (OCP). This expands on the deployment topology options of kdb Insights Enterprise, and enables customers to take advantage of its capabilities without having to run in a public cloud. For further details, see OpenShift infrastructure prerequisites. Note See here for details on an issue with Openshift upgrades. 
- 
Azure and GCP Parquet Reader Support The kdb Insights Parquet Reader functionality has been extended to support Azure and GCP object storage. Users can now read, decode, and watch Parquet files stored on Azure and GCP, as well as AWS. These enhancements are available in the UI, the q API and the Python API. 
- 
HTTP Publishing kdb Insights Enterprise has introduced a REST interface to publish data over HTTP. This expands the interoperability of kdb Insights Enterprise for ingesting data. Note that file size is limited to 10MB per publish. See Upload via HTTP for more details. 
- 
Python Interface to Reliable Transport A new Python interface allows you to publish data to Reliable Transport from your own Python application in Docker, or on Linux or Windows. See here for details. 
- 
New Database Preview API You can now query a sample of your data from the database to understand your data/schema, construct more complex queries, or build visuals on the full data set. See here for details. 
Improvements
- 
Autoscaling Service Gateways The Service Gateway and Aggregator can now autoscale if CPU exceeds your configured threshold. The default is to trigger scaling when CPU exceeds 80% for 5 seconds, with a default stabilization period of 300 seconds. All of this is configurable in your values file. See here for details. 
- 
CLI Enhancements The kdb Insights Enterprise CLI contains a number of security and user experience improvements added: - Browser-based authentication for users, and the ability to authenticate even without a browser
- Ability to authenticate once and still straddle administrator and developer views
- Token caching & refreshing to support the authentication methods
- Use of profiles to allow for concurrent sessions in different environments
 See CLI Authentication for details. 
- 
UI Enhancements - 
When editing a pipeline node, you are now reminded to apply your current changes before moving away to perform other operations. This avoids the potential loss of changes when clicking on to another node. 
- 
Ability to view the rolled-up status of a pipeline group when there are multiple pipelines/replicas. 
- 
Undo and Redo buttons have been added to the Pipeline editor. 
- 
Pipeline settings have been moved into a new ‘Settings’ tab on the Pipeline page. See here for details. 
- 
For tables marked in a foreign key relationship, further validation has been added upon startup to check that these exist and fail fast if any are missing. 
- 
The autocomplete widget in code editors now only appears when manually triggered with Ctrl + Space. 
 
- 
- 
Stream Processor - 
Cloud file readers in the Stream Processor now support watching for new files. You can now provide a pattern expression to search for file names. When watching is enabled, the file reader will poll for new files that match the expression. For full details on file watching, see the Amazon S3 reader, the Azure Blob storage reader and the Google Cloud storage reader. 
- 
You can now deploy replicas of pipelines. When deploying, select the “Advanced” option to configure a “Replicas” input field. The environment will deploy the configured number of replicated pipelines identical in configuration with a different ID. See here for details. 
 
- 
Fixes
Expand to see the full detail of resolved issues here
Database
- 
Improved startup performance of HDB DAPs when loading late data from IDB tier mount. 
- 
Storage Manager resiliency improvements have been made to improve how SM cleans up aborted transactions after a failure event. 
- 
Improved validation for schemas in the UI. Rules now validate against invalid configuration combinations with attributes, sorts and reserved words. 
- 
Improved failure recovery for object storage in Storage Manager. This resolves a case where EOI would not complete and would report SM Flushing filesystem with [directory]errors.
Reliable Transport
- Logging for LEADER/FOLLOWER updates have been changed to DEBUG level to reduce log noise.
Stream Processor
- 
Previously, it was possible that FINISHEDSP pipelines using multiple partitioned workers could spawn extra zombie workers. This has been resolved.
- 
Pipeline quick tests no longer fail if they contained a kdb Insights Stream or kdb Insights Database reader or writer. 
- 
Previously it was not possible to maintain state of any object that contained a kdb guid type. This is now fixed. However, if a rollback to an earlier version is required after an upgrade, a rollback step should be run so that on-disk checkpoints can be converted to a format compatible with earlier versions. 
- 
Fixed an issue where the csv decoder, with option header=first, and paired with an unbounded streaming reader, was incorrectly dropping the first record in every stream batch.
- 
Fixed a determinism gap when reading objects from cloud storage using a glob pattern. In a recovery scenario, it was possible to receive duplicate data. 
- 
Fixed a bug where unpopulated column of type 0h (i.e. list) was not getting filled in with blank entries correctly. 
- 
If a pipeline is deployed as part of an assembly, .qsp.write.toDatabasenow defaults to writing to that assembly. This means the assembly name can be omitted when calling.qsp.write.toDatabase, for example,.qsp.write.toDatabase[trade; .qsp.use`directWrite!(::;1b)].
- 
Fixed a bug where in a single path pipeline, the existence of more than one emitter resulted in that same number of combine nodes being added. 
Upgrades
- Resolved a previously-published known issue where upgrades could occasionally fail with an error when running kxi install upgrade. This occurred due to a race condition in the 1.7.0 version of the CLI when trying to replace the CRDs.
File Watchers
- 
When using the file/cloud readers in a non-file watching scenario, files that were not getting chunked did not have their state checkpointed. This meant that during a recovery scenario, duplicate data would be generated for those files. 
- 
An issue has been resolved that could cause the file watcher to lose data at the boundaries when chunking was set to auto.
Security
- Various CVEs were remediated as part of this release.
User Interface
- 
Resolved the issue where the resizing of a browser window threw the error Error: Cannot read properties of undefined (reading 'getBoundingClientRect') or this.getElements()[0] is undefined.
- 
Resolved an issue where certain Python libraries such as spacy,tensorflow,kerasdid not work in the Scratchpad.
- 
Postgres and SqlServer nodes no longer incorrectly have a password field. 
- 
Resolved the issue where the Views page in the UI occasionally froze when performing certain operations using the map. 
- 
The instances where the error "Failed to compare saved assembly [assembly name] to deployed version" were erroneously triggered are now resolved. 
- 
Resolved the issue where resizing your browser window throws "Error: Cannot read properties of undefined (reading 'getBoundingClientRect') or this.getElements()[0] is undefined". 
- 
Duplicate filters are no longer being reported after creating then saving a filter. 
- 
Navigating to a Dashboard/Screen from Actions is now working in Views. Previously, you could receive the error "Error: Cannot read properties of undefined (reading 'navigate')" or be redirected to the homepage. 
- 
Creating a View with a Datagrid, copy it to a second View and pasting, and then returning to your original View would cause your changes to be lost. This has now been resolved. 
- 
Fixed the incorrect JSON file format that was causing issues when trying to download pipeline logs from the UI. 
Third-party Dependencies
kdb Insights Enterprise 1.8.0 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.8.0 release of the standalone infrastructure installation scripts.
Artifacts
| type | location | 
|---|---|
| Enterprise | insights-1.8.0.tgz | 
| Operator | kxi-operator-1.8.0.tgz | 
| CLI | kxicli-1.8.0-py3-none-any.whl | 
| C interface | kxi-c-sdk 1.8.0 | 
| RT Python interface | kxi-rtpy-1.8.0 | 
| Java interface | kxi-java-sdk 1.6.0 | 
| RT Bridge | rt-bridge 1.7.0 | 
| Infrastructure | kxi-terraform-1.8.0.tgz | 
Upgrade notes
- 
Encryption of data in transit{:target="blank"} is turned on by default for fresh installs. When you upgrade _kdb Insights Enterprise the CLI gives you the option to turn encryption on or off. To change this setting after installation, perform an upgrade. 
- 
When creating a new database through the kdb Insights Enterprise UI, the isShardedschema property is now being defaulted to true. See here for more details on the implications of partitioned tables.
Known Issues
- 
Upgrading kdb Insights Enterprise on Openshift will report that the insights-on-k8stask will fail to install Istio. This can be safely ignored. Please follow the instructions to install Istio as a prerequisite.
- 
Using a Stream Processor Amazon S3 reader may fail when running on EKS. To workaround this, please set the tenantfield tokxinsights.
- 
If you have has an existing kxi-licensesecret created from akc.licork4.lic,kxi install setupwill re-use this secret, but will not set the appropriate values in the resultingvalues.yaml. See the available license types here.
- 
Occasionally installs and upgrades may fail with an error when running kxi install. This can occur due to timeouts with the helm upgrade, giving errors such as the below:timed out waiting for the condition context deadline exceededRe-run the install or upgrade to resolve this issue. 
- 
With entitlements enabled, the Query tab in the UI will not return data as there are issues with resolving the correct database name when checking entitlements. In order to workaround this issue, you should create a second entitlement for each database / assembly. For example if you create and entitle an assembly called dfx-assembly, you should also create an identical entitlement calleddfx-assembly-qe. This-qeentitlement should be kept in-sync when updating the main one.This restriction will be removed in a future release. 
- 
qsqlrequests, made either through theQtab (Query environment) in the UI or via REST to/qsql, do not work with entitlements. The.kxi.qsqlAPI should be disabled if using entitlements. This is disabled by default in kdb Insights Enterprise. See here for more details.
1.7.4
Release Date
2024-01-04
Fixes
Expand to see the full detail of resolved issues here
Database
- 
Improved failure recovery for object storage in Storage Manager. This resolves a case where EOI would not complete and would report SM Flushing filesystem with [directory]errors.
- 
Resolved a bug in which EOIs were not completing, and NoSuchKeyerrors were occurring after moving data to object storage.
- 
Improvements have been made to the refresh token logic for AWS deployments. Previously, token refresh logic was erroneous if the session was not requesting object storage bucket data. The refresh rotated every 30 minutes instead of at the session expiry time. Session expiry time is configured with EC2 instance metadata, or by KX_KURL_AWS_TOKEN_DURATIONwhen using Amazon STS.
User Interface
- 
Resolved an issue where certain Python libraries such as spacy,tensorflow,kerasdid not work in the Scratchpad.
- 
In the Query tab, duplicate filters are no longer being reported after creating then saving a filter. 
Security
- Various CVEs have been remediated as part of this release.
Third-party dependencies
kdb Insights Enterprise 1.7.4 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.7.4 release of the standalone infrastructure installation scripts.
Artifacts
| type | location | 
|---|---|
| Enterprise | insights-1.7.4.tgz | 
| Operator | kxi-operator-1.7.2.tgz | 
| CLI | kxicli-1.7.2-py3-none-any.whl | 
| C interface | kxi-c-sdk 1.7.0 | 
| Java interface | kxi-java-sdk 1.6.0 | 
| RT Bridge | rt-bridge 1.7.0 | 
| Infrastructure | kxi-terraform-1.7.0.tgz | 
1.7.3
Release Date
2023-11-01
Fixes
Expand to see the full detail of resolved issues here
Database
- Optimizations made to the getDataAPI to improve query performance when theprtnColis sorted.
Security
- Various CVEs have been remediated as part of this release.
Third-party dependencies
kdb Insights Enterprise 1.7.0 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.7.0 release of the standalone infrastructure installation scripts.
Artifacts
| type | location | 
|---|---|
| Enterprise | insights-1.7.3.tgz | 
| Operator | kxi-operator-1.7.2.tgz | 
| CLI | kxicli-1.7.2-py3-none-any.whl | 
| C interface | kxi-c-sdk 1.7.0 | 
| Java interface | kxi-java-sdk 1.6.0 | 
| RT Bridge | rt-bridge 1.7.0 | 
| Infrastructure | kxi-terraform-1.7.0.tgz | 
1.7.2
Release Date
2023-10-03
Improvements
- 
SQL Queries - SQL queries will now use less memory if late data is enabled and you are querying data for the current day.
 
Fixes
Expand to see the full detail of resolved issues here
Database
- 
Resolved an issue where data for dates modified after the retention period was not getting moved from the first to the secondary HDB tier. 
- 
Improved the startup time for HDB DAPs, allowing for faster availability of processes that serve queries. 
Stream Processor
- The Apply Schema transform node now works with NULLs in string types.
Third-party dependencies
kdb Insights Enterprise 1.7.0 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.7.0 release of the standalone infrastructure installation scripts.
Artifacts
| type | location | 
|---|---|
| Enterprise | insights-1.7.2.tgz | 
| Operator | kxi-operator-1.7.0.tgz | 
| CLI | kxicli-1.7.1-py3-none-any.whl | 
| C interface | kxi-c-sdk 1.7.0 | 
| Java interface | kxi-java-sdk 1.6.0 | 
| RT Bridge | rt-bridge 1.7.0 | 
| Infrastructure | kxi-terraform-1.7.0.tgz | 
1.7.1
Release Date
2023-09-19
Fixes
Expand to see the full detail of resolved issues here
Database
- 
Resolved an issue with the Storage Manager not rolling back aborted transactions if an EOD failed. 
- 
Deleting data from the HDB using a filteroption now correctly performs the delete. Previously, this returned an error claiming that the column(s) being filtered didn’t exist.
- 
EOIs are no longer delayed after an EOI recovery event. Previously, it was possible for EOIs to become held up if the process was terminated then subsequently recovered. The EOIs would still complete successfully, but with a delay. 
Security
- Resolved CVE-2023-37920 Certifi's removal of e-Tugra root certificate, by upgrading the spaCy dependency.
Stream Processor
- Attempts to horizontally scale pipelines using the direct write feature will now explicitly error since this is not currently supported.
Deployments & Upgrades
- Resolved the known issue in 1.7.0 in which a race condition could cause an upgrade to fail with an error when running kxi install upgrade.
Third-party dependencies
kdb Insights Enterprise 1.7.0 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.7.0 release of the standalone infrastructure installation scripts.
Artifacts
| type | location | 
|---|---|
| Enterprise | insights-1.7.1.tgz | 
| Operator | kxi-operator-1.7.0.tgz | 
| CLI | kxicli-1.7.1-py3-none-any.whl | 
| C interface | kxi-c-sdk 1.7.0 | 
| Java interface | kxi-java-sdk 1.6.0 | 
| RT Bridge | rt-bridge 1.7.0 | 
| Infrastructure | kxi-terraform-1.7.0.tgz | 
1.7.0
Release Date
2023-08-25
New Features
- 
End-of-day writedown memory controls The Storage Manager (SM) process now supports restricting memory consumption for data writedown, giving the opportunity for cost savings. Reducing the RAM allocated to SM may cause EOD to run longer than if RAM was unrestricted. For guidance on tuning your RAM setup, see Performance best practices and the recommended system sizes for Azure here. 
- 
One-node RT kdb Insights Enterprise now allows you to optionally deploy an RT Stream as a one-node cluster instead of a three-node cluster when deploying via the kdb Insights CLI. - In a three-node cluster, RT provides fault tolerance and high availability (HA).
- In a one-node cluster, RT provides fault tolerance, but the cluster is not highly available. This configuration saves resources and reduces costs for workload use cases that do not need to be highly available. In the event that the single RT node goes down, the publisher then continues to write to its local RT log file. When the RT node restarts, the publisher retrieves any data that is present on the publisher node that it has not yet received.
 See here for more details on RT architecture. 
- 
C Subscriber support in Reliable Transport The C language interface for RT is now able to subscribe to the data on an RT stream. See here for more details. 
- 
Backfill a new column with derived data When adding a new column to your schema, you can now define a custom function that will backfill the new column with derived data. 
- 
Publishing derived data from custom APIs Custom APIs that generate derived data can now stream and/or persist their output. 
- 
Appending data on batch ingest When ingesting data using the direct write feature, you now have the option to append data rather than replace it. See overwrite option for more details. 
- 
Data Entitlements for querying data Beta When querying via REST or IPC, kdb Insights Enterprise now provides data entitlement restrictions for limiting user access to the data contained within specific deployed databases. 
- 
Parquet file reader Beta Ingesting Parquet files from local storage or from an AWS S3 bucket using the q reader API, Python reader API and the UI is now enabled. This feature will be enabled for Azure and GCP and include a file watcher with file pattern matching in a future release. 
Improvements
- 
End-of-day writedown performance improvements The Storage Manager (SM) process has been optimized to significantly improve its performance - up to 50-70% reduction in EOD duration. This improved EOD performance can reduce the memory allocated or the time taken for writedown, depending on your workloads and configuration. For guidance and best practices on how to configure your schema and system to take advantage of these optimizations, review Performance best practices and the recommended system sizes for Azure here. 
- 
User interface - 
The database schema editor has been completely redesigned with a new responsive table grid for entering column metadata details. The editor uses keyboard driven actions for efficient data entry. Backed by HTML canvas rendering, hundreds of columns can be added with ease. 
- 
The Database configuration now supports different storage classes for the IDB and HDB (for example, FSx for Lustre). There is now a dropdown under Advanced Writedown settings for the File Systemthat changes the mount storage class. See here for details.
- 
The code editors in the Pipeline Editor can now be used to evaluate q and Python code. See Executable Editors in the Building a Pipelinesection for more information.
- 
Virtual queries are now available in Views. See Virtual data sources for more information. 
- 
The ‘Database Wizard’ has been removed from the UI. Databases can now be created and configured using the unified database configuration screens. 
- 
Query results in the UI are now shown using the timezone as returned by the query APIs for both Console and Table views. Previously, Table view would apply the user’s timezone which may have been different. 
 
- 
- 
Readers - 
When using cloud and file readers, you can now use filename pattern matching to ingest multiple files using a single reader. This expands the ability for you to build up ingest workloads that pull in multiple files. For example, using an S3 reader, you could read all CSV files in all folders within a bucket using the pattern: s3://path/to/bucket/**/*.csv
- 
When using cloud and file readers you can now use a file watcher which is usually paired with filename pattern matching described above. The reader will continually watch for new files matching the file path(s) provided. See here for details on: - q APIs: .qsp.read.fromGoogleStorage, .qsp.read.fromAzureStorage and .qsp.read.fromAmazonS3.
- Python APIs: .qsp.read.fromGoogleStorage, from_azure_storage and from_amazon_s3.
- UI: Google Cloud Storage, Microsoft Azure Storage and Amazon S3.
 Not to be used with the Write Direct to HDBoptionThe Watcher options should not be used when also choosing the Write Direct to HDBoption in the Database Writer in the UI, the q or Python APIs.
- 
Advanced configuration options for the Kafka Reader node in the Pipeline Builder UI allow more flexible options for security protocol configuration or changes to fetch intervals, as seen when subscribing to an Azure Event Hub Kafka connector. 
 
- 
- 
Reliable Transport - Users can now launch KXI feeds from outside of their Kubernetes cluster and send data to their kdb Insights Enterprise deploy.
 
- 
Logging - 
RT Stream logs are now included in Database logs on the Diagnostics page, and they are also included in the Database Issues counts shown on the Database Overview page. 
- 
When viewing a deployed pipeline, you can now click on an icon to jump straight to the pipeline logs. 
 
- 
- 
Terraform Scripts - The default node types for each cloud provider have been changed to ensure that the default node group uses memory-optimized instances, and the node group for rook-ceph has storage-optimized instances:
 AWS: default node pool: "r5.xlarge" rook-ceph node pool: "i3.2xlarge" Azure: default node pool: "Standard_E4_v3" rook-ceph node pool:”Standard_L8s_v2" GCP: default node pool: "n1-highmem-4" rook-ceph node pool:”n2-standard-8"- 
The deployment of the nginx controller has been changed to be a Daemonset which will ensure consistent availability across all nodes. 
- 
The standalone installation using the terraform client scripts now enables cloud native system metrics on GKE clusters. 
 
Fixes
Expand to see the full detail of resolved issues here
Database
- When using the Filter By Label option in the Query page, you can now use more than one label for the filter. In previous releases, additional labels beyond the first were not taken into account when the query was executed. 
- 
Fixed an issue where schema type conversions from strings to GUIDs would fail and cause a type error. 
- 
Fixed an issue on certain NFS-based system (namely Lustre) where the ‘current’ database pointer could get converted to a directory resulting in an unexpected error. 
EISDIR: /data/idb/current.new -> /data/idb/current
- 
An error has been fixed that would occur when updating an object storage tier that used an inventory file after a data migration. 
- 
Fixed an issue when querying with .kxi.getDatausing a groupBy operation on a foreign key column where the name of the foreign key column would be thrown and the query would fail to complete.
- 
Fixed an issue where renaming columns in the schema UI would incorrectly delete the underlying column and create a new one with null data. Column renames in the UI now correctly preserve the column’s data. 
- 
A new warning has been added to the Resource Coordinator if no Aggregators connect to it. After a wait period, if an Aggregator continues not to connect, this will be escalated to an error to indicate that the system is not ready for queries. 
- 
Stream resources now correctly show the amount of resources to be used when an additional stream was added. Previously the stream resources were only showing the compute settings for a single stream instead of adding both together. 
- 
When the kdb Insights Database was configured with an object storage tier but an inventory file was not provided, the Storage Manager would error on startup with invalid object storage URI error. This has been changed to not attempt to create an inventory file if no configuration is explicitly provided. 
- 
Resolved an issue when attempting to migrate HDB data to Azure Blob Storage. Previously, this would fail with a signature error. 
- 
Fixed a potential race condition between NFS replication and DAP reload signals. It was previously possible that a DAP may reload before NFS replicated data which could result in data gaps. A new sequencing mechanism has been added to ensure DAPs do not reload until replication is complete. 
- 
Values in a symbol column will now be properly available immediately after a batch ingest. Previously, these would be missing until the next EOI. 
- 
Renaming a sort column now longer errors. 
Stream Processor
- 
q code in a pipeline’s Global Code field will now be executed with the same semantics as loading a .q file. This fixes issues around expressions incorrectly being concatenated, the handling of comments, and expressions starting with . 
- 
The return of UDFs when generating q objects is no longer incorrectly wrapped as foreign objects. A user no longer needs to use a null python function following the UDF to unwrap it to the correct type. 
Command Line Interface - Reinstalls and rollbacks no longer fail due to password history issues with the initUser.
Third-party dependencies
kdb Insights Enterprise 1.7.0 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.7.0 release of the standalone infrastructure installation scripts.
Artifacts
| type | location | 
|---|---|
| Enterprise | insights-1.7.0.tgz | 
| Operator | kxi-operator-1.7.0.tgz | 
| CLI | kxicli-1.7.0-py3-none-any.whl | 
| C interface | kxi-c-sdk 1.7.0 | 
| Java interface | kxi-java-sdk 1.6.0 | 
| RT Bridge | rt-bridge 1.7.0 | 
| Infrastructure | kxi-terraform-1.7.0.tgz | 
Upgrade notes
- 
Occasionally upgrades may fail with an error when running kxi install upgrade. This occurs due to a race condition in the 1.7.0 of the CLI when trying to replace the CRDs. The upgrade will stall and timeout at this point... Replacing CRD assemblies.insights.kx.com Replacing CRD assemblyresources.insights.kx.com Error: Timed out waiting for CRD assemblyresources.insights.kx.com to be deletedRe-running the upgrade should workaround the issue. This will be fixed in the next patch release. 
Known Issues
- 
With entitlements enabled, the Query tab in the UI will not return data as there are issues with resolving the correct database name when checking entitlements. In order to workaround this issue, you should create a second entitlement for each database / assembly. For example if you create and entitle an assembly called dfx-assembly, you should also create an identical entitlement calleddfx-assembly-qe. This-qeentitlement should be kept in-sync when updating the main one.This restriction will be removed in a future release. 
- 
Previously cloud readers in a failure recovery scenario would begin reading file(s) from the start, even if they had read them prior to crashing. This would have caused duplicate data if using a stream or database writer. As of 1.7 this is no longer the case. One exception case remains, when using a glob pattern match in a non watching scenario. If the pipeline fails, recovers and matches a new set of files (because the underlying files in the object storage have changed) we may get duplicate data. 
- 
qsqlrequests, made either through theQtab (query environment) in the UI or via REST to/qsql, do not work with entitlements. The.kxi.qsqlAPI should be disabled if using entitlements.
- 
Occasionally installs and upgrades may fail with an error when running kxi install. This can occur due to timeouts with the helm upgrade, giving errors such as the below:timed out waiting for the condition context deadline exceededRe-run the install or upgrade to resolve this issue. 
Backward Compatibility
If you are upgrading from a version earlier than 1.6.3 you must also read each of the relevant release notes to ensure you know all the changes that will affect the upgrade. Refer to the previous release page for older releases.
1.6.4
Release Date
2023-11-28
kdb Insights Core Version
This version of kdb Insights Enterprise runs kdb Insights Core 4.0.5.
Fixes
Expand to see the full detail of resolved issues here
Database
- 
Improved failure recovery for object storage in Storage Manager. This resolves a case where EOI would not complete and would report SM Flushing filesystem with [directory]errors.
- 
Resolved a bug in which EOIs were not completing, and NoSuchKeyerrors were occurring after moving data to object storage.
- 
Improvements have been made to the refresh token logic for AWS deployments. Previously, token refresh logic was erroneous if the session was not requesting object storage bucket data. The refresh rotated every 30 minutes instead of at the session expiry time. Session expiry time is configured with EC2 instance metadata, or by KX_KURL_AWS_TOKEN_DURATIONwhen using Amazon STS.
- 
Added a fix for the GCP system command expiry timer being discarded/ignored, which resulted in tokens not refreshing at all using gcloud auth.
Security
- Various CVEs were remediated as part of this release.
Artifacts
| type | location | 
|---|---|
| Enterprise | insights-1.6.4.tgz | 
| Operator | kxi-operator-1.6.1.tgz | 
| CLI | kxicli-1.6.1-py3-none-any.whl | 
| C SDK | kxi-c-sdk 1.6.0 | 
| Java SDK | kxi-java-sdk 1.6.0 | 
| RT Bridge | rt-bridge 1.6.0 | 
| Infrastructure | kxi-terraform-1.6.1.tgz | 
1.6.3
Release Date
2023-07-25
Improvements
- A new quick test deploy option is available for pipelines for faster iteration during development. This deploys a pipeline in test mode to the user’s scratchpad process and is significantly faster than a full test. See quick test deploy for more information.
Fixes
Expand to see the full detail of resolved issues here
Database
- 
Fixed a potential race condition between NFS replication and DAP reload signals. It was previously possible that a DAP may reload before NFS replicated data, which could result in data gaps. A new sequencing mechanism has been added to ensure DAPs do not reload until replication is complete. 
- 
Fixed an issue where converting a column from a stringto asymbolwould throw atypeerror.
- 
An error has been fixed that would occur when updating an object storage tier that used an inventory file after a data migration. 
- 
A new warning has been added to the Resource Coordinator if no Aggregators connect to it. After a wait period, if an Aggregator continues not to connect, this will be escalated to an error to indicate that the system is not ready for queries. 
- 
REST queries could have input parameters converted to the wrong type when multiple type options were possible. REST APIs were converting to the maximum possible type instead of using the correct default type. 
- 
Database names in diagnostics now correctly correspond to the name of the assembly that the database maps to. 
User Interface
- 
Any change made on the Database UI tab will now mark the database as unsaved, and warn the user if trying to close the tab with any unsaved changes. 
- 
The View Errorsbutton is now renamed toView Database Errorsand points to the database error logs. To viewPipeline Errors, click on theOpen Pipeline Errorsicon next to each pipeline error.
- 
Fixed an issue where renaming columns in the schema UI would incorrectly delete the underlying column and create a new one with null data. Column renames in the UI now correctly preserve the column’s data. 
Artifacts
| type | location | 
|---|---|
| Enterprise | insights-1.6.3.tgz | 
| Operator | kxi-operator-1.6.1.tgz | 
| CLI | kxicli-1.6.1-py3-none-any.whl | 
| C SDK | kxi-c-sdk 1.6.0 | 
| Java SDK | kxi-java-sdk 1.6.0 | 
| RT Bridge | rt-bridge 1.6.0 | 
| Infrastructure | kxi-terraform-1.6.1.tgz | 
1.6.2
Release Date
2023-07-03
New Features
- 
A file watcher for polling cloud storage is now supported in the Stream Processor. The file watcher can monitor any Azure, AWS, or GCP object storage directory. It polls for new files to ingest into an SP pipeline. See the q reader API for details on how to configure the watchparameter in your SP reader. This feature will be available in the Python API and UI in a future release.
- 
Query resiliency has been improved by adding the ability to control how processes serving queries are shut down. These processes can now be configured to stay up to serve in-progress query requests before shutting down, ensuring users still receive their data and are unimpacted by system operations. Users simply define how long a process should continue to serve requests before ultimately going offline. This is configured by setting .values.service-gateway.aggregator.aggregator.terminationGracePeriodSecondsto an appropriate duration in your values file during installation.
- 
Query scalability has increased with the new ability to independently scale query processes within an assembly, allowing each assembly to have a tailored amount of these processes. Making this configurable and manually scalable lets you better size your assemblies with specific query workloads in mind. See routing configuration for more details. Furthermore, a new routing parameter called scope supports routing query requests based on your target assembly(s). 
- 
Reading directly from a Parquet file(s) in local storage is now supported in Stream Processor pipelines, allowing users to take advantage of this efficient common file format. See the q reader API for more details. This feature will be available in the Python API and UI in a future release. 
- 
Connect your existing kdb database already in object storage to your kdb Insights Enterprise system and query it. 
- 
Pipelines created in the UI can now be exported to be run by the CLI, either for automation or for migrating between environments. From the UI, select the pipeline and click ‘Export’. See Exporting artifacts for more details. 
Fixes
Expand to see the full detail of resolved issues here
User Interface
- 
In the kdb Insights Enterprise UI, new validation has been added for table names within schemas to ensure that they do not contain invalid characters. Previously, invalid characters could be included in tables names and the database would error after it was deployed. 
- 
In the kdb Insights Enterprise UI, you can now allow an internal stream to read data from an external source directly to a database. See stream configuration for more details. 
- 
When creating a new database or renaming an existing database, you are prevented from entering a database name longer than 24 characters. 
Artifacts
| type | location | 
|---|---|
| Enterprise | insights-1.6.2.tgz | 
| Operator | kxi-operator-1.6.1.tgz | 
| CLI | kxicli-1.6.1-py3-none-any.whl | 
| C SDK | kxi-c-sdk 1.6.0 | 
| Java SDK | kxi-java-sdk 1.6.0 | 
| RT Bridge | rt-bridge 1.6.0 | 
| Infrastructure | kxi-terraform-1.6.0.tgz | 
1.6.1
Release Date
2023-06-22
Improvements
- In the kdb Insights Database, a new routing parameter called scope has been introduced for routing query requests based on assembly. This parameter allows the user to specifically target individual assemblies for their query.
Artifacts
| type | location | 
|---|---|
| Enterprise | insights-1.6.1.tgz | 
| Operator | kxi-operator-1.6.0.tgz | 
| CLI | kxicli-1.6.0-py3-none-any.whl | 
| C SDK | kxi-c-sdk 1.6.0 | 
| Java SDK | kxi-java-sdk 1.6.0 | 
| RT Bridge | rt-bridge 1.6.0 | 
| Infrastructure | kxi-terraform-1.6.0.tgz | 
1.6.0
Release Date
2023-06-20
Improvements
- 
Support for air-gapped environments has been improved and both kxi install runandkxi install upgradesupport installing packaged charts (chart tgz’s) by passing the packaged chart name as an argument. If you use the default value ofkx-insightsfor the chart repo, you can install it as follows:kxi install run --version 1.6.0 --filepath values.yaml insights-1.6.0.tgzThis argument also supports chart references, for example: kxi install run --version 1.6.0 --filepath values.yaml <CHART_REPO>/insights
- 
The kdb Insights Database can now work with or without an inventory file provided for an object storage tier. Using an inventory file for your object storage tier is still the recommended configuration, as this leverages caching and greatly improves performance when querying object storage data. 
- 
The kdb Insights Enterprise UI has an improved left hand menu. It can be minimized, and it is displayed alongside the Pipeline Operators list when the pipeline editor is active. 
- 
The kdb Insights Database now validates that primary keys for a partitioned table include the partition column. Previously, setting a primary key on a partitioned table that was not the partition column would error when queried. 
- 
Query timeout messages now indicate a reason for the timeout. Previously, query timeouts gave no reason, or said “timed out for unspecified reasons”. See queuing timeouts for more details. 
- 
Greater stability through the use of Kubernetes discovery between the Service Gateway and database processes. 
- 
Client-side pivot queries are now available in Views, with optional server-side computation for kdb+/q. 
- 
When calling kxi install deletethe kdb Insights CLI now backs up assemblies before tearing them down.
Fixes
Expand to see the full detail of resolved issues here
Security
- Various CVEs have been remediated as part of this release.
Database
- 
Resiliency improvements have been made to ensure the kdb Insights Database can recover from multiple days without end-of-day processing having completed. Previously, if more than 2 EODs were missed, it was possible to get a misalignederror on recovery.
- 
Validation has been added for assemblies to ensure that tiers' scheduled alignment time (snap value) are provided as the kdb+ timetype (19h). Previously users could enter a timespan which would silently be ignored. Entering a timespan will now error.
Reliable Transport
- Kubernetes service account tokens are now automatically refreshed from disk. In previous versions these were not refreshed, causing failing requests to the Kubernetes control plane and pods had to be restarted.
Deprecation
CLI Install Commands
The following three arguments have been deprecated from kxi install setup: chart-repo-name, chart-repo-username and chart-repo-url.
To prevent breaking changes the arguments will still work, but they may be removed in a future version. Adding a chart repository is now decoupled from kxi commands. The suggested approach when calling kxi install setup is to add the chart repository directly using helm repo add and to reference that repository by passing the chart reference as an argument.
If you use the default value of kx-insights for the chart repo, you can install it as follows:
kxi install run --version 1.6.0 --filepath values.yaml
If you have used a non-default chart repo value then you can install with:
kxi install run --version 1.6.0 --filepath values <CHART_REPO>/insights
CLI Lifecycle Commands
The following commands have been removed. Please use the equivalents below to manage assemblies.
| removed | supported command | 
|---|---|
| kxi azure assembly backup | kxi assembly backup | 
| kxi azure assembly delete | kxi assembly teardown | 
| kxi azure assembly restore | kxi assembly deploy | 
Third-party dependencies
kdb Insights Enterprise 1.6.0 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.6.0 release of the standalone infrastructure installation scripts.
Artifacts
| type | location | 
|---|---|
| Enterprise | insights-1.6.0.tgz | 
| Operator | kxi-operator-1.6.0.tgz | 
| CLI | kxicli-1.6.0-py3-none-any.whl | 
| C SDK | kxi-c-sdk 1.6.0 | 
| Java SDK | kxi-java-sdk 1.6.0 | 
| RT Bridge | rt-bridge 1.6.0 | 
| Infrastructure | kxi-terraform-1.6.0.tgz | 
Known Issues
- 
In 1.6.0 only, any code evaluated in the Python editor will throw a type error. To fix the Python editor for this issue you can run the following in a q editor: \d .com_kx_edi python.run: { z: python.i.removeExtraIndents z; a: python.i.run[z; y]; $[x;$[y;python.i.truncate (),a;a];$[y;"";::]] }
- 
When entering a query via the UI, Start and End Date fields are always required. To query against a splayed table or reference data, dummy dates must be entered. 
- 
When writing Python code in the scratchpad, if you type from kxi import sp, it will automatically auto-correct tofrom kxi import super. The workaround for this issue is as follows:- Accept the auto-correct
- Add a new line to the scratchpad
- Go back up and edit superback tosp
- Press the down arrow to go to the next line
 
- 
On startup of pods, the following error might be observed after approximately three minutes of a pod starting up no acct for 3x period, exiting. This stems from a temporary startup job not shutting down correctly. It is independent from the main processes and does not indicate any application fault.
- 
A number of stability issues were identified around license checking. These could cause adverse performance in some circumstances so it is recommended to upgrade your license to prevent these issues. To do this, grab your license UUID from the System Information dialogue in the kdb Insights Enterprise UI or from a running process using last " " vs .z.l 7. Save this to a variable$LICENSE_UUIDand run the commands belowklic license renew $LICENSE_UUID --version=latest env QLIC=$(pwd) klic license fetch $LICENSE_UUIDOnce the license is fetched you can update your license secret using the command below. Below commands default the license secret name to kxi-license, set the$SECRETvariable if this isn’t correct.printf "data:\n license: %s\n" $(base64 -w0 kx.lic) > patch.yaml kubectl patch secret ${SECRET:-kxi-license} --patch-file=patch.yaml
- When upgrading, the kdb Insights CLI does not wait until an assembly is fully operative before returning control. Therefore, there is a delay between the kdb Insights CLI returning control and the assembly being ready. If, for any reason, the assembly cannot start, you will not be notified.
- If a reader node is added to a pipeline that invokes .qsp.read.fromFileusing chunking, then compilation fails.
- A known issue exists within the kxi install rollbackcommand when rolling back to prior versions. When the target version was installed withkeycloak.initUserenabled. It is expected thekeycloak-config-clijob will fail. This is due to the rollback trying to revert that user's password and violating the password history policy.
The rollback failure will manifest as the failure of the keycloak-config-cli job. This will create job pods as it fails and retries.
In order to proceed with the rollback it's recommended to delete kubectl delete job ${RELEASE_NAME}-keycloak-config-cli. 
A known issue exists during a reinstall using the CLI where the keycloak.initUser is enabled. If the user's password has changed,
the reinstall will try to revert it back and be rejected by the password history policy. 
This can be avoided by disabling the user import on reinstall using --import-users False as below:
kxi install run --import-users False ..
Backward Compatibility
If performing a rollback from 1.6.0 to 1.5.x, a rollback chart is required. See Upgrading for more details.
1.5.3
Release Date
2023-06-19
Improvements
- 
Resiliency improvements have been made to ensure the kdb Insights Database can recover from multiple days without end-of-day processing having completed. Previously, if more than 2 EODs were missed, it was possible to get a misalignederror on recovery.
- 
The kdb Insights Database can now work with or without an inventory file provided for an object storage tier. Using an inventory file for your object storage tier is still the recommended configuration, as this leverages caching and greatly improves performance when querying object storage data. 
- 
In cases where no data transformation is required, the kdb Insights Enterprise UI now allows Streams to be configured to write directly to the database. This reduces the amount of resources required for data ingestion and lowers operating costs. 
Fixes
Expand to see the full detail of resolved issues here
Security
- Various CVEs have been remediated as part of this release.
User Interface
- 
When creating a new database or renaming an existing database, you are now prevented from entering a database name longer than 24 characters. Previously, there was no restriction which could lead to name truncation. 
- 
The Database Schema Code View page now accepts all schema configuration options. Previously, it would not accept blockSizeorisSharded.
Reliable Transport
- Kubernetes service account tokens are now automatically refreshed from disk. In previous versions these were not refreshed, causing failing requests to the Kubernetes control plane and a need to restart your pods to recover.
Artifacts
| type | location | 
|---|---|
| Enterprise | insights-1.5.3.tgz | 
| Operator | kxi-operator-1.5.3.tgz | 
| CLI | kxicli-1.5.0-py3-none-any.whl | 
| C SDK | kxi-c-sdk 1.5.0 | 
| Java SDK | kxi-java-sdk 1.5.0 | 
| RT Bridge | rt-bridge 1.5.0 | 
| Infrastructure | kxi-terraform-1.5.1.tgz | 
1.5.2
Release Date
2023-05-31
Improvements
- 
In the kdb Insights Enterprise UI, when filtering queries in the Query page, distinct is now a supported aggregation type. 
- 
The getDataAPI can now perform aggregations on foreign key columns.
Fixes
Expand to see the full detail of resolved issues here
- Kubernetes service account tokens are now automatically refreshed from disk. In previous versions these were not refreshed, causing failing requests to the Kubernetes control plane and pods had to be restarted.
Database
- 
When deploying an assembly via the kdb Insights CLI, if ‘size’ is not specified for DAP instances, a default of 3 replicas will once again be applied. In 1.5.1, this default was increased to 4 to provide increased availability, but 3 has been restored as the standard to control costs. Users can configure a greater number of replicas if desired. 
- 
In the kdb Insights Enterprise UI, pipelines associated with a database now show in the status table. Previously, only the first pipeline would be shown. 
- 
In the kdb Insights Enterprise UI, the database schema overview now updates when changes are made to the database’s schema. Previously, this would only show the schema state when first viewed. 
- 
In the kdb Insights Enterprise UI, database documents no longer get marked as modified after a teardown or cleanup. 
- 
The database configuration UI now validates that the minimum rollover time is 1 minute. Previously, this could be set to 0. 
Stream Processor
- Pipelines can be now be safely torn down without checkpoints having been cleared. Previously, if a teardown was followed by a restart, it is possible the pipeline would never run.
Artifacts
| type | location | 
|---|---|
| Enterprise | insights-1.5.2.tgz | 
| Operator | kxi-operator-1.5.2.tgz | 
| CLI | kxicli-1.5.0-py3-none-any.whl | 
| C SDK | kxi-c-sdk 1.5.0 | 
| Java SDK | kxi-java-sdk 1.5.0 | 
| RT Bridge | rt-bridge 1.5.0 | 
| Infrastructure | kxi-terraform-1.5.1.tgz | 
1.5.0
Release Date
2023-05-09
New Features
UI
- The kdb Insights Enterprise UI has a new and improved look and user experience for viewing the details of your database(s). All relevant details about a database are now grouped together in a single summary page, giving users an intuitive view into the details and health of its components. Users can quickly see if any errors or warnings are present, and drill down into the details to investigate directly from the page. The details of your schema are conveniently presented for reference as well. To accompany this new interface, the term Assemblies has been simplified to Database in the UI. Assemblies remain the underlying concept tying components together, and are still referenced in documentation. Manual upgrade of old streams and schemas may be required. See upgrading entities in the UI for more details.
Queries
- 
To protect against reserved word and column name conflicts, the way labels are passed to a query has changed. Labels should now be specified either as a dictionary, or with the prefix label_. The old label style is still supported in 1.5, but is deprecated and will be disabled by default in 1.6. See upgrade considerations on labels for more details.
- 
Distinct has been added to the available aggregations in getDatafor database queries.
Pipelines
- 
Users can now use Python code in all areas of the pipeline UI, allowing for further flexibility in Python user experience with kdb Insights Enterprise. Previously, the addition of Python code to sections of pipeline UI were limited in scope to the function cells of the pipeline configuration forms. 
- 
The Stream Processor Python API can now leverage automatic schema conversion using a new function kxi.sp.transform.schema.
- 
Users can now use the Kafka Schema Registry in Python and the UI. See kxi.sp.read.from_kafkafor Python, and the Kafka reader.
- 
String manipulation utilities have been added to the UI and the Stream Processor Python and q APIs, allowing users to selectively convert the string data to upper or lowercase representations for the purpose of data cleansing. 
- 
Non-UI deployments of Stream Processors now support pipeline replicas, providing enhanced resilience to deployed pipelines. Users can now choose to run their pipeline with replicas for high availability in the Stream Processor. This replaces the previous use of pipeline groups. 
Reliable Transport
- 
Reliable Transport now offers subscribers the ability to use dynamic client-side filtering, enabling users to control what parts of the data feed their subscribers need to receive. This can greatly improve ingestion performance by eliminating the need for subscribers to handle discarding of unnecessary data. See Filteringfor more information.
- 
RT has introduced logHistory, a new API to assist in analysis and debugging. The API returns metadata about the RT log file history for logs that are no longer available. This includes:- The log file name.
- The time of the first message added to that log file.
- The position of the first message added to that log file.
 See Log File Meta Datafor more information.
Command Line Interface
- 
A rollback command has been added to the CLI to simplify rolling back your installed instance of kdb Insights Enterprise after upgrading. 
- 
A kxi usersubcommand has been added to the CLI to support managing users programmatically. This provides greater flexibility than using the keycloakinitUservalues at deploy time.
Standalone Installation
- Ability to control which components should be enabled (cert-manager,ingress-nginx, sharedfiles storage class). The available components are defined on the configuration file (kxi-terraform.env).
Improvements
- 
Batch ingest now supports ingesting tables that have no symbols. Additionally, extra validation has been added to verify symbol integrity. 
- 
Batch ingest now supports sorting of columns. 
- 
The kdb Insights Database gateway now supports returning responses that are greater than 2GB for IPC requests. See routing configuration for more details. 
- 
Database schemas in the UI can now be modified for assemblies that have been stopped. See schema modification. 
- 
Requests that supply a log correlator (logCorr) will now see that correlator in the Service Gateway logs. Previously a random correlator was used in the Service Gateway logs. 
- 
Users can now utilize backtick syntax when defining aggregations in Views, e.g. `c1`avg`price.
- 
Pipeline editors can now be resized vertically. 
- 
Labels for improved accessibility have been added to the Pipelines screen. 
- 
Added significant improvements for accessibility using keyboard navigation and/or screen readers in the UI. - 
Users can exit a text area in a code block on the Query page by first pressing "CTRL+M" before pressing the "Tab" key. 
- 
The entity tree menu button can now be opened when hovering your mouse over the entity tree. Arrows can then be used to navigate. 
- 
"Code View" on the Schemas page can now be closed with the "Esc" key. 
- 
The Views and Pipeline pages now allow draggable elements to be inserted/dragged onto the page with the use of your keyboard. 
 
- 
- Kubernetes 1.25 is now supported and the default version for standalone installations.
- Ensure the latest AWS CLI is installed on the docker image used for standalone installations
Fixes
Expand to see the full detail of resolved issues here
Database
- 
Additional historical tiers that used object storage in the UI now allow dashes and spaces in file names. Previously they would error for dashes and spaces. 
- 
Migrating tiers to object storage could fail with the eventual error SMDBM Migration discontinued due to failureif multiple threads were used.
- 
New validation has been added to prevent accidentally adding a object storage tier to a database that does not already have one. This would previously error at EOD with a file not found error. 
- 
Schema conversions are now more robust on network based file systems (ex. Rook Ceph). Previously, this could result in a EXDEV. OS Reports: Invalid cross-device link errorin the Storage Manager.
- 
Changes to disk sort columns in a schema that would be incompatible with the current disk sort will now error with a clear message at deploy time. Previously, this would error with a u-failerror either at an EOI or EOD.
- 
Batch ingest can now gracefully handle scenarios where there is no data provided in the session. Previously, this would result in the following error: Error reporting to licensing server: Value must be a long, leaving the ingest pipeline stuck in aRUNNINGstate.
- 
When removing a symbol column from a table, the SM should be able to properly handle its removal as well as the sym file. 
- 
If an in-memory sort is applied to a column in a schema, it is now sorted on arrival in the RDB. Previously, if data arrived out of order with this set, an s-failerror would be thrown.
- 
In the Storage Manager metrics, the kxi_sm_hdb_date_recordsmetric no longer reports an empty value at startup, which resulted in false alerts about the HDB being offline.
- 
The Storage Manager now double buffers its state table in order to protect against corruption. 
- 
Rapid successive queries using qsql, such as those from Views in the kdb Insights Enterprise UI, no longer have the potential to return query results out of order.
- 
The kxi_sg_pendingmetric would previously be decremented twice when a connection closed, resulting in negative pending values.
- 
The Service Gateways were creating duplicate connections to Resource Coordinators while they were waiting to come online. This was resulting in a large number of redundant connections being opened between the services. In large deployments, this could result in connerrors in the Resource Coordinator.
- 
RDBs and HDBs that require a dependency on the IDB will now error at startup if one is not specified as part of the mount configuration. 
User Interface
- 
Previously, a database would show a loading spinner if one of its pipelines had reached a ‘finished’ state while its other components were in a ‘ready' state. This has now been rectified and the database will display a ‘ready’ state in this case. 
- 
An issue with pasting into text fields in a pipeline node’s configuration has been fixed. Previously, the node may be been duplicated. 
Stream Processor
- 
Pipeline names are now properly displayed in the Running Pipelines section of the Overview page. Previously, these were displaying the pipeline ID and were not clickable for viewing further information. 
- 
Pipelines deployed via as part of a Database now properly set Kubernetes secrets. Previously, secrets were only being set properly for standalone pipelines. 
- 
The presence of a UTF-8 byte-order mark at the beginning of CSV files will now be automatically removed from data when acted on by the Stream Processor CSV decoder. 
- 
Expression readers now return the result of Python lambdas. 
- 
Window nodes in the Stream Processor can now accept dictionaries as input batches. Previously, incoming dictionaries would be merged with input batch in the buffer, instead of appending to a buffered list of dictionaries. 
- 
The python write.to_databasenode previously converted assembly names to booleans. This is now resolved, and also fully supports the direct write functionality.
- 
The Stream Processor's Protobuf decoder no longer ignores the value of As Listwhen a pipeline is deployed from the UI. Previously, this value was being overwritten.
- 
The Stream Processors Protocol Buffer Encoder node now properly saves the selected Payload Type. 
- 
The Stream Processor Database Reader now supports SQL statement queries. Previously, this node had erroneously suggested the use of qsql statements for querying which was unsupported. 
- 
The default onFinishfunctions for the apply node have been updated to have the correct parameters and examples of flushing a buffer.
- 
When using directWrite functionality in .qsp.write.toDatabase, table names as strings are now supported. Previously, this had to be a symbol.
- 
Copy/pasting nodes within a pipeline document while other pipeline documents are open in the background no longer produces duplicates. Previously, the copy/paste operation was being applied to both the intended pipeline as well as the unintended pipelines, resulting in nodes disappearing due to shared names/ids. 
- 
Security vulnerabilities patched in the Stream Processor for the following CVEs: CVE-2022-41910, CVE-2022-41902, CVE-2022-41900, CVE-2022-41880. 
- 
Query sessions had previously set error trapping to 1within the q session, resulting in users being unable to interact with their query session. This behavior manifested in users being unable to interact with their query sessions until they were manually restarted.
Command Line Interface
- With previous versions of the kdb Insights CLI, the kxi install list-versions command would return an outdated list of versions. This has now been resolved and the list will be updated on each invocation.
Standalone Installation
- Fix Rook-Ceph OSD not getting assigned if underlying node changes
Third-party dependencies
kdb Insights Enterprise 1.5.0 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.5.0 release of the standalone infrastructure installation scripts.
Artifacts
| type | location | 
|---|---|
| Enterprise | insights-1.5.0.tgz | 
| Operator | kxi-operator-1.5.0.tgz | 
| CLI | kxicli-1.5.0-py3-none-any.whl | 
| C SDK | kxi-c-sdk 1.5.0 | 
| Java SDK | kxi-java-sdk 1.5.0 | 
| RT Bridge | rt-bridge 1.5.0 | 
| Infrastructure | kxi-terraform-1.5.0.tgz | 
Upgrade notes
Upgrading existing assemblies
With the adoption of NuRaft by the Reliable Transport (RT) service, if you are upgrading an existing assembly from 1.3.x to any newer release, you must delete the RT PVCs.
Causes duplicate data
Due to the change in the Raft implementation, duplicate data will occur with this upgrade procedure.
- Stop all external publishers to kdb Insights Enterprise
- Wait for all published messages to be available for querying from the database; this will reduce (but not eliminate) the amount of duplicate data
- 
Backup any assemblies that may be running $ kxi assembly backup --filepath assembly-state-file.yaml Persisted assembly definitions for ['dfx-assembly', 'iot-assembly'] to assembly-state-file.yaml
- 
Teardown assemblies named in the output of the backup command $ kxi assembly teardown --name dfx-assembly --wait --use-kubeconfig Tearing down assembly dfx-assembly Are you sure you want to teardown dfx-assembly [y/N]: y Waiting for assembly to be torn down [------------------------------------] 0% $ kxi assembly teardown --name iot-assembly --wait --use-kubeconfig Tearing down assembly iot-assembly Are you sure you want to teardown iot-assembly [y/N]: y Waiting for assembly to be torn down [------------------------------------] 0%
- 
Delete the RT PVCs kubectl get pvc -n <namespace> | grep sequencer-store | awk '{ print $ 1 }' | xargs kubectl delete pvc -n <namespace>
- 
Carry out the upgrade 
- 
Restore assemblies kxi assembly deploy --filepath assembly-state-file.yaml --use-kubeconfig
Restriction on upgrading to older versions
The CLI will not allow you to "upgrade" to an older version of kdb Insights Enterprise. Please use the rollback command to revert to a previous version.
Known Issues
- 
On startup of pods, the following error might be observed after approximately three minutes of a pod starting up no acct for 3x period, exiting. This stems from a temporary startup job not shutting down correctly. It is independent from the main processes and does not indicate any application fault.
- 
A number of stability issues were identified around license checking. These could cause adverse performance in some circumstances so it is recommended to upgrade your license to prevent these issues. To do this, grab your license UUID from the System Information dialogue in the kdb Insights Enterprise UI or from a running process using last " " vs .z.l 7. Save this to a variable$LICENSE_UUIDand run the commands belowklic license renew $LICENSE_UUID --version=latest env QLIC=$(pwd) klic license fetch $LICENSE_UUIDOnce the license is fetched you can update your license secret using the command below. Below commands default the license secret name to kxi-license, set the$SECRETvariable if this isn’t correct.printf "data:\n license: %s\n" $(base64 -w0 kx.lic) > patch.yaml kubectl patch secret ${SECRET:-kxi-license} --patch-file=patch.yaml
- Publishing of a single message larger than 1GB is not supported.
- Adding a sort attribute to memory or disk is currently not supported. Changing the attribute to be sorted will not apply the attribute and will error for data on disk.
- When upgrading, the kdb Insights CLI does not wait until an assembly is fully operative before returning control. Therefore, there is a delay between the kdb Insights CLI returning control and the assembly being ready. If, for any reason, the assembly cannot start, you will not be notified.
- 
If the Resource Coordinator (RC) times out a request on a dequeue, the displayed message "Unknown reason" should be interpreted as "Timed out before we were able to dequeue". 
- 
If two processes have the same host and port, then the second one to register will overwrite the first, meaning the first will be invisible to the RC, and consequently never receive any requests. 
- 
When entering a query via the UI, Start and End Date fields are always required. To query against a splayed table or reference data, dummy dates must be entered. 
- 
When writing Python code in the scratchpad, if you type from kxi import sp, it will automatically auto-correct tofrom kxi import super. The workaround for this issue is as follows:- Accept the auto-correct
- Add a new line to the scratchpad
- Go back up and edit superback tosp
- Press the down arrow to go to the next line
 
- 
Any object storage reader nodes in pipelines created in the UI prior to 1.4.0 may need to be edited after the upgrade, as the file path may be split across several path inputs on the properties tab. To remedy, delete the path fields and enter the correct path into the reader. 
- 
If a reader node is added to a pipeline that invokes .qsp.read.fromFileusing chunking, then compilation fails.
- A known issue exists within the kxi install rollbackcommand when rolling back to prior versions. When the target version was installed withkeycloak.initUserenabled. It is expected thekeycloak-config-clijob will fail. This is due to the rollback trying to revert that user's password and violating the password history policy.
The rollback failure will manifest as the failure of the keycloak-config-cli job. This will create job pods as it fails and retries.
In order to proceed with the rollback it's recommended to delete kubectl delete job ${RELEASE_NAME}-keycloak-config-cli. 
A known issue exists during a reinstall using the CLI where the keycloak.initUser is enabled. If the user's password has changed,
the reinstall will try to revert it back and be rejected by the password history policy. 
This can be avoided by disabling the user import on reinstall using --import-users False as below:
kxi install run --import-users False ..
Backward Compatibility
If you are upgrading from a version earlier than 1.5.0 you must also read each of the relevant release notes below to ensure you know all the changes that will affect the upgrade.
1.4.5
Release for kdb Insights Enterprise.
Release Date
2023-04-26
Improvements
 [IMPROVEMENT]: If publishing a message larger than 1GB, the publisher will now receive a message too large error. Users can catch the error (need more clear detail) to avoid getting an error at runtime. This would previously cause downstream subscriber processes to run out of memory during processing. 
[IMPROVEMENT]: SQL queries that filter by time but do not explicitly select the time column are now supported. This would previously error.
Fixes
 [FIX]: Fixed an issue where rapid successive queries using qsql such as those from Views in the kdb Insights UI could return query results out of order. 
 [FIX]: Schema conversions are now more robust on network based file systems (ex. Rook Ceph).  Previously, this could result in a EXDEV. OS Reports: Invalid cross-device link error in the Storage Manager.  
[FIX]: Window nodes in the Stream Processor can now accept dictionaries as input batches. Previously, incoming dictionaries would be merged with input batch in the buffer, instead of appending to a buffered list of dictionaries.
Third-party dependencies
kdb Insights Enterprise 1.4 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.4 release of the standalone infrastructure installation scripts.
Artifacts
| type | location | 
|---|---|
| Enterprise | insights-1.4.5.tgz | 
| Operator | kxi-operator-1.4.2.tgz | 
| CLI | kxicli-1.4.2-py3-none-any.whl | 
| C SDK | kxi-c-sdk 1.4.0 | 
| Java SDK | kxi-java-sdk 1.4.0 | 
| RT Bridge | rt-bridge 1.4.0 | 
| Infrastructure | kxi-terraform-1.4.1.tgz | 
Upgrade notes
Upgrading existing assemblies
With the adoption of NuRaft by the Reliable Transport (RT) service, if you are upgrading an existing assembly created using a version prior to 1.4.0, you must delete the RT PVCs.
Causes duplicate data
Due to the change in the Raft implementation, duplicate data will occur with this upgrade procedure.
- Stop all external publishers to kdb Insights Enterprise
- Wait for all published messages to be available for querying from the database; this will reduce (but not eliminate) the amount of duplicate data
- 
Backup any assemblies that may be running $ kxi assembly backup --filepath assembly-state-file.yaml Persisted assembly definitions for ['dfx-assembly', 'iot-assembly'] to assembly-state-file.yaml
- 
Teardown assemblies named in the output of the backup command $ kxi assembly teardown --name dfx-assembly --wait --use-kubeconfig Tearing down assembly dfx-assembly Are you sure you want to teardown dfx-assembly [y/N]: y Waiting for assembly to be torn down [------------------------------------] 0% $ kxi assembly teardown --name iot-assembly --wait --use-kubeconfig Tearing down assembly iot-assembly Are you sure you want to teardown iot-assembly [y/N]: y Waiting for assembly to be torn down [------------------------------------] 0%
- 
Delete the RT PVCs kubectl get pvc -n <namespace> | grep sequencer-store | awk '{ print $ 1 }' | xargs kubectl delete pvc -n <namespace>
- 
Carry out the upgrade 
- 
Restore assemblies kxi assembly deploy --filepath assembly-state-file.yaml --use-kubeconfig
Licensing
A number of stability issues were identified around license checking. These could cause adverse performance in some circumstances so it is recommended to upgrade your license to prevent these issues.
To do this, grab your license UUID from the System Information dialogue in the kdb Insights Enterprise UI or from a running process using last " " vs .z.l 7. Save this to a variable $LICENSE_UUID and run the commands below.
klic license renew $LICENSE_UUID --version=latest
env QLIC=$(pwd) klic license fetch $LICENSE_UUID
Once the license is fetched you can update your license secret using the command below. Below commands default the license secret name to kxi-license, set the $SECRET variable if this isn’t correct.
printf "data:\n  license: %s\n" $(base64 -w0 kx.lic) > patch.yaml
kubectl patch secret ${SECRET:-kxi-license} --patch-file=patch.yaml
User import
The initUser will be automatically imported on initial install but not on upgrade. This prevents the initUser password from being reset on upgrade. 
A new value has been added to allow you to change this behavior from the default.
keycloak:
  importUsers: false
Monitoring
We have reduced the frequency that Prometheus will scrape the metrics from a sidecar. You will be affected if you are refreshing/polling monitoring dashboards at a rate below 2 minutes.
If you wish to continue with the higher frequency you can take one of the following steps:
-  Update the interval field within their charts.
    ```yaml
    metrics:
      serviceMonitor:
        interval: "30s"
    ```
- Override the chart values using the global value within insights/values.yaml.
    ```yaml
    global:
      metrics:
        serviceMonitor:
          interval: "30s"
    ```
- Update your assembly yaml, to override the default.
    ```yaml
    spec:
      metrics:
        enabled: true
        serviceMonitor:
          enabled: true
          interval: 10s
    ```
- Update your default within the Assembly Resource - This is generated using the insights/values.yaml.
    ```yaml
    kxi-operator:
      config:
        sidecar:
          metrics:
            serviceMonitor:
              interval: 30s
    ```
Default password policy
The default password policy has been updated to include the following rule:
- Not one of the previous 24 passwords
If you are upgrading from an earlier version and set importUsers: true, the password for initUser must be updated to a new, valid password in the values file before upgrade.
Default Keycloak Credentials
As of 1.3.0 the Keycloak initUser and initClient credentials are no longer defaulted within the kdb Insights values.yaml. See here for more details.
Downgrading to earlier versions
Downgrading to earlier versions was previously supported by executing kxi install upgrade. This is no longer supported. To install an earlier version, execute the rollback steps.
Schema Configuration Changes
The field updTsCol is no longer used, and has been removed from the Schema Settings screen. It should be removed from any separately maintained assembly YAML, or configuration made in the Schema Code View screen. 
Known Issues
- Publishing of a single message larger than 1GB is not supported.
- On startup of pods, the following error might be observed after approximately three minutes of a pod starting up no acct for 3x period, exiting. This stems from a temporary startup job not shutting down correctly. It is independent from the main processes and does not indicate any application fault.
- 
Adding a sort attribute to memory or disk is currently not supported. Changing the attribute to be sorted will not apply the attribute and will error for data on disk. 
- 
Schema changes will fail when attempting to remove all symbol columns from a schema that previously had any. 
When upgrading, the kdb Insights CLI does not wait until an assembly is fully operative before returning control. There is, therefore, a delay between the kdb Insights CLI returning control and the assembly being ready. If, for any reason, the assembly cannot start, you will not be notified.
- 
If the Resource Coordinator (RC) times out a request on a dequeue, the displayed message "Unknown reason" should be interpreted as "Timed out before we were able to dequeue". 
- 
If two processes have the same host and port, then the second one to register will overwrite the first, meaning the first will be invisible to the RC, and consequently never receive any requests. 
- 
When entering a query via the UI, Start and End Date fields are always required. To query against a splayed table or reference data, dummy dates must be entered. 
- 
When writing Python code in the scratchpad, if you type from kxi import sp, it will automatically auto-correct tofrom kxi import super. The workaround for this issue is as follows:- Accept the auto-correct
- Add a new line to the scratchpad
- Go back up and edit superback tosp
- Press the down arrow to go to the next line
 
- If in the Import Wizard, Next is clicked, no error will be thrown, which is invalid. At least one file needs to be present.
The kxi-controller will periodically log errors when an assembly has been deployed from the kdb Insights CLI. These errors can be safely ignored.
"[] Failed to compare saved assembly  to deployed version, error: type"
- 
Any object storage reader nodes in pipelines created in the UI prior to 1.4.0 may need to be edited after the upgrade, as the file path may be split across several path inputs on the properties tab. To remedy, delete the path fields and enter the correct path into the reader. 
- 
If a reader node is added to a pipeline that invokes .qsp.read.fromFileusing chunking, then compilation fails.
- When defining getData aggregations in a View configuration, a semi-colon separated list must be passed in the form of colAlias;aggFn;col. Symbols lists are currently not supported.
- 
Screen readers will not read out node information represented in a pop-up when hovered over, and may freeze when attempting to read a large amount of content. 
- 
Unable to navigate up and down cells and read all table content when navigating using only a keyboard. 
- The default CPU resources for PostgreSQL are too low and result in CPU throttling. The CPU resource can be updated by setting the below in your installation configuration values.yaml.
keycloak:
  postgresql:
    primary:
      resources:
        limits:
          cpu: 2000m
        requests:
          cpu: 50m
1.4.4
Release for kdb Insights Enterprise.
Release Date
2023-04-20
Improvements
[IMPROVEMENT]: The kdb Insights Database now supports a REST interface for loading historical datasets into an existing database. You can now perform a historical batch ingest using a simple REST API. For more details, see batch ingestion.
 [IMPROVEMENT]: Query requests that supply a log correlator (logCorr) will now see that correlator in the Service Gateway logs, allowing for easier traceability in query execution and an improved debugging experience. Previously a random correlator was used in the Service Gateway logs. 
[IMPROVEMENT]: Added significant improvements for accessibility using keyboard navigation and/or screen readers in the UI.
- 
Users can exit a text area in a code block on the Query page by first pressing "CTRL+M" before pressing the "Tab" key. 
- 
The entity tree menu button can now be opened when hovering your mouse over the entity tree. Arrows can then be used to navigate. 
- 
"Code View" on the Schemas page can now be closed with the "Esc" key. 
- 
The Views and Pipeline pages now allow draggable elements to be inserted/dragged onto the page with the use of your keyboard. 
Fixes
[FIX]: Security vulnerabilities patched in the Stream Processor for the following CVEs: CVE-2022-41910, CVE-2022-41902, CVE-2022-41900, CVE-2022-41880.
[FIX]: Additional historical tiers that use object storage in the UI now allow dashes and spaces in file names. Previously they would error for dashes and spaces.
 [FIX]: Migrating tiers to object storage could fail with the eventual error SMDBM Migration discontinued due to failure if multiple threads were used. 
[FIX]: If an SM client cannot connect to SM after a number of retries, it will now restart the pod to try to automatically recover. This resolves connection issues in DAPs when there are network connectivity issues.
[FIX]: Reading of files from Azure Storage larger than ~1MB now successfully writes to a kdb Insights database. Previously this was erroring due to an issue in the chunking of larger files.
[FIX]: The Service Gateway was creating duplicate connections to Resource Coordinators while they were waiting to come online. This was resulting in a large number of redundant connections being opened between the services. In large deployments, this could result in connection errors in the Resource Coordinator.
[FIX]: Expression readers now return the result of Python lambdas.
[FIX]: After upgrading kdb Insights Enterprise from 1.3.x to 1.4.x, clicking a node in a previously-saved pipeline in the UI no longer causes the function definition to flicker and disappear.
[FIX]: Fixed issue with 1.4.0 kxi-terraform scripts, where Terragrunt config was incompatible and was causing deployment failures on AWS.
Third-party dependencies
kdb Insights Enterprise 1.4 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.4 release of the standalone infrastructure installation scripts:target="_blank"}.
Artifacts
| type | location | 
|---|---|
| Enterprise | insights-1.4.4.tgz | 
| Operator | kxi-operator-1.4.2.tgz | 
| CLI | kxicli-1.4.2-py3-none-any.whl | 
| C SDK | kxi-c-sdk 1.4.0 | 
| Java SDK | kxi-java-sdk 1.4.0 | 
| RT Bridge | rt-bridge 1.4.0 | 
| Infrastructure | kxi-terraform-1.4.1.tgz | 
Upgrade notes
Upgrading existing assemblies
With the adoption of NuRaft by the Reliable Transport (RT) service, if you are upgrading an existing assembly created using a version prior to 1.4.0, you must delete the RT PVCs.
Causes duplicate data
Due to the change in the Raft implementation, duplicate data will occur with this upgrade procedure.
- Stop all external publishers to kdb Insights Enterprise
- Wait for all published messages to be available for querying from the database; this will reduce (but not eliminate) the amount of duplicate data
- 
Backup any assemblies that may be running $ kxi assembly backup --filepath assembly-state-file.yaml Persisted assembly definitions for ['dfx-assembly', 'iot-assembly'] to assembly-state-file.yaml
- 
Teardown assemblies named in the output of the backup command $ kxi assembly teardown --name dfx-assembly --wait --use-kubeconfig Tearing down assembly dfx-assembly Are you sure you want to teardown dfx-assembly [y/N]: y Waiting for assembly to be torn down [------------------------------------] 0% $ kxi assembly teardown --name iot-assembly --wait --use-kubeconfig Tearing down assembly iot-assembly Are you sure you want to teardown iot-assembly [y/N]: y Waiting for assembly to be torn down [------------------------------------] 0%
- 
Delete the RT PVCs kubectl get pvc -n <namespace> | grep sequencer-store | awk '{ print $ 1 }' | xargs kubectl delete pvc -n <namespace>
- 
Carry out the upgrade 
- 
Restore assemblies kxi assembly deploy --filepath assembly-state-file.yaml --use-kubeconfig
Licensing
A number of stability issues were identified around license checking. These could cause adverse performance in some circumstances so it is recommended to upgrade your license to prevent these issues.
To do this, grab your license UUID from the System Information dialogue in the kdb Insights Enterprise UI or from a running process using last " " vs .z.l 7. Save this to a variable $LICENSE_UUID and run the commands below.
klic license renew $LICENSE_UUID --version=latest
env QLIC=$(pwd) klic license fetch $LICENSE_UUID
Once the license is fetched you can update your license secret using the command below. Below commands default the license secret name to kxi-license, set the $SECRET variable if this isn’t correct.
printf "data:\n  license: %s\n" $(base64 -w0 kx.lic) > patch.yaml
kubectl patch secret ${SECRET:-kxi-license} --patch-file=patch.yaml
User import
The initUser will be automatically imported on initial install but not on upgrade. This prevents the initUser password from being reset on upgrade. 
A new value has been added to allow you to change this behavior from the default.
keycloak:
  importUsers: false
Monitoring
We have reduced the frequency that Prometheus will scrape the metrics from a sidecar. You will be affected if you are refreshing/polling monitoring dashboards at a rate below 2 minutes.
If you wish to continue with the higher frequency you can take one of the following steps:
-  Update the interval field within their charts.
    ```yaml
    metrics:
      serviceMonitor:
        interval: "30s"
    ```
- Override the chart values using the global value within insights/values.yaml.
    ```yaml
    global:
      metrics:
        serviceMonitor:
          interval: "30s"
    ```
- Update your assembly yaml, to override the default.
    ```yaml
    spec:
      metrics:
        enabled: true
        serviceMonitor:
          enabled: true
          interval: 10s
    ```
- Update your default within the Assembly Resource - This is generated using the insights/values.yaml.
    ```yaml
    kxi-operator:
      config:
        sidecar:
          metrics:
            serviceMonitor:
              interval: 30s
    ```
Default password policy
The default password policy has been updated to include the following rule:
- Not one of the previous 24 passwords
If you are upgrading from an earlier version and set importUsers: true, the password for initUser must be updated to a new, valid password in the values file before upgrade.
Default Keycloak Credentials
As of 1.3.0 the Keycloak initUser and initClient credentials are no longer defaulted within the kdb Insights values.yaml. See here for more details.
Downgrading to earlier versions
Downgrading to earlier versions was previously supported by executing kxi install upgrade. This is no longer supported. To install an earlier version, execute the rollback steps.
Schema Configuration Changes
The field updTsCol is no longer used, and has been removed from the Schema Settings screen. It should be removed from any separately maintained assembly YAML, or configuration made in the Schema Code View screen. 
Known Issues
- On startup of pods, the following error might be observed after approximately three minutes of a pod starting up no acct for 3x period, exiting. This stems from a temporary startup job not shutting down correctly. It is independent from the main processes and does not indicate any application fault.
- 
Adding a sort attribute to memory or disk is currently not supported. Changing the attribute to be sorted will not apply the attribute and will error for data on disk. 
- 
Schema changes will fail when attempting to remove all symbol columns from a schema that previously had any. 
- When upgrading, the kdb Insights CLI does not wait until an assembly is fully operative before returning control. There is, therefore, a delay between the kdb Insights CLI returning control and the assembly being ready. If, for any reason, the assembly cannot start, you will not be notified.
- 
If the Resource Coordinator (RC) times out a request on a dequeue, the displayed message "Unknown reason" should be interpreted as "Timed out before we were able to dequeue". 
- 
If two processes have the same host and port, then the second one to register will overwrite the first, meaning the first will be invisible to the RC, and consequently never receive any requests. 
- 
When entering a query via the UI, Start and End Date fields are always required. To query against a splayed table or reference data, dummy dates must be entered. 
- 
When writing python code in the scratchpad, if you type from kxi import sp, it will automatically auto-correct tofrom kxi import super. The workaround for this issue is as follows:- Accept the auto-correct
- Add a new line to the scratchpad
- Go back up and edit superback tosp
- Press the down arrow to go to the next line
 
- If in the Import Wizard, Next is clicked, no error will be thrown, which is invalid. At least one file needs to be present.
- The kxi-controller will periodically log errors when an assembly has been deployed from the kdb Insights CLI. These errors can be safely ignored.
"[] Failed to compare saved assembly  to deployed version, error: type"
- 
Any object storage reader nodes in pipelines created in the UI prior to 1.4.0 may need to be edited after the upgrade, as the file path may be split across several path inputs on the properties tab. To remedy, delete the path fields and enter the correct path into the reader. 
- 
If a reader node is added to a pipeline that invokes .qsp.read.fromFileusing chunking, then compilation fails.
- When defining getData aggregations in a View configuration, a semi-colon separated list must be passed in the form of colAlias;aggFn;col. Symbols lists are currently not supported.
- 
Screen readers will not read out node information represented in a pop-up when hovered over, and may freeze when attempting to read a large amount of content. 
- 
Unable to navigate up and down cells and read all table content when navigating using only a keyboard. 
- The default CPU resources for PostgreSQL are too low and result in CPU throttling. The CPU resource can be updated by setting the below in your installation configuration values.yaml.
keycloak:
  postgresql:
    primary:
      resources:
        limits:
          cpu: 2000m
        requests:
          cpu: 50m
1.4.3
Release Date
2023-03-31
Improvements
[IMPROVEMENT] We have reduced the frequency that Prometheus will scrape the metrics from a sidecar. You will be affected if you are refreshing/polling monitoring dashboards at a rate below 2 minutes.
If you wish to continue with the higher frequency you can take one of the following steps:
-  Update the interval field within their charts.
    ```yaml
    metrics:
    serviceMonitor:
        interval: "30s"
    Assemblies
    ```
- 
Update your assembly yaml, to override the default. ```yaml spec: metrics: enabled: true serviceMonitor: enabled: true interval: 10s ```
- 
Update your default within the Assembly Resource - This is generated using the insights/values.yaml. ```yaml kxi-operator: config: sidecar: metrics: serviceMonitor: interval: 30s ```
Fixes
[FIX]: Service Gateway: fixed remote code injection vulnerability in Snake YAML CVE-2022-1471
[FIX]: Queries to the kdb Insights Database now have a default timeout of 60s (previously 30s). This allows for longer running queries to be issued from query clients, such as the scratchpad.
[FIX]: Additional historical tiers in the UI now allow for a retention period to be set on the HDB tier. Previously this was erroring due to a validation issue.
[FIX]: In the UI, the real-time database rollover tier now correctly checks that rollover is less than the interval tier.
[FIX]: Requests to object storage (Azure Storage, AWS S3, Google Cloud Storage) will now backoff and retry if they get a throttle request from the vendor. Jitter will be introduced to the retry to ensure that replicated processes do not all retry at the same time.
[FIX]: Setting a column type to Any now correctly uses an anymap type. This was previously reset to an unselected value.
[FIX]: The REST Server's heartbeat logs are now set to TRACE to reduce log output (previously they were logged as INFO logs).
[FIX]: Pasting into a pipeline node’s configuration no longer duplicates the node.
[FIX]: Resolved issue where some pipelines with merge nodes would error with 'missing edge'.
[FIX]: Comments can now be added to the last line of the Scratchpad without causing it to error.
[FIX]: The Scratchpad now has more memory allocated for ad-hoc queries in the kdb Insights Enterprise query panel.
[FIX]: Stream Processor file reader nodes (Azure, AWS S3, File and Google storage) would only process the first file presented even when multiple files were present.
[FIX]: Object storage tiers can now be added to a database via the kdb Insights Enterprise UI.
Third-party dependencies
kdb Insights Enterprise 1.4.3 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.4.3 release of the standalone infrastructure installation scripts.
Artifacts
| type | location | 
|---|---|
Upgrade notes
Upgrading existing assemblies
With the adoption of NuRaft by the Reliable Transport (RT) service, if you are upgrading an existing assembly to version 1.4.0, you must delete the RT PVCs.
Causes duplicate data
Due to the change in the Raft implementation, duplicate data will occur with this upgrade procedure.
- Stop all external publishers to kdb Insights Enterprise
- Wait for all published messages to be available for querying from the database; this will reduce (but not eliminate) the amount of duplicate data
- 
Backup any assemblies that may be running $ kxi assembly backup --filepath assembly-state-file.yaml Persisted assembly definitions for ['dfx-assembly', 'iot-assembly'] to assembly-state-file.yaml
- 
Teardown assemblies named in the output of the backup command $ kxi assembly teardown --name dfx-assembly --wait --use-kubeconfig Tearing down assembly dfx-assembly Are you sure you want to teardown dfx-assembly [y/N]: y Waiting for assembly to be torn down [------------------------------------] 0% $ kxi assembly teardown --name iot-assembly --wait --use-kubeconfig Tearing down assembly iot-assembly Are you sure you want to teardown iot-assembly [y/N]: y Waiting for assembly to be torn down [------------------------------------] 0%
- 
Delete the RT PVCs kubectl get pvc -n <namespace> | grep sequencer-store | awk '{ print $ 1 }' | xargs kubectl delete pvc -n <namespace>
- 
Carry out the upgrade 
- 
Restore assemblies kxi assembly deploy --filepath assembly-state-file.yaml --use-kubeconfig
User import
The initUser will be automatically imported on initial install but not on upgrade. This prevents the initUser password from being reset on upgrade. 
A new value has been added to allow you to change this behavior from the default.
keycloak:
  importUsers: false
Default password policy
The default password policy has been updated to include the following rule:
- Not one of the previous 24 passwords
If you are upgrading from an earlier version and set importUsers: true, the password for initUser must be updated to a new, valid password in the values file before upgrade.
Default Keycloak Credentials
As of 1.3.0 the Keycloak initUser and initClient credentials are no longer defaulted within the kdb Insights values.yaml. See here for more details.
Downgrading to earlier versions
Downgrading to earlier versions was previously supported by executing kxi install upgrade. This is no longer supported. To install an earlier version, execute the rollback steps.
Schema Configuration Changes
The field updTsCol is no longer used, and has been removed from the Schema Settings screen. It should be removed from any separately maintained assembly YAML, or configuration made in the Schema Code View screen. 
Known Issues
- 
On startup of pods, the following error might be observed after approximately three minutes of a pod starting up no acct for 3x period, exiting. This stems from a temporary startup job not shutting down correctly. It is independent from the main processes and does not indicate any application fault.
- 
On initial startup of kdb Insights Enterprise, there may be some noise printed in the logs while the system initializes unable to flush accounting logs. This relates to the capturing of consumption-based license logs and is thrown while all pods get into a running state. It does not indicate any fault in the application and all data should be flushed correctly after a short period.
- 
Adding a sort attribute to memory or disk is currently not supported. Changing the attribute to be sorted will not apply the attribute and will error for data on disk. 
- 
Schema changes will fail when attempting to remove all symbol columns from a schema that previously had any. 
- 
Historical object storage tiers cannot be added using the UI due to a validation issue. These tiers can still be configured using assembly files submitted using the KXI CLI. 
When upgrading, the kdb Insights CLI does not wait until an assembly is fully operative before returning control. There is, therefore, a delay between the kdb Insights CLI returning control and the assembly being ready. If, for any reason, the assembly cannot start, you will not be notified.
- 
If the Resource Coordinator (RC) times out a request on a dequeue, the displayed message "Unknown reason" should be interpreted as "Timed out before we were able to dequeue". 
- 
If two processes have the same host and port, then the second one to register will overwrite the first, meaning the first will be invisible to the RC, and consequently never receive any requests. 
- 
When entering a query via the UI, Start and End Date fields are always required. To query against a splayed table or reference data, dummy dates must be entered. 
- 
When writing python code in the scratchpad, if you type from kxi import sp, it will automatically auto-correct tofrom kxi import super. The workaround for this issue is as follows:- Accept the auto-correct
- Add a new line to the scratchpad
- Go back up and edit superback tosp
- Press the down arrow to go to the next line
 
- If in the Import Wizard, Next is clicked, no error will be thrown, which is invalid. At least one file needs to be present.
The kxi-controller will periodically log errors when an assembly has been deployed from the kdb Insights CLI. These errors can be safely ignored.
"[] Failed to compare saved assembly  to deployed version, error: type"
- 
Please ensure all pipelines have different names. Two pipelines with the same name may not be deploy correctly. 
- 
Any object storage reader nodes in pipelines created in the UI prior to 1.4.0 may need to be edited after the upgrade, as the file path may be split across several path inputs on the properties tab. To remedy, delete the path fields and enter the correct path into the reader. 
- 
If a reader node is added to a pipeline that invokes .qsp.read.fromFileusing chunking, then compilation fails.
When defining getData aggregations in a View configuration, a semi-colon separated list must be passed in the form of colAlias;aggFn;col. Symbols lists are currently not supported. 
The default CPU resources for PostgreSQL are too low and result in CPU throttling. The CPU resource can be updated by setting the below in your installation configuration values.yaml. 
keycloak:
  postgresql:
    primary:
      resources:
        limits:
          cpu: 2000m
        requests:
          cpu: 50m
1.4.2
Release for kdb Insights Enterprise.
Release Date
2023-03-17
Fixes
[FIX] Resource utilization in the UI Scratchpad has been greatly improved. This fix along with a larger default memory allocation provide greater Scratchpad process stability.
Third-party dependencies
kdb Insights Enterprise 1.4.2 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.4.0 release of the standalone infrastructure installation scripts.
Artifacts
| type | location | 
|---|---|
| Enterprise | insights-1.4.2.tgz | 
| Operator | kxi-operator-1.4.0.tgz | 
| CLI | kxicli-1.4.1-py3-none-any.whl | 
| C SDK | kxi-c-sdk 1.4.0 | 
| Java SDK | kxi-java-sdk 1.4.0 | 
| RT Bridge | rt-bridge 1.4.0 | 
| Infrastructure | kxi-terraform-1.4.0.tgz | 
Upgrade notes
Upgrading existing assemblies
With the adoption of NuRaft by the Reliable Transport (RT) service, if you are upgrading an existing assembly to version 1.4.0, you must delete the RT PVCs.
Causes duplicate data
Due to the change in the Raft implementation, duplicate data will occur with this upgrade procedure.
- Stop all external publishers to kdb Insights Enterprise
- Wait for all published messages to be available for querying from the database; this will reduce (but not eliminate) the amount of duplicate data
- 
Backup any assemblies that may be running $ kxi assembly backup --filepath assembly-state-file.yaml Persisted assembly definitions for ['dfx-assembly', 'iot-assembly'] to assembly-state-file.yaml
- 
Teardown assemblies named in the output of the backup command $ kxi assembly teardown --name dfx-assembly --wait --use-kubeconfig Tearing down assembly dfx-assembly Are you sure you want to teardown dfx-assembly [y/N]: y Waiting for assembly to be torn down [------------------------------------] 0% $ kxi assembly teardown --name iot-assembly --wait --use-kubeconfig Tearing down assembly iot-assembly Are you sure you want to teardown iot-assembly [y/N]: y Waiting for assembly to be torn down [------------------------------------] 0%
- 
Delete the RT PVCs kubectl get pvc -n <namespace> | grep sequencer-store | awk '{ print $ 1 }' | xargs kubectl delete pvc -n <namespace>
- 
Carry out the upgrade 
- 
Restore assemblies kxi assembly deploy --filepath assembly-state-file.yaml --use-kubeconfig
User import
The initUser will be automatically imported on initial install but not on upgrade. This prevents the initUser password from being reset on upgrade. 
A new value has been added to allow you to change this behavior from the default.
keycloak:
  importUsers: false
Default password policy
The default password policy has been updated to include the following rule:
- Not one of the previous 24 passwords
If you are upgrading from an earlier version and set importUsers: true, the password for initUser must be updated to a new, valid password in the values file before upgrade.
Default Keycloak Credentials
As of 1.3.0 the Keycloak initUser and initClient credentials are no longer defaulted within the kdb Insights values.yaml. See here for more details.
Downgrading to earlier versions
Downgrading to earlier versions was previously supported by executing kxi install upgrade. This is no longer supported. To install an earlier version, execute the rollback steps.
Schema Configuration Changes
The field updTsCol is no longer used, and has been removed from the Schema Settings screen. It should be removed from any separately maintained assembly YAML, or configuration made in the Schema Code View screen. 
Known Issues
- 
On startup of pods, the following error might be observed once roughly after three minutes of a pod starting up no acct for 3x period, exiting. This stems from a temporary startup job not shutting down correctly. It is independent from the main processes and does not indicate any application fault.
- 
On initial startup of kdb Insights Enterprise, there may be some noise printed in the logs while the system initializes unable to flush accounting logs. This relates to the capturing of consumption-based license logs and is thrown while all pods get into a running state. It does not indicate any fault in the application and all data should be flushed correctly after a short period.
- 
Adding a sort attribute to memory or disk is currently not supported. Changing the attribute to be sorted will not apply the attribute and will error for data on disk. 
- 
Schema changes will fail when attempting to remove all symbol columns from a schema that previously had any. 
- 
Historical object storage tiers cannot be added using the UI due to a validation issue. These tiers can still be configured using assembly files submitted using the KXI CLI. 
When upgrading, the kdb Insights CLI does not wait until an assembly is fully operative before returning control. There is, therefore, a delay between the kdb Insights CLI returning control and the assembly being ready. If, for any reason, the assembly cannot start, you will not be notified.
- 
If the Resource Coordinator (RC) times out a request on a dequeue, the displayed message "Unknown reason" should be interpreted as "Timed out before we were able to dequeue". 
- 
If two processes have the same host and port, then the second one to register will overwrite the first, meaning the first will be invisible to the RC, and consequently never receive any requests. 
- 
When entering a query via the UI, Start and End Date fields are always required. To query against a splayed table or reference data, dummy dates must be entered. 
- 
When writing python code in the scratchpad, if you type from kxi import sp, it will automatically auto-correct tofrom kxi import super. The workaround for this issue is as follows:- Accept the auto-correct
- Add a new line to the scratchpad
- Go back up and edit superback tosp
- Press the down arrow to go to the next line
 
- If in the Import Wizard, Next is clicked, no error will be thrown, which is invalid. At least one file needs to be present.
The kxi-controller will periodically log errors when an assembly has been deployed from the kdb Insights CLI. These errors can be safely ignored.
"[] Failed to compare saved assembly  to deployed version, error: type"
- 
When creating a pipeline the user interface does not stop you from creating it with the same name as an existing pipeline, however two pipelines with the same name may not be deploy correctly. Please ensure all pipelines have different names. 
- 
Any object storage reader nodes in pipelines created in the UI prior to 1.4.0 may need to be edited after the upgrade, as the file path may be split across several path inputs on the properties tab. To remedy, delete the path fields and enter the correct path into the reader. 
- 
If a reader node is added to a pipeline that invokes .qsp.read.fromFileusing chunking, then compilation fails.
When defining getData aggregations in a View configuration, a semi-colon separated list must be passed in the form of colAlias;aggFn;col. Symbols lists are currently not supported. 
The default CPU resources for PostgreSQL are too low and result in CPU throttling. The CPU resource can be updated by setting the below in your installation configuration values.yaml. 
keycloak:
  postgresql:
    primary:
      resources:
        limits:
          cpu: 2000m
        requests:
          cpu: 50m
1.4.1
Release for kdb Insights Enterprise.
Release Date
2023-03-14
Fixes
[FIX] In 1.3.3 and 1.4.0, if the Storage Manager falls behind on EODs for more than a full day, IDB links could be written incorrectly when late data was present. If this issue is encountered, manual data changes are required to recover the database including backup of the stream logs from the date of the failure. Please contact KX Support for help with recovery.
This issue is characterized by a log statement from the Storage Manager as follows: "Unexpected condition: EOXa watermark date YYYY.MM.DD is less than HDB stream date YYYY.MM.DD, setting it to match HDB stream date". The IDB may also start reporting "No such file or directory" on ordinal partitions.
Third-party dependencies
kdb Insights Enterprise 1.4.1 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.4.0 release of the standalone infrastructure installation scripts.
Artifacts
| type | location | 
|---|---|
| Enterprise | insights-1.4.1.tgz | 
| Operator | kxi-operator-1.4.0.tgz | 
| CLI | kxicli-1.4.1-py3-none-any.whl | 
| C SDK | kxi-c-sdk 1.4.0 | 
| Java SDK | kxi-java-sdk 1.4.0 | 
| RT Bridge | rt-bridge 1.4.0 | 
| Infrastructure | kxi-terraform-1.4.0.tgz | 
Upgrade notes
Upgrading existing assemblies
With the adoption of NuRaft by the Reliable Transport (RT) service, if you are upgrading an existing assembly to version 1.4.0, you must delete the RT PVCs.
Causes duplicate data
Due to the change in the Raft implementation, duplicate data will occur with this upgrade procedure.
- Stop all external publishers to kdb Insights Enterprise
- Wait for all published messages to be available for querying from the database - this will reduce (but not eliminate) the amount of duplicate data
- 
Backup any assemblies that may be running $ kxi assembly backup --filepath assembly-state-file.yaml Persisted assembly definitions for ['dfx-assembly', 'iot-assembly'] to assembly-state-file.yaml
- 
Teardown assemblies named in the output of the backup command $ kxi assembly teardown --name dfx-assembly --wait --use-kubeconfig Tearing down assembly dfx-assembly Are you sure you want to teardown dfx-assembly [y/N]: y Waiting for assembly to be torn down [------------------------------------] 0% $ kxi assembly teardown --name iot-assembly --wait --use-kubeconfig Tearing down assembly iot-assembly Are you sure you want to teardown iot-assembly [y/N]: y Waiting for assembly to be torn down [------------------------------------] 0%
- 
Delete the RT PVCs kubectl get pvc -n <namespace> | grep sequencer-store | awk '{ print $ 1 }' | xargs kubectl delete pvc -n <namespace>
- 
Carry out the upgrade 
- 
Restore assemblies kxi assembly deploy --filepath assembly-state-file.yaml --use-kubeconfig
User import
The initUser will be automatically imported on initial install but not on upgrade. This prevents the initUser password from being reset on upgrade. 
A new value has been added to allow you to change this behavior from the default.
keycloak:
  importUsers: false
Default password policy
The default password policy has been updated to include the following rule:
- Not one of the previous 24 passwords
If you are upgrading from an earlier version and set importUsers: true, the password for initUser must be updated to a new, valid password in the values file before upgrade.
Default Keycloak Credentials
As of 1.3.0 the Keycloak initUser and initClient credentials are no longer defaulted within the kdb Insights values.yaml. See here for more details.
Downgrading to earlier versions
Downgrading to earlier versions was previously supported by executing kxi install upgrade. This is no longer supported. To install an earlier version, execute the rollback steps.
Schema Configuration Changes
The field updTsCol is no longer used, and has been removed from the Schema Settings screen. It should be removed from any separately maintained assembly YAML, or configuration made in the Schema Code View screen. 
Known Issues
- 
On startup of pods, the following error might be observed after approximately three minutes of a pod starting up no acct for 3x period, exiting. This stems from a temporary startup job not shutting down correctly. It is independent from the main processes and does not indicate any application fault.
- 
On initial startup of kdb Insights Enterprise, there may be some noise printed in the logs while the system initializes unable to flush accounting logs. This relates to the capturing of consumption-based license logs and is thrown while all pods get into a running state. It does not indicate any fault in the application and all data should be flushed correctly after a short period.
- 
If end-of-day processing is interrupted and remains incomplete until the next EOD period, this prevents further EODs from completing and requires manual recovery. 
- 
Adding a sort attribute to memory or disk is currently not supported. Changing the attribute to be sorted will not apply the attribute and will error for data on disk. 
- 
Schema changes will fail when attempting to remove all symbol columns from a schema that previously had any. 
- 
Historical object storage tiers cannot be added using the UI due to a validation issue. These tiers can still be configured using assembly files submitted using the KXI CLI. 
When upgrading, the kdb Insights CLI does not wait until an assembly is fully operative before returning control. There is, therefore, a delay between the kdb Insights CLI returning control and the assembly being ready. If, for any reason, the assembly cannot start, you will not be notified.
- 
If the Resource Coordinator (RC) times out a request on a dequeue, the displayed message "Unknown reason" should be interpreted as "Timed out before we were able to dequeue". 
- 
If two processes have the same host and port, then the second one to register will overwrite the first, meaning the first will be invisible to the RC, and consequently never receive any requests. 
- 
When entering a query via the UI, Start and End Date fields are always required. To query against a splayed table or reference data, dummy dates must be entered. 
- 
When writing Python code in the scratchpad, if you type from kxi import sp, it will automatically auto-correct tofrom kxi import super. The workaround for this issue is as follows:- Accept the auto-correct
- Add a new line to the scratchpad
- Go back up and edit superback tosp
- Press the down arrow to go to the next line
 
- If in the Import Wizard, Next is clicked, no error will be thrown, which is invalid. At least one file needs to be present.
The kxi-controller will periodically log errors when an assembly has been deployed from the kdb Insights CLI. These errors can be safely ignored.
"[] Failed to compare saved assembly  to deployed version, error: type"
- 
Please ensure all pipelines have different names. Two pipelines with the same name may not be deploy correctly. 
- 
Any object storage reader nodes in pipelines created in the UI prior to 1.4.0 may need to be edited after the upgrade, as the file path may be split across several path inputs on the properties tab. To remedy, delete the path fields and enter the correct path into the reader. 
- 
If a reader node is added to a pipeline that invokes .qsp.read.fromFileusing chunking, then compilation fails.
When defining getData aggregations in a View configuration, a semi-colon separated list must be passed in the form of colAlias;aggFn;col. Symbols lists are currently not supported. 
The default CPU resources for PostgreSQL are too low and result in CPU throttling. The CPU resource can be updated by setting the below in your installation configuration values.yaml. 
keycloak:
  postgresql:
    primary:
      resources:
        limits:
          cpu: 2000m
        requests:
          cpu: 50m
1.4.0
Release for kdb Insights Enterprise.
Release Date
2023-03-03
New Features
Introducing Pythonic pipeline development in the UI, dynamic logging notifications providing direct access to root cause of underlying issues, an enhanced user experience for database configuration and additional security enhancements.
[NEW] Pipelines
- 
You can now use Python in the pipeline builder in the UI to perform aggregations and analytics. 
- 
Ingest large batches of data directly into the historical database has been moved out of beta. - Use fewer resources. Memory and disk resources greatly reduced during ingest.
- Select the Write Direct to HDBfield in the Database Writer in the UI, or use the q and Python APIs.
 
[NEW] User Interface
- 
Improvements to the observability user experience with two new icons in top right hand-side of the UI banner: - 
A notification icon shows a count of new log messages. This ensures you are notified of any new error messages wherever you are in the UI. You can also click on the icon to show more details of the message, these are displayed in the right-hand third of the screen. 
- 
A settings icon enables you to update the application logging level for future log records written by the kdb Insights Enterprise components. 
 
- 
- 
You can now share the URL of a View by selecting the view on the left-hand toolbar, right-clicking and choosing the new Sharebutton. This URL just shares the content of the View and not the toolbars (e.g. it does not show the left-hand toolbar or the Design/Preview panel at the top).
[NEW] Databases
A new version of our Database Configuration page is now available, under a beta flag, that provides an enhanced user experience. It can be toggled on and off from the Settings option in the main toolbar. We recommend that you use the existing Database Configuration age for all running databases, but please try the new user interface out and give us your feedback.
[NEW] Packages
The user interface now allows you to configure which Packages and their associated Custom APIs are used within individual databases, this had previously only been possible through kdb CLI deployments.
[NEW] Security Improvements
- Keycloak has been updated to version 19. This impacts the following:- The Keycloak Admin console has been changed
- Logout screen provides a redirection to the login page
 
Improvements
Keycloak realm
In this release, the handling of the Keycloak realm has been improved. This realm contains the role definitions, users and clients. Previously the realm was not being imported by default on install. The role definitions will always be imported as part of an install or upgrade now. The users and clients will only be imported by default on install (kxi install), and not on upgrade.
To make changes to the initClient and initUser on upgrade, you will need to tell the application to import them using the setting below.
keycloak:
  importUsers: true
Reliable Transport
The kdb Insights Enterprise transport layer has adopted a version of Raft called NuRaft. This improves the fault tolerance and performance of kdb Insights Enterprise. NuRaft is an open source version of Raft. Migrating to NuRaft also provides kdb Insights Enterprise with additional capabilities for future enhancements to Reliable Transport.
Third-party dependencies
kdb Insights Enterprise 1.4.0 standalone install supports the following versions of third-party dependencies:
These versions are used in the 1.4.0 release of the standalone infrastructure installation scripts .
Artifacts
| type | location | 
|---|---|
| Enterprise | insights-1.4.0.tgz | 
| Operator | kxi-operator-1.4.0.tgz | 
| CLI | kxicli-1.4.0-py3-none-any.whl | 
| C SDK | kxi-c-sdk 1.4.0 | 
| Java SDK | kxi-java-sdk 1.4.0 | 
| RT Bridge | rt-bridge 1.4.0 | 
| Infrastructure | kxi-terraform-1.4.0.tgz | 
Upgrade notes
Upgrading existing assemblies
With the adoption of NuRaft by the Reliable Transport (RT) service, if you are upgrading an existing assembly to version 1.4.0, you must delete the RT PVCs.
Causes duplicate data
Due to the change in the Raft implementation, duplicate data will occur with this upgrade procedure.
- Stop all external publishers to kdb Insights Enterprise
- Wait for all published messages to be available for querying from the database - this will reduce (but not eliminate) the amount of duplicate data
- 
Backup any assemblies that may be running $ kxi assembly backup --filepath assembly-state-file.yaml Persisted assembly definitions for ['dfx-assembly', 'iot-assembly'] to assembly-state-file.yaml
- 
Teardown assemblies named in the output of the backup command $ kxi assembly teardown --name dfx-assembly --wait --use-kubeconfig Tearing down assembly dfx-assembly Are you sure you want to teardown dfx-assembly [y/N]: y Waiting for assembly to be torn down [------------------------------------] 0% $ kxi assembly teardown --name iot-assembly --wait --use-kubeconfig Tearing down assembly iot-assembly Are you sure you want to teardown iot-assembly [y/N]: y Waiting for assembly to be torn down [------------------------------------] 0%
- 
Delete the RT PVCs kubectl get pvc -n <namespace> | grep sequencer-store | awk '{ print $ 1 }' | xargs kubectl delete pvc -n <namespace>
- 
Carry out the upgrade 
- 
Restore assemblies kxi assembly deploy --filepath assembly-state-file.yaml --use-kubeconfig
User import
The initUser will be automatically imported on initial install but not on upgrade. This prevents the initUser password from being reset on upgrade. 
A new value has been added to allow you to change this behavior from the default.
keycloak:
  importUsers: false
Default password policy
The default password policy has been updated to include the following rule
- Not one of the previous 24 passwords
If you are upgrading from an earlier version and set importUsers: true, the password for initUser must be updated to a new, valid password in the values file before upgrade.
Default Keycloak Credentials
As of 1.3.0 the Keycloak initUser and initClient credentials are no longer defaulted within the kdb Insights values.yaml. See here for more details.
Downgrading to earlier versions
Downgrading to earlier versions was previously supported by executing kxi install upgrade. This is no longer supported. To install an earlier version, execute the rollback steps .
Schema Configuration Changes
The field updTsCol is no longer used, and has been removed from the Schema Settings screen. It should be removed from any separately maintained assembly YAML, or configuration made in the Schema Code View screen. 
Supported Python versions in the CLI
Support for Python 3.7 has been dropped in the CLI.
Known Issues
- 
On startup of pods, the following error might be observed once roughly after three minutes of a pod starting up no acct for 3x period, exiting. This stems from a temporary startup job not shutting down correctly. It is independent from the main processes and does not indicate any application fault.
- 
On initial startup of kdb Insights Enterprise, there may be some noise printed in the logs while the system initializes unable to flush accounting logs. This relates to the capturing of consumption-based license logs and is thrown while all pods get into a running state. It does not indicate any fault in the application and all data should be flushed correctly after a short period.
- 
If end-of-day processing is interrupted and remains incomplete until the next EOD period, this prevents further EODs from completing and requires manual recovery. 
- 
Adding a sort attribute to memory or disk is currently not supported. Changing the attribute to be sorted will not apply the attribute and will error for data on disk. 
- 
Schema changes will fail when attempting to remove all symbol columns from a schema that previously had any. 
- 
Historical object storage tiers cannot be added using the UI due to a validation issue. These tiers can still be configured using assembly files submitted using the KXI CLI. 
When upgrading, the kdb Insights CLI does not wait until an assembly is fully operative before returning control. There is, therefore, a delay between the kdb Insights CLI returning control and the assembly being ready. If, for any reason, the assembly cannot start, you will not be notified.
- 
If the Resource Coordinator (RC) times out a request on a dequeue, the displayed message "Unknown reason" should be interpreted as "Timed out before we were able to dequeue". 
- 
If two processes have the same host and port, then the second one to register will overwrite the first, meaning the first will be invisible to the RC, and consequently never receive any requests. 
- 
When entering a query via the UI, Start and End Date fields are always required. To query against a splayed table or reference data, dummy dates must be entered. 
- 
When writing Python code in the scratchpad, if you type from kxi import sp, it will automatically auto-correct tofrom kxi import super. The workaround for this issue is as follows:- Accept the auto-correct
- Add a new line to the scratchpad
- Go back up and edit superback tosp
- Press the down arrow to go to the next line
 
- If in the Import Wizard, Next is clicked, no error will be thrown, which is invalid. At least one file needs to be present.
The kxi-controller will periodically log errors when an assembly has been deployed from the kdb Insights CLI. These errors can be safely ignored.
"[] Failed to compare saved assembly  to deployed version, error: type"
- 
When creating a pipeline the user interface does not stop you from creating it with the same name as an existing pipeline, however two pipelines with the same name may not be deploy correctly. Please ensure all pipelines have different names. 
- 
Any object storage reader nodes in pipelines created in the UI prior to 1.4.0 may need to be edited after the upgrade, as the file path may be split across several path inputs on the properties tab. To remedy, delete the path fields and enter the correct path into the reader. 
- 
If a reader node is added to a pipeline that invokes .qsp.read.fromFileusing chunking, then compilation fails.
When defining getData aggregations in a View configuration, a semi-colon separated list must be passed in the form of colAlias;aggFn;col. Symbols lists are currently not supported. 
The default CPU resources for PostgreSQL are too low and result in CPU throttling. The CPU resource can be updated by setting the below in your installation configuration values.yaml. 
keycloak:
  postgresql:
    primary:
      resources:
        limits:
          cpu: 2000m
        requests:
          cpu: 50m
1.3.4
Release for kdb Insights Enterprise.
Release Date
2023-03-13
Fixes
[FIX] As of 1.3.3, if the Storage Manager falls behind on EODs for more than a full day, IDB links could be written incorrectly when late data was present. If this issue is encountered, manual data changes are required to recover the database including backup of the stream logs from the date of the failure. Please contact KX Support for help with recovery.
This issue is characterized by a log statement from the Storage Manager as follows: "Unexpected condition: EOXa watermark date YYYY.MM.DD is less than HDB stream date YYYY.MM.DD, setting it to match HDB stream date". The IDB may also start reporting "No such file or directory" on ordinal partitions.
Artifacts
| type | location | 
|---|---|
| Infrastructure | kxi-terraform-1.3.1.tgz | 
| kdb Insights Enterprise | insights-1.3.4.tgz | 
| Operator | kxi-operator-1.3.1.tgz | 
| CLI | kxicli-1.3.1-py3-none-any.whl | 
| ODBC Driver | kodbc 1.3.0 | 
| Java SDK | java-sdk 1.3.0 | 
Batch Ingest Known Issues
- In the unlikely event of two batch ingests being done within an end of interval (EOI) event (for example, a 10 min window) a one hour delay would occur for the subsequent ingest, but there would not be any data loss, just a delay.
- If the Storage Manager (SM) crashes during a batch ingest, the ingest will fail. On SM recovery, it will not try again and must be restarted, but no clean-up is required.
Upgrade Notes
- When upgrading kdb Insights Enterprise, assemblies deployed from the UI in earlier versions will be restarted but will not be automatically upgraded. To upgrade these assemblies, please restart them from the UI post-upgrade.
Resource Coordinator
- 
If the Resource Coordinator (RC) times out a request on a dequeue, the displayed message "Unknown reason" can be misleading in the timeout message. It should be interpreted as "Timed out before we were able to dequeue". 
- 
If two processes have the same host and port, then the second one to register will overwrite the first, meaning the first will be invisible to the RC, and consequently never receive any requests. 
Python Scratchpad for Queries
- If the script consists of multiple statements, the console does not print the output of the last evaluation, and instead it only displays the expression before it is evaluated.
S3 Import Wizard
- If you select the source, S3, and click Next, no error will be thrown, which is invalid. At least one file needs to be present.
Keycloak Config CLI
We recommend that you enable the Keycloak Config CLI when upgrading to ensure that any realm changes are imported.
This can be enabled by setting:
keycloak:
  keycloakConfigCli:
    enabled: true
in your values file if you are deploying Keycloak as a part of kdb Insights Enterprise.
If you use a shared Keycloak instance, this can be enabled by setting:
keycloak-config-cli:
  enabled: true
in your values file.
Keycloak initUser password reset
Enabling the Keycloak Config CLI will cause the initUser's password to be reset. It will be reset to the value of the keycloak.initUser.auth key.
Default Password Policy
As of 1.3.0 a default password policy is now being enforced.
The default policy is:
- At least one uppercase letter
- At least one lowercase letter
- At least one symbol
- At least one number
- Minimum length of 14 characters
Information about how the policy can be configured and adjusted can be found here.
If you are upgrading from an earlier version, and want the default password policy to be applied, the keycloak config CLI must be enabled.
Keycloak initUser
The Keycloak initUser password must satisfy the policy if it is enabled.
Default Keycloak Credentials
As of 1.3.0 the Keycloak initUser and initClient credentials are no longer defaulted within the Insights values.yaml. These defaults would previously create the demoinsights user and test-publisher client on a new deployment of kdb Insights Enterprise.
If you currently set initUser.enabled=true or initClient.enabled=true within your own values.yaml, you may receive the following errors at deploy time:
Keycloak initUser has been enabled
The following fields are required to be set
 .Values.keycloak.initUser.name
 .Values.keycloak.initUser.auth
Keycloak initClient has been enabled
The following fields are required to be set
 .Values.keycloak.initClient.clientId
 .Values.keycloak.initClient.clientSecret
If enabling the initUser you are required to set:
keycloak:
  initUser:
    enabled: true
    name: "initUsername"
    auth: "initUserPassword"
Where a Keycloak passwordPolicy has been enabled, initUser.auth must satisfy the policy requirements.
If enabling the initClient you are required to set:
keycloak:
  initClient:
    enabled: true
    clientId: "initClientID"
    clientSecret: "initClientSecret"
Internal Network LoadBalancers
As of 1.3.0 by default annotations are added to Service resources of type LoadBalancer.
These annotations restrict access to the LoadBalancers from outside the cluster.
To disable these annotations and permit access from outside the cluster, you must set:
global:
    service:
        useInternalLBAnnotations: false
For additional configuration options see here.
Assembly blockSize Changed
The blockSize configuration within an assembly spec.tables.<table>.blockSize has been updated with the following semantics:
- if unset: all data received in an interval will be buffered in RAM within SM, written down at the end of the interval- this has the highest performance, but has no RAM limit on received data
 
- if set: once a table's rows surpass the configured limit, buffered data will be flushed to disk to release RAM- the smaller this number is set to, the worse ingest performance but stronger RAM limits; this should be balanced
 
Previously, blockSize was ignored, always buffering all data in memory. To reproduce previous behavior, unset the blockSize field in the assembly for each table.
Known Issues
- 
On startup of pods, the following error might be observed after approximately three minutes of a pod starting up no acct for 3x period, exiting. This stems from a temporary startup job not shutting down correctly. It is independent from the main processes and does not indicate any application fault.
- 
On initial startup of kdb Insights Enterprise, there may be some noise printed in the logs while the system initializes unable to flush accounting logs. This relates to the capturing of consumption-based license logs and is thrown while all pods get into a running state. It does not indicate any fault in the application and all data should be flushed correctly after a short period.
- Setting SM replicas (defining sizegreater than 1) in assembly YAML will cause writedown/storage and query problems. Thesizeparameter for SM should always be set to 1.
sm:
  size: 1
- If the cluster and/or resource configuration for the kxi-discovery-serviceis limited, a race condition can occur at startup causing the Discovery Service to be in a crash/restart loop. This can be solved by giving the Discovery Service additional CPU and memory resources; full details on setting custom resources can be found here.
- Upon upgrade or downgrade, the API Gateway containers may enter a CrashLoopBackOff state. Resources can be reapplied by performing a 'rollback' to the upgraded version. Get the upgraded version by looking at the output from:
helm ls
'Rollback' (re-apply resources) to the upgraded version:
helm rollback <release name> <current revision>
There are two known issues with the UI logout.
- After performing a logout action, you will not be redirected back to the login screen.
- If you were logged out due to inactivity, you might see a "Logout failed" error.
In both of these cases, the logout has been successful and the user can re-login by navigating back to the main page, i.e. https://${INSIGHTS_HOSTNAME}.
1.3.3
Release for kdb Insights Enterprise.
Release date
2023-01-17
New features
Functionality for improved ingestion, efficiency and reduction of resources. Take advantage of an IDE to develop your databases, pipelines and query interfaces.
[NEW] Improved ingestion
- 
[Beta] Ingest large batches of data directly into the historical database: - Use fewer resources. Memory and disk resources greatly reduced during ingest.
- Select the Direct Writingfield in the Database Writer in the UI, or use the q and Python APIs.
 See details here for known issues. 
[NEW] Writing data to Amazon S3
- You can now write data to Amazon S3 by either:- Selecting the Amazon S3 Writer node in the UI.
- Using the q and Python APIs.
 
[NEW] Improved IDE capabilities
- 
Build YAML files and upload them using kdb Insights CLI: - Speed up development workflow, improve productivity.
- Access to the Kubernetes control plane is no longer needed. This is now handled for you by the CLI.
- Assembly management using CLI.
 
- 
If you have access to KX Analyst, you can use it to develop functions. You can now: - Enjoy a rich IDE development environment with syntax highlighting for YAML files.
- Query kdb Insights Enterprise data using REST API or query interface.
- Upload using the CLI or as part of CI/CD pipeline.
- Build a complete SDLC that harnesses the flexibility of KX Analyst against kdb Insights Enterprise data.
 Note Contact your KX Sales representative if you are interested in using KX Analyst. In future releases, additional IDEs will become available, including VS Code and Jupyter Notebooks. 
Improvements
[NEW] Reliable Transport
- Reliable Transport's logging default level for the sequencer and merger has been changed from DEBUG to INFO.
Fixes
 [FIX] Following a hard reset of the Reliable Transport (RT), the log files in the out folder are truncated rather than deleted. This means that the replicated log files for all subscribers to the RT instance will be garbage collected once the RT archiver starts after the reset. This prevents a hard reset from causing subscriber PVCs to fill up due to old/corrupt log files remaining. 
Artifacts
| type | location | 
|---|---|
| Infrastructure | kxi-terraform-1.3.1.tgz | 
| kdb Insights Enterprise | insights-1.3.3.tgz | 
| Operator | kxi-operator-1.3.1.tgz | 
| CLI | kxicli-1.3.1-py3-none-any.whl | 
| ODBC Driver | kodbc 1.3.0 | 
| Java SDK | java-sdk 1.3.0 | 
| RT Bridge | rt-bridge-1.4.0-install.sh | 
Known Issues
Batch ingest
- In the unlikely event of two batch ingests being done within an end of interval (EOI) event (for example, a 10 min window) a one hour delay would occur for the subsequent ingest, but there would not be any data loss, just a delay.
- If the Storage Manager (SM) crashes during a batch ingest, the ingest will fail. On SM recovery, it will not try again and must be restarted, but no clean-up is required.
Discovery Service
- If the cluster and/or resource configuration for the kxi-discovery-serviceis limited, a race condition can occur at startup causing the Discovery Service to be in a crash/restart loop. This can be solved by giving the Discovery Service additional CPU and memory resources; full details on setting custom resources can be found here.
Upgrade Notes
Upgrading assemblies
When upgrading kdb Insights Enterprise, assemblies deployed from the UI in earlier versions will be restarted but will not be automatically upgraded. To upgrade these assemblies, please restart them from the UI post-upgrade.
Terraform Script
Note the version. GKE cluster cannot be deployed using a 1.3.0 version of the script; a 1.3.* version of the client scripts is needed to use Kubernetes v1.22 on GKE.
Keycloak Config CLI
It is recommended to enable the Keycloak Config CLI when upgrading to ensure that any realm changes are imported.
This can be enabled by setting:
keycloak:
  keycloakConfigCli:
    enabled: true
in your values file if you are deploying Keycloak as a part of kdb Insights Enterprise.
If you use a shared Keycloak instance, this can be enabled by setting:
keycloak-config-cli:
  enabled: true
in your values file.
Keycloak initUser password reset
Enabling the Keycloak Config CLI will cause the initUser's password to be reset. It will be reset to the value of the keycloak.initUser.auth key.
Default password policy
As of 1.3.0 a default password policy is now being enforced.
The default policy is:
- At least one uppercase letter
- At least one lowercase letter
- At least one symbol
- At least one number
- Minimum length of 14 characters or greater
Information about how the policy can be configured and adjusted can be found here.
If you are upgrading from an earlier version, and want the default password policy to be applied, the Keycloak config CLI must be enabled.
Keycloak initUser
The Keycloak initUser password must satisfy the policy if it is enabled.
Default Keycloak Credentials
As of 1.3.0 the Keycloak initUser and initClient credentials are no longer defaulted within the kdb Insights values.yaml. These defaults would previously create the demoinsights user and test-publisher client on a new deployment of kdb Insights Enterprise.
If you currently set initUser.enabled=true or initClient.enabled=true within your values.yaml, you may receive the following errors at deploy time:
Keycloak initUser has been enabled
The following fields are required to be set
 .Values.keycloak.initUser.name
 .Values.keycloak.initUser.auth
Keycloak initClient has been enabled
The following fields are required to be set
 .Values.keycloak.initClient.clientId
 .Values.keycloak.initClient.clientSecret
If enabling the initUser you are required to set:
keycloak:
  initUser:
    enabled: true
    name: "initUsername"
    auth: "initUserPassword"
Where Keycloak passwordPolicy has been enabled, initUser.auth must satisfy the policy requirements.
If enabling the initClient you are required to set:
keycloak:
  initClient:
    enabled: true
    clientId: "initClientID"
    clientSecret: "initClientSecret"
Internal Network LoadBalancers
As of 1.3.0 by default annotations are added to Service resources of type LoadBalancer.
These annotations restrict access to the LoadBalancers from outside the cluster.
To disable these annotations and permit access from outside the cluster, set:
global:
    service:
        useInternalLBAnnotations: false
For additional configuration options see here.
Assembly blockSize changed
The blockSize configuration within an assembly spec.tables.<table>.blockSize has been updated with the following semantics:
- If unset: all data received in an interval will be buffered in RAM within SM, written down at the end of the interval. This has the highest performance, but has no RAM limit on received data
- If set: once a table's rows surpass the configured limit, buffered data will be flushed to disk to release RAM. The smaller this number is set to, the worse ingest performance but stronger RAM limits - this should be balanced
Previously, blockSize was ignored, always buffering all data in memory. To reproduce previous behavior, unset the blockSize field in the assembly for each table.
Known Issues
- 
On startup of pods, the following error might be observed once roughly after three minutes of a pod starting up no acct for 3x period, exiting. This stems from a temporary startup job not shutting down correctly. It is independent from the main processes and does not indicate any application fault.
- 
On initial startup of kdb Insights Enterprise, there may be some noise printed in the logs while the system initializes unable to flush accounting logs. This relates to the capturing of consumption-based license logs and is thrown while all pods get into a running state. It does not indicate any fault in the application and all data should be flushed correctly after a short period.
- Setting SM replicas (defining sizegreater than 1) in assembly YAML will cause writedown/storage and query problems. Thesizeparameter for SM should always be set to 1.
sm:
  size: 1
- Upon upgrade or downgrade, the API Gateway containers may enter a CrashLoopBackOff state. Resources can be reapplied by performing a 'rollback' to the upgraded version. Get the upgraded version by looking at the output from:
helm ls
'Rollback' (re-apply resources) to the upgraded version:
helm rollback <release name> <current revision>
There are two known issues with the UI logout.
- After performing a logout action, the user will not be redirected back to the login screen.
- In the case a user was logged out due to inactivity, a "Logout failed" error might be observed.
In both of these cases, the logout has been successful and the user can re-login by navigating back to the main page, i.e. https://${INSIGHTS_HOSTNAME}
- 
If the Resource Coordinator (RC) times out a request on a dequeue, the displayed message "Unknown reason" should be interpreted as "Timed out before we were able to dequeue". 
- 
If two processes have the same host and port, then the second one to register will overwrite the first, meaning the first will be invisible to the RC, and consequently never receive any requests. 
If the script consists of multiple statements, the console does not print the output of the last evaluation, and instead it only displays the expression before it is evaluated.
If S3 is selected as the source and Next is clicked, no error will be thrown, which is invalid. At least one file needs to be present.
1.3.2
Release for kdb Insights Enterprise.
Release Date
2022-12-05
New Features
[NEW] Pipelines
- 
[Beta] Compressed files (GZIP) can now be decoded using the q and Python APIs. 
- 
Multiple file paths can be added to a cloud storage Reader node using the +button in the UI, or via the q and Python APIs.
- 
Wildcard support using *is now available when using a single file path with the Amazon S3 Reader.
- 
CSV encoding is now available, using a new node in the UI, or via the q and Python APIs. 
- 
It is now possible to write to Amazon S3 buckets, using a new node in the UI, or via the q and Python APIs. 
- 
Pipeline lifecycle events can be subscribed to via the q API. This can be used, for example, to invoke a callback once files have been processed by a pipeline. 
Improvements
- Queries will no longer time out after 60 seconds at the gateway. Longer timeouts can be configured in getDataAPI calls using thetimeoutheader option.
Fixes
[FIX] Query
- An issue where DAPs could enter low-memory mode earlier than they should has been resolved.
Artifacts
| type | location | 
|---|---|
| Infrastructure | kxi-terraform-1.3.0.tgz | 
| Platform | insights-1.3.2.tgz | 
| Operator | kxi-operator-1.3.1.tgz | 
| CLI | kxicli-1.3.0-py3-none-any.whl | 
| ODBC Driver | kodbc 1.3.0 | 
| Java SDK | java-sdk 1.3.0 | 
Upgrade notes
Upgrading assemblies
When upgrading kdb Insights Enterprise, assemblies deployed from the UI in earlier versions will be restarted but will not be automatically upgraded. To upgrade these assemblies, please restart them from the UI post-upgrade.
Keycloak Config CLI
It is recommended to enable the Keycloak Config CLI when upgrading to ensure that any realm changes are imported.
This can be enabled by setting:
keycloak:
  keycloakConfigCli:
    enabled: true
in your values file if you are deploying Keycloak as a part of kdb Insights Enterprise.
If you use a shared Keycloak instance, this can be enabled by setting:
keycloak-config-cli:
  enabled: true
in your values file.
Keycloak initUser password reset
Enabling the Keycloak Config CLI will cause the initUser's password to be reset. It will be reset to the value of the keycloak.initUser.auth key.
Default password policy
As of 1.3.0 a default password policy is now being enforced.
The default policy is:
- At least one uppercase letter
- At least one lowercase letter
- At least one symbol
- At least one number
- Minimum length of 14 characters or greater
Information about how the policy can be configured and adjusted can be found here.
If you are upgrading from an earlier version, and want the default password policy to be applied, the keycloak config CLI must be enabled.
Keycloak initUser
The Keycloak initUser password must satisfy the policy if it is enabled
Default Keycloak Credentials
As of 1.3.0 the Keycloak initUser and initClient credentials are no longer defaulted within kdb Insights Enterprise values.yaml. These defaults would previously create the demoinsights user and test-publisher client on a new deployment of kdb Insights Enterprise.
Users who currently set initUser.enabled=true or initClient.enabled=true within their own values.yaml may receive the following errors at deploy time:
Keycloak initUser has been enabled
The following fields are required to be set
 .Values.keycloak.initUser.name
 .Values.keycloak.initUser.auth
Keycloak initClient has been enabled
The following fields are required to be set
 .Values.keycloak.initClient.clientId
 .Values.keycloak.initClient.clientSecret
If enabling the initUser you are required to set:
keycloak:
  initUser:
    enabled: true
    name: "initUsername"
    auth: "initUserPassword"
Where keycloak passwordPolicy has been enabled, initUser.auth must satisfy the policy requirements.
If enabling the initClient you are required to set:
keycloak:
  initClient:
    enabled: true
    clientId: "initClientID"
    clientSecret: "initClientSecret"
Internal Network LoadBalancers
As of 1.3.0 by default annotations are added to Service resources of type LoadBalancer.
These annotations restrict access to the LoadBalancers from outside the cluster.
To disable these annotations and permit access from outside the cluster, the user is required to set:
global:
    service:
        useInternalLBAnnotations: false
For additional configuration options see here.
Assembly blockSize changed
The blockSize configuration within an assembly spec.tables.<table>.blockSize has been updated with the following semantics:
- if unset: all data received in an interval will be buffered in RAM within SM, written down at the end of the interval- this has the highest performance, but has no RAM limit on received data
 
- if set: once a table's rows surpass the configured limit, buffered data will be flushed to disk to release RAM- the smaller this number is set to, the worse ingest performance but stronger RAM limits - this should be balanced
 
Previously, blockSize was ignored, always buffering all data in memory. To reproduce previous behavior, unset the blockSize field in the assembly for each table.
Known Issues
- 
On startup of pods, the following error might be observed once roughly after three minutes of a pod starting up no acct for 3x period, exiting. This stems from a temporary startup job not shutting down correctly. It is independent from the main processes and does not indicate any application fault.
- 
On initial startup of kdb Insights Enterprise, there may be some noise printed in the logs while the system initializes unable to flush accounting logs. This relates to the capturing of consumption-based license logs and is thrown while all pods get into a running state. It does not indicate any fault in the application and all data should be flushed correctly after a short period.
- Setting SM replicas (defining sizegreater than 1) in assembly YAML will cause writedown/storage and query problems. Thesizeparameter for SM should always be set to 1.
sm:
  size: 1
- If the cluster and/or resource configuration for the kxi-discovery-serviceis limited, a race condition can occur at startup causing the Discovery Service to be in a crash/restart loop. This can be solved by giving the Discovery Service additional CPU and memory resources; full details on setting custom resources can be found here.
- Upon upgrade or downgrade, the API Gateway containers may enter a CrashLoopBackOff state. Resources can be reapplied by performing a 'rollback' to the upgraded version. Get the upgraded version by looking at the output from:
helm ls
'Rollback' (re-apply resources) to the upgraded version:
helm rollback <release name> <current revision>
There are two known issues with the UI logout.
- After performing a logout action, the user will not be redirected back to the login screen.
- In the case a user was logged out due to inactivity, a "Logout failed" error might be observed
In both of these cases, the logout has been successful and the user can re-login by navigating back to the main page, i.e. https://${INSIGHTS_HOSTNAME}
1.3.1
Release for kdb Insights Enterprise.
Release Date
2022-11-23
Security
[FIX] kdb Insights Enterprise 1.3.1 contains security updates for a number of critical CVEs
Streams and Reliable Transport
[FIX] An issue which could cause RT archiving to fail has been fixed.
Artifacts
| type | location | 
|---|---|
| Infrastructure | kxi-terraform-1.3.0.tgz | 
| Platform | insights-1.3.1.tgz | 
| Operator | kxi-operator-1.3.1.tgz | 
| CLI | kxicli-1.3.0-py3-none-any.whl | 
| ODBC Driver | kodbc 1.3.0 | 
| Java SDK | java-sdk 1.3.0 | 
Upgrade notes
Upgrading assemblies
When upgrading kdb Insights Enterprise, assemblies deployed from the UI in earlier versions will be restarted but will not be automatically upgraded. To upgrade these assemblies, please restart them from the UI post-upgrade.
Keycloak Config CLI
It is recommended to enable the Keycloak Config CLI when upgrading to ensure that any realm changes are imported.
This can be enabled by setting:
keycloak:
  keycloakConfigCli:
    enabled: true
in your values file if you are deploying Keycloak as a part of kdb Insights Enterprise.
If you use a shared Keycloak instance, this can be enabled by setting:
keycloak-config-cli:
  enabled: true
in your values file.
Keycloak initUser password reset
Enabling the Keycloak Config CLI will cause the initUser's password to be reset. It will be reset to the value of the keycloak.initUser.auth key.
Default password policy
As of 1.3.0 a default password policy is now being enforced.
The default policy is:
- At least one uppercase letter
- At least one lowercase letter
- At least one symbol
- At least one number
- Minimum length of 14 characters or greater
Information about how the policy can be configured and adjusted can be found here
If you are upgrading from an earlier version, and want the default password policy to be applied, the keycloak config CLI must be enabled.
Keycloak initUser
The Keycloak initUser password must satisfy the policy if it is enabled
Default Keycloak Credentials
As of 1.3.0 the Keycloak initUser and initClient credentials are no longer defaulted within the kdb Insights Enterprise values.yaml. These defaults would previously create the demoinsights user and test-publisher client on a new deployment of kdb Insights Enterprise.
Users who currently set initUser.enabled=true or initClient.enabled=true within their own values.yaml may receive the following errors at deploy time:
Keycloak initUser has been enabled
The following fields are required to be set
 .Values.keycloak.initUser.name
 .Values.keycloak.initUser.auth
Keycloak initClient has been enabled
The following fields are required to be set
 .Values.keycloak.initClient.clientId
 .Values.keycloak.initClient.clientSecret
If enabling the initUser you are required to set:
keycloak:
  initUser:
    enabled: true
    name: "initUsername"
    auth: "initUserPassword"
Where keycloak passwordPolicy has been enabled, initUser.auth must satisfy the policy requirements.
If enabling the initClient you are required to set:
keycloak:
  initClient:
    enabled: true
    clientId: "initClientID"
    clientSecret: "initClientSecret"
Internal Network LoadBalancers
As of 1.3.0 by default annotations are added to Service resources of type LoadBalancer.
These annotations restrict access to the LoadBalancers from outside the cluster.
To disable these annotations and permit access from outside the cluster, the user is required to set:
global:
    service:
        useInternalLBAnnotations: false
For additional configuration options see here.
Assembly blockSize changed
The blockSize configuration within an assembly spec.tables.<table>.blockSize has been updated with the following semantics:
- if unset: all data received in an interval will be buffered in RAM within SM, written down at the end of the interval- this has the highest performance, but has no RAM limit on received data
 
- if set: once a table's rows surpass the configured limit, buffered data will be flushed to disk to release RAM- the smaller this number is set to, the worse ingest performance but stronger RAM limits - this should be balanced
 
Previously, blockSize was ignored, always buffering all data in memory. To reproduce previous behavior, unset the blockSize field in the assembly for each table.
Known Issues
- 
On startup of pods, the following error might be observed once roughly after three minutes of a pod starting up no acct for 3x period, exiting. This stems from a temporary startup job not shutting down correctly. It's independent from the main processes and doesn't indicate any application fault.
- 
On initial startup of kdb Insights Enterprise, there may be some noise printed in the logs while the system initializes unable to flush accounting logs. This relates to the capturing of consumption-based license logs and is thrown while all pods get into a running state. It does not indicate any fault in the application and all data should be flushed correctly after a short period.
- Setting SM replicas (defining sizegreater than 1) in assembly YAML will cause writedown/storage and query problems. Thesizeparameter for SM should always be set to 1.
sm:
  size: 1
- If the cluster and/or resource configuration for the kxi-discovery-serviceis limited, a race condition can occur at startup causing the Discovery Service to be in a crash/restart loop. This can be solved by giving the Discovery Service additional CPU and memory resources; full details on setting custom resources can be found here.
- Upon upgrade or downgrade, the API Gateway containers may enter a CrashLoopBackOff state. Resources can be reapplied by performing a 'rollback' to the upgraded version. Get the upgraded version by looking at the output from:
helm ls
'Rollback' (re-apply resources) to the upgraded version:
helm rollback <release name> <current revision>
There are two known issues with the UI logout.
- After performing a logout action, the user will not be redirected back to the login screen.
- In the case a user was logged out due to inactivity, a "Logout failed" error might be observed
In both of these cases, the logout has been successful and the user can re-login by navigating back to the main page, i.e. https://${INSIGHTS_HOSTNAME}
1.3.0
Release for kdb Insights Enterprise.
Release Date
2022-10-26
Features
[NEW] User Interface
- Items in the page tree have been renamed for clarity and consistency with the CLI.- Data is now known as Assemblies
- Explore is now known as Queries
- Reports is now known as Views
 
[NEW] Pipelines
- 
An "Auto" setting for Parse Strings in the Apply Schema node has been added. The column will be parsed if the input is textual (strings or bytes), but the output type is non-textual. 
- 
Data types are now visible for each column for Test Deploy previews. These can be used to validate the data types and the data shape of Transforms and Maps results. 
- 
Data types and column names are validated for Database writers as part of a test deploy. 
- 
Additional Reader validation has been introduced to pipelines, to ensure correctness of settings before deploying. 
- 
Test deploy previews can now show non-tabular data. 
- 
Previews are now available for Reader nodes, before data has been decoded. 
- 
The visibility of a Pipeline's state has been improved in the Overview tab. Warning and error counts can be clicked on to launch a diagnostics tab for that Pipeline. 
[NEW] Assemblies
- 
It is now possible to see assemblies created using kxi assembly createin the UI. Note that assemblies created and managed through the command-line are not editable via the UI.
- 
Additional logging has been added to the Storage Manager, to ease troubleshooting. 
- 
Schema configuration validation has been improved. 
[NEW] Install and Packages
- 
The kdb Insights Operator is no longer uninstalled by default by kxi install delete, the command line parameter--uninstall-operatormust now be used.
- 
Many values for kxi install setupcan now be passed via command line parameter, please see the CLI Reference for more detail.
- 
Improved support for rolling back to previous versions. Enter a previous version number using the upgrade command kxi install upgradeto roll back.
- 
The current kubectlcontext is now used as the default in all commands, instead of the namespace specified in thecli-configfile.
- 
kdb Insights Python modules for packaging and machine learning are no longer dependent on libc.musl, and can now be used for development on Windows and Mac.
- 
Custom user query APIs and Aggregation functions can be installed and initialized within Data Access Processes and Aggregators as outlined here. 
- 
Custom user query APIs and Aggregation functions can be installed and initialized within Data Access Processes and Aggregators as outlined here. 
[NEW] Observability
- Reliable Transport diagnostics are now available in diagnostics exports from the UI.
[NEW] Infrastructure
- The base image for most components has been moved to Rocky Linux.
Fixes
A large number of fixes have gone into kdb Insights Enterprise 1.3.0. Known issues which have been resolved, along with some other highlights, are listed below.
[FIX] Streams and Reliable Transport
- A hard reset can now be performed on Reliable Transport, to recover from stream corruption. Please contact KX Support for usage instructions.
[FIX] Pipelines
- 
Pipelines which have their data cleared when they're torn-down can now be re-deployed with the same name. Previously, this would cause RT sequence number problems, stopping data from flowing. 
- 
Persistent pop-up errors in the UI after resizing a Map node have been resolved. 
- 
.qsp.read.fromDatabasecan now be used in pipelines.
- 
Renaming a pipeline node no longer disconnects its edges. 
- 
Empty pipelines are no longer deployable. 
[FIX] User Interface
- Validation fixes so that date and time fields can be entered without use of the picker.
[FIX] Java SDK
- Occasional authentication failures when querying via Java SDK have been resolved. These would previously be seen more frequently on slower connections.
Artifacts
| type | location | 
|---|---|
| Infrastructure | kxi-terraform-1.3.0.tgz | 
| Platform | insights-1.3.0.tgz | 
| Operator | kxi-operator-1.3.0.tgz | 
| CLI | kxicli-1.3.0-py3-none-any.whl | 
| ODBC Driver | kodbc 1.3.0 | 
| Java SDK | java-sdk 1.3.0 | 
Upgrade notes
Upgrading assemblies
When upgrading kdb Insights Enterprise, assemblies deployed from the UI in earlier versions will be restarted but will not be automatically upgraded. To upgrade these assemblies, please restart them from the UI post-upgrade.
Keycloak Config CLI
It is recommended to enable the Keycloak Config CLI when upgrading to ensure that any realm changes are imported.
This can be enabled by setting:
keycloak:
  keycloakConfigCli:
    enabled: true
in your values file if you are deploying Keycloak as a part of KX Insights.
If you use a shared Keycloak instance, this can be enabled by setting:
keycloak-config-cli:
  enabled: true
in your values file.
Keycloak initUser password reset
Enabling the Keycloak Config CLI will cause the initUser's password to be reset. It will be reset to the value of the keycloak.initUser.auth key.
Default password policy
As of 1.3.0 a default password policy is now being enforced.
The default policy is:
- At least one uppercase letter
- At least one lowercase letter
- At least one symbol
- At least one number
- Minimum length of 14 characters or greater
Information about how the policy can be configured and adjusted can be found here.
If you are upgrading from an earlier version, and want the default password policy to be applied, the keycloak config CLI must be enabled.
Keycloak initUser
The Keycloak initUser password must satisfy the policy if it is enabled
Default Keycloak Credentials
As of 1.3.0 the Keycloak initUser and initClient credentials are no longer defaulted within the kdb Insights Enterprise values.yaml. These defaults would previously create the demoinsights user and test-publisher client on a new deployment of kdb Insights Enterprise.
Users who currently set initUser.enabled=true or initClient.enabled=true within their own values.yaml may receive the following errors at deploy time:
Keycloak initUser has been enabled
The following fields are required to be set
 .Values.keycloak.initUser.name
 .Values.keycloak.initUser.auth
Keycloak initClient has been enabled
The following fields are required to be set
 .Values.keycloak.initClient.clientId
 .Values.keycloak.initClient.clientSecret
If enabling the initUser you are required to set:
keycloak:
  initUser:
    enabled: true
    name: "initUsername"
    auth: "initUserPassword"
Where keycloak passwordPolicy has been enabled, initUser.auth must satisfy the policy requirements.
If enabling the initClient you are required to set:
keycloak:
  initClient:
    enabled: true
    clientId: "initClientID"
    clientSecret: "initClientSecret"
Internal Network LoadBalancers
As of 1.3.0 by default annotations are added to Service resources of type LoadBalancer.
These annotations restrict access to the LoadBalancers from outside the cluster.
To disable these annotations and permit access from outside the cluster, the user is required to set:
global:
    service:
        useInternalLBAnnotations: false
For additional configuration options see here.
Known Issues
- If you request too much data in a single getData(), the request will fail. To overcome this issue you should request less data per getData() call. The error message returned will look like the example below
   {"header":{"http":"json","corr":"6dd8f0c5-1895-49c9-a87a-636a834af370","logCorr":"6dd8f0c5-1895-49c9-a87a-636a834af370","client":":10.0.10.76:5050","api":".kxi.getData","protocol":"gw","numRP":1,"ogRcID":"10.0.10.100:5060","to":"2022-04-07T11:41:35.717000000","retryCount":0,"rc":42,"ac":10,"ai":"Agg died"},"payload":[]}
- 
The user-defined variables & functions in the Queries tab are shared across users. (We recommend that you prefix all your variables with characters that are unique to your user.) 
- 
The Queries tab allows users to execute arbitrary code within the cluster. To lock down the environment, this can be restricted with role based authentication using Keycloak. Restrict the roles relating to insights.scratch.*
- 
The Queries tab will not print results to the console for multi-line python code. Results are only printed if there is just one line of python code. 
- 
On startup of pods, the following error might be observed once roughly after three minutes of a pod starting up no acct for 3x period, exiting. This stems from a temporary startup job not shutting down correctly. It's independent from the main processes and doesn't indicate any application fault.
- 
On initial startup of the kdb Insights Enterprise, there may be some noise printed in the logs while the system initializes unable to flush accounting logs. This relates to the capturing of consumption-based license logs and is thrown while all pods get into a running state. It does not indicate any fault in the application and all data should be flushed correctly after a short period.
- Setting SM replicas (defining sizegreater than 1) in assembly YAML will cause writedown/storage and query problems. Thesizeparameter for SM should always be set to 1.
sm:
  size: 1
- If the cluster and/or resource configuration for the kxi-discovery-serviceis limited, a race condition can occur at startup causing the Discovery Service to be in a crash/restart loop. This can be solved by giving the Discovery Service additional CPU and memory resources; full details on setting custom resources can be found here
- Upon upgrade or downgrade, the API Gateway containers may enter a CrashLoopBackOff state. Resources can be reapplied by performing a 'rollback' to the upgraded version. Get the upgraded version by looking at the output from:
helm ls
'Rollback' (re-apply resources) to the upgraded version:
helm rollback <release name> <current revision>
There are two known issues with the UI logout.
- After performing a logout action, the user will not be redirected back to the login screen.
- In the case a user was logged out due to inactivity, a "Logout failed" error might be observed
In both of these cases, the logout has been successful and the user can re-login by navigating back to the main page, i.e. https://${INSIGHTS_HOSTNAME}
1.2.1
Release for kdb Insights Enterprise.
Release Date
2022-09-22
Fixes
kdb Insights Enterprise 1.2.1 is a security update for vulnerabilities in the included images for Keycloak/PostgreSQL.
Artifacts
| type | location | 
|---|---|
| Infrastructure | kxi-terraform-1.2.0.tgz | 
| Platform | insights-1.2.1.tgz | 
| Operator | kxi-operator-1.2.0.tgz | 
| CLI | kxicli-1.2.0-py3-none-any.whl | 
| ODBC Driver | kodbc 1.2.0 | 
| Java SDK | java-sdk 1.2.0 | 
| keycloak-server | keycloak-server-0.2.1.tgz | 
Upgrade notes
Upgrading assemblies
When upgrading kdb Insights Enterprise, assemblies deployed from the UI in earlier versions will be restarted but will not be automatically upgraded. To upgrade these assemblies, please restart them from the UI post-upgrade.
Version 1.2.1 requires a custom storageClassName definition
The addition of support for packages introduces a new storageClassName defined as sharedfiles, this is defined by default in any deployments of kdb Insights Enterprise that rely on the KX provided Terraform scripts for deployment but must be added manually by a user as outlined here.
Alternatively, within the deployment configuration as outlined here, modify the storageClassName to an alternative supported RWX storage option for example rookcephfs.
Keycloak 18
The version of Keycloak used within kdb Insights Enterprise 1.2.0 and 1.2.1 has been upgraded from Keycloak 16 to Keycloak 18.
Please follow the Keycloak 18 migration steps to migrate your Keycloak data prior to upgrading kdb Insights Enterprise from versions older than 1.2.0.
Azure Marketplace upgrade
Upgrading from v1.2.0 Marketplace release has a known issue. Keycloak was upgraded in v1.2.1 which contained non backward compatible changes. The PostgreSQL secret format has changed, and existingSecret from values.yaml has an extra nested key. Please make sure values.yaml has the extra  auth nested key, and that the secret containing PostgreSQL passwords, usually called kxi-postgresql, has dropped the postgresql prefix from the data keys.
Known Issues
- If you request too much data in a single getData(), the request will fail. To overcome this issue you should request less data per getData() call. The error message returned will look like the example below
   {"header":{"http":"json","corr":"6dd8f0c5-1895-49c9-a87a-636a834af370","logCorr":"6dd8f0c5-1895-49c9-a87a-636a834af370","client":":10.0.10.76:5050","api":".kxi.getData","protocol":"gw","numRP":1,"ogRcID":"10.0.10.100:5060","to":"2022-04-07T11:41:35.717000000","retryCount":0,"rc":42,"ac":10,"ai":"Agg died"},"payload":[]}
- 
The user-defined variables & functions in the Explore tab are shared across users. (We recommend that you prefix all your variables with characters that are unique to your user.) 
- 
The Explore tab allows users to execute arbitrary code within the cluster. To lock down the environment, this can be restricted with role based authentication using Keycloak. Restrict the roles relating to insights.scratch.*
- 
The Explore tab will not print results to the console for multi-line python code. Results are only printed if there is just one line of python code. 
- 
On startup of pods, the following error might be observed once roughly after three minutes of a pod starting up no acct for 3x period, exiting. This stems from a temporary startup job not shutting down correctly. It's independent from the main processes and doesn't indicate any application fault.
- 
On initial startup of the kdb Insights Enterprise, there may be some noise printed in the logs while the system initializes unable to flush accounting logs. This relates to the capturing of consumption-based license logs and is thrown while all pods get into a running state. It does not indicate any fault in the application and all data should be flushed correctly after a short period.
- 
The KX ODBC driver is not currently available for use on Windows, therefore as the Java SDK requires the ODBC driver to be installed, neither SDKs are currently available on Windows. 
- 
When either the Java SDK or ODBC driver is being used, if kdb Insights Enterprise Information Service fails to respond to the SDK for at least 1 minute it will deem their own configuration too old and will disconnect and stop publisher into kdb Insights Enterprise. This can be observed when the control plane is inaccessible (for example during the default GCP maintenance window, 5am UTC, if it hasn’t been disabled). Any application using the SDKs will need to account for this and introduce some restart logic which will trigger the SDK to restart, and force a reconnect attempt by the SDK. 
Sample extract from the application log:
2022-05-24 20:30:48.103035      INFO    1       Started replicator to :34.142.40.180:5000, pid 41697
2022-05-24 20:31:48.127821      INFO    1       Process 41697 terminated
2022-05-24 20:31:48.128196      INFO    1       Started replicator to :34.142.40.180:5000, pid 41714
2022-05-24 20:36:12.700002      INFO    1       Process 41714 terminated
2022-05-24 20:36:12.700467      INFO    1       Started replicator to :34.142.40.180:5000, pid 41772
2022-05-25 05:04:50.077286      INFO    0       New configuration fetched
2022-05-25 05:04:50.092259      WARN    0       Config parse error at offset 0: Expected opening bracket
2022-05-25 05:05:50.046686      ERROR   0       Config is too old
2022-05-25 05:05:50.046813      INFO    0       Waiting for the driver to sync the data
- Setting SM replicas (defining sizegreater than 1) in assembly YAML will cause writedown/storage and query problems. Thesizeparameter for SM should always be set to 1.
sm:
  size: 1
- 
Torn-down pipelines that include Database or Stream Writers cannot be directly restarted after having their resources removed. Upon redeploy, data will not be published downstream from the pipeline. A workaround is to rename the pipeline. Resources are removed by checking "Clear Pipeline State" during teardown in the UI, or by directly deleting the Kubernetes PVCs backing the pipeline. If either of these things are done, the pipeline must be renamed before relaunching it. 
- 
.qsp.read.fromDatabasecannot be run in a pipeline to query a kdb Insights Enterprise database. The following example code can be used as a workaround to query data (ex. reference data to be used within a pipeline).
onResponse:{[hdr;data]
if[0 <> hdr`ac;
    .sp.log.error ("Query failed host=%s, api=%s, code=%n, error=%s";hdr`gw; hdr`api; hdr`ac; hdr`ai)];
publish data
}
.qsp.onStart {
    h:hopen hsym `$.spenv.getReleaseName[],"-sg-gateway:5050";
    res: neg[h] (`.kxi.getData; (enlist `table)!(enlist `instruments); `onResponse; ()!());
}
.qsp.run .qsp.read.fromCallback[`publish] .qsp.write.toConsole[]
- Upon upgrade or downgrade, the API Gateway containers may enter a CrashLoopBackOff state. Resources can be reapplied by performing a 'rollback' to the upgraded version. Get the upgraded version by looking at the output from:
helm ls
'Rollback' (re-apply resources) to the upgraded version:
helm rollback <release name> <current revision>
There are two known issues with the UI logout.
- After performing a logout action, the user will not be redirected back to the login screen.
- In the case a user was logged out due to inactivity, a "Logout failed" error might be observed
In both of these cases, the logout has been successful and the user can navigate re-login by navigating back to the main page, i.e. https://${INSIGHTS_HOSTNAME}
1.2.0
Release for kdb Insights Enterprise.
Release Date
2022-09-02
Features
[NEW] Install and Packages
- 
Upgrade support{:target="blank"} in the kxicommand line tool for easier upgrades. _Please take note of other Upgrade Notes below.
- 
You must now provide a namespace when deleting installs using kxi install deletein the CLI.
- 
Ability to list, add and delete custom versioned user code via packages to kdb Insights Enterprise via the CLI outlined here. 
- 
Support within packages for the definition of User Defined Functions (UDFs) written in Python or q for deployment to stream-processor or use in the Explore Window. 
[NEW] Pipelines
- 
MQTT QoS 0 Reader has been added. 
- 
Users can run Test deploys in the UI, which provide user feedback on issues when building or editing a pipeline. This includes visualization of the data at each node in the pipeline, and clear indications of which nodes failed. 
- 
CPU and Memory resources can now be configured from the User Interface to allow rightsizing of data pipelines. 
- 
Use of User Defined Functions as part of a pipeline. 
- 
Apply Schema is now available for use after the CSV decoder, so the optional schema parameters for the CSV node have been removed from the Pipelines UI. Users should take care to ensure they're parsing all fields in the Apply Schema node when it's being applied to CSV decoded data. 
[NEW] Explore and Query
- 
Significant speed improvements to Explore. Query environments are pre-allocated as part of Data/assemblies, and so switching between tabs, assemblies, or instances is now instant. Query environments must be enabled in the Database/Data Access screen, or in assembly configuration, for the assembly to be available in Explore. 
- 
Filtering and aggregation are now available on the Query tab. 
- 
There is no need to choose a database when using the Query or SQL options in the Explore window. Label filtering can be used to select particular databases. You can now read from tables with the same name and schema across multiple databases when using the Query or SQL tabs. 
- 
Import and use of User Defined Functions in pipelines and the Explore Window to allow running of custom code. 
- 
Console output can now be cleared by right-clicking in the Console and choosing "Clear". 
- 
The query section at the top of Explore tabs can now be collapsed for a larger code area. 
[NEW] Databases
- 
CPU and Memory resources can now be configured from the User Interface to allow rightsizing of storage and query services. 
- 
Redundant replicas possible for all query-path processes, enabling greater query uptime despite process, node, or availability-zone failure. 
- 
Ability for Data Access tiers (RDB, IDB, HDB) to share compute resources by using mountListwithin Assembly configuration rather thanmountName.
- 
Granular assembly deployment status showing the state of deploying components, and assembly deployment errors, are now surfaced in the UI. Mouse-over the assembly's status icon while it's deploying to see the breakdown. 
- 
Environmental variables can now be configured in the UI for Data Access and Storage when the Advanced view is enabled. 
- 
Code View for Schemas is now available in the UI. Users can edit (or copy/paste) schemas directly, rather than configuring through UI forms. 
[NEW] Performance
- Cluster overprovisioning support that can be configured to enable faster scaling, by reserving resources.
[NEW] Java SDK
- 
Query support has been added to the Java SDK. 
- 
For ingestion there is an option to validate the data being ingested to ensure it is in the format that is expected by the database, before it is ingested. 
- 
Batch publishing is available, if required. 
[NEW] Observability
- It is now possible to filter for a displayed value (for example, a particular Container) in the Diagnostics screen. Right-click on the value and select "Filter by [...]".
[NEW] Infrastructure
- A storage class named sharedfiles, that is backed by shared storage, is automatically created when deploying via client Terraform scripts.sharedfilesstorage is used for storing Packages and required by kdb Insights Enterprise.
Fixes
A large number of fixes have gone into kdb Insights Enterprise 1.2.0. Known issues which have been resolved, along with some other highlights, are listed below.
[FIX] Pipelines
- Pipelines no longer report an initial "Unresponsive" status in the UI when launching.
[FIX] Explore and Query
- 
With the introduction of Query Environments, there is no longer an issue where PVCs are not removed upon assembly teardown due to active Explore tabs targeting the assembly. 
- 
SQL queries can now target splayed tables (reference data). 
[FIX] Observability
- All UI notifications now appear in the Diagnostics panel.
[FIX] UI
- Redeploying Data (assembly) no longer adds extra nodes to the navigation tree.
Artifacts
| type | location | 
|---|---|
| Infrastructure | kxi-terraform-1.2.0.tgz | 
| Platform | insights-1.2.0.tgz | 
| Operator | kxi-operator-1.2.0.tgz | 
| CLI | kxicli-1.2.0-py3-none-any.whl | 
| ODBC Driver | kodbc 1.2.0 | 
| Java SDK | java-sdk 1.2.0 | 
Upgrade notes
Upgrading assemblies
When upgrading kdb Insights Enterprise, assemblies deployed from the UI in earlier versions will be restarted but will not be automatically upgraded. To upgrade these assemblies, please restart them from the UI post-upgrade.
Version 1.2.0 requires a custom storageClassName definition
The addition of support for packages introduces a new storageClassName defined as sharedfiles, this is defined by default in any deployments of kdb Insights Enterprise that rely on the KX provided Terraform scripts for deployment but must be added manually by a user as outlined here.
Alternatively, within the deployment configuration as outlined here, modify the storageClassName to an alternative supported RWX storage option for example rookcephfs.
Keycloak 18
The version of Keycloak used within kdb Insights Enterprise has been upgraded from Keycloak 16 to Keycloak 18.
Please follow the Keycloak 18 migration steps to migrate your Keycloak data prior to upgrading kdb Insights Enterprise.
Known Issues
- If you request too much data in a single getData(), the request will fail. To overcome this issue you should request less data per getData() call. The error message returned will look like the example below
   {"header":{"http":"json","corr":"6dd8f0c5-1895-49c9-a87a-636a834af370","logCorr":"6dd8f0c5-1895-49c9-a87a-636a834af370","client":":10.0.10.76:5050","api":".kxi.getData","protocol":"gw","numRP":1,"ogRcID":"10.0.10.100:5060","to":"2022-04-07T11:41:35.717000000","retryCount":0,"rc":42,"ac":10,"ai":"Agg died"},"payload":[]}
- 
The user-defined variables & functions in the Explore tab are shared across users. (We recommend that you prefix all your variables with characters that are unique to your user.) 
- 
The Explore tab allows users to execute arbitrary code within the cluster. To lock down the environment, this can be restricted with role based authentication using Keycloak. Restrict the roles relating to insights.scratch.*
- 
The Explore tab will not print results to the console for multi-line python code. Results are only printed if there is just one line of python code. 
- 
On startup of pods, the following error might be observed once roughly after three minutes of a pod starting up no acct for 3x period, exiting. This stems from a temporary startup job not shutting down correctly. It's independent from the main processes and doesn't indicate any application fault.
- 
On initial startup of the kdb Insights Enterprise, there may be some noise printed in the logs while the system initializes unable to flush accounting logs. This relates to the capturing of consumption-based license logs and is thrown while all pods get into a running state. It does not indicate any fault in the application and all data should be flushed correctly after a short period.
- 
The KX ODBC driver is not currently available for use on Windows, therefore as the Java SDK requires the ODBC driver to be installed, neither SDKs are currently available on Windows. 
- 
When either the Java SDK or ODBC driver is being used, if kdb Insights Enterprise Information Service fails to respond to the SDK for at least 1 minute it will deem their own configuration too old and will disconnect and stop publisher into kdb Insights Enterprise. This can be observed when the control plane is inaccessible (for example during the default GCP maintenance window, 5am UTC, if it hasn’t been disabled). Any application using the SDKs will need to account for this and introduce some restart logic which will trigger the SDK to restart, and force a reconnect attempt by the SDK. 
Sample extract from the application log:
2022-05-24 20:30:48.103035      INFO    1       Started replicator to :34.142.40.180:5000, pid 41697
2022-05-24 20:31:48.127821      INFO    1       Process 41697 terminated
2022-05-24 20:31:48.128196      INFO    1       Started replicator to :34.142.40.180:5000, pid 41714
2022-05-24 20:36:12.700002      INFO    1       Process 41714 terminated
2022-05-24 20:36:12.700467      INFO    1       Started replicator to :34.142.40.180:5000, pid 41772
2022-05-25 05:04:50.077286      INFO    0       New configuration fetched
2022-05-25 05:04:50.092259      WARN    0       Config parse error at offset 0: Expected opening bracket
2022-05-25 05:05:50.046686      ERROR   0       Config is too old
2022-05-25 05:05:50.046813      INFO    0       Waiting for the driver to sync the data
- Setting SM replicas (defining sizegreater than 1) in assembly YAML will cause writedown/storage and query problems. Thesizeparameter for SM should always be set to 1.
sm:
  size: 1
- 
Torn-down pipelines that include Database or Stream Writers cannot be directly restarted after having their resources removed. Upon redeploy, data will not be published downstream from the pipeline. A workaround is to rename the pipeline. Resources are removed by checking "Clear Pipeline State" during teardown in the UI, or by directly deleting the Kubernetes PVCs backing the pipeline. If either of these things are done, the pipeline must be renamed before relaunching it. 
- 
.qsp.read.fromDatabasecannot be run in a pipeline to query a kdb Insights Enterprise database. The following example code can be used as a workaround to query data (ex. reference data to be used within a pipeline).
onResponse:{[hdr;data]
if[0 <> hdr`ac;
    .sp.log.error ("Query failed host=%s, api=%s, code=%n, error=%s";hdr`gw; hdr`api; hdr`ac; hdr`ai)];
publish data
}
.qsp.onStart {
    h:hopen hsym `$.spenv.getReleaseName[],"-sg-gateway:5050";
    res: neg[h] (`.kxi.getData; (enlist `table)!(enlist `instruments); `onResponse; ()!());
}
.qsp.run .qsp.read.fromCallback[`publish] .qsp.write.toConsole[]
- Upon upgrade or downgrade, the API Gateway containers may enter a CrashLoopBackOff state. Resources can be reapplied by performing a 'rollback' to the upgraded version. Get the upgraded version by looking at the output from:
helm ls
'Rollback' (re-apply resources) to the upgraded version:
helm rollback <release name> <current revision>
There are two known issues with the UI logout.
- After performing a logout action, the user will not be redirected back to the login screen.
- In the case a user was logged out due to inactivity, a "Logout failed" error might be observed
In both of these cases, the logout has been successful and the user can navigate re-login by navigating back to the main page, i.e. https://${INSIGHTS_HOSTNAME}
1.1.2
kdb Insights Enterprise 1.1.2 is a patch release that corrects a small number of observability and query issues.
Release Date
2022-07-15
Observability
 [FIX] Metrics responses are all now terminated with a newline \n. Absence of the newline caused import issues with some metrics scrapers, for example Azure Monitor.
Explore and Queries
 [FIX] The getData API endpoint no longer returns an error when an outputTZ is provided.
[FIX] Queries against the interval tier (idb) around the end-of-day rollover process could return zero results.
Infrastructure
[NEW] The Terraform scripts will now pass the correct platform to the Docker container when running them on Macs
[FIX] The Helm version in the Terraform scripts' Dockerfile has been pinned to a version without AWS compatibility issues.
Artifacts
| type | location | 
|---|---|
| Infrastructure | kxi-terraform-1.1.1.tgz | 
| Platform | insights-1.1.2.tgz | 
| Operator | kxi-operator-1.1.0.tgz | 
| CLI | kxicli-0.9.0-py3-none-any.whl | 
| ODBC Driver | kodbc 1.1.0 | 
| Java SDK | java-sdk 1.1.0 | 
Upgrade notes
Data loss of UI assembly definitions for versions earlier than 1.1.1
Assembly definitions built from the kdb Insights Enterprise UI in versions earlier than 1.1.1 will be lost as part of an uninstall of the application. The assembly components (assemblies, databases, pipelines, reports, schemas, streams) are stored on a PVC in the application. This storage is incorrectly torn down as part of an uninstall, resulting in data loss on re-install or upgrade.
To prevent this data loss the following commands can be run to backup the data. This should be run prior to the uninstall, with kubectl configured to the target cluster and namespace.
kubectl exec insights-kxi-controller-0 -- tar -C /kxic/data -czf - . > kxi-controller-data.tgz
To restore, the user should run the following command post-install.
cat kxi-controller-data.tgz |  kubectl exec insights-kxi-controller-0 --stdin -- tar -C /kxic/data -xzf -
kdb Insights Operator Version
As the version of the kdb Insights Operator has not changed from 1.1.0 to 1.1.2, the command for deploying kdb Insights Enterprise is slightly different than in earlier releases. The older kdb Insights Operator version must be explicitly passed to the CLI.
kxi install run --filepath values.yaml --version 1.1.2 --operator-version 1.1.0
Please see the guide to Installing kdb Insights Enterprise or Upgrading kdb Insights Enterprise for more detail.
New functionality and roles
kdb Insights Enterprise 1.1.1 includes new features permissioned by additional roles. If you are upgrading to 1.1.2 from a version earlier than 1.1.1, please see the section about authentication upgrades for more information about how to incorporate realm changes, including new roles, during an upgrade.
Known Issues
- If you request too much data in a single getData(), the request will fail. To overcome this issue you should request less data per getData() call. The error message returned will look like the example below
   {"header":{"http":"json","corr":"6dd8f0c5-1895-49c9-a87a-636a834af370","logCorr":"6dd8f0c5-1895-49c9-a87a-636a834af370","client":":10.0.10.76:5050","api":".kxi.getData","protocol":"gw","numRP":1,"ogRcID":"10.0.10.100:5060","to":"2022-04-07T11:41:35.717000000","retryCount":0,"rc":42,"ac":10,"ai":"Agg died"},"payload":[]}
- 
The user-defined variables & functions in the Explore tab are shared across users. (We recommend that you prefix all your variables with characters that are unique to your user.) 
- 
Assemblies applied directly through kubectl cannot be edited in the User Interface. However, they can be queried via the Explore tab. 
- 
Currently users will be logged out but will not be notified via the UI. If users consistently encounter errors, we suggest they log out and in again. 
- 
The Explore tab allows users to execute arbitrary code within the cluster. To lock down the environment, this can be restricted with role based authentication using Keycloak. Restrict the roles relating to insights.scratch.*
- 
The Explore tab will not print results to the console for multi-line python code. Results are only printed if there is just one line of python code. 
- 
The drop-down list of assemblies in the first Explore tab opened after applying the first kdb Insights Enterprise assembly will take a short while to populate. Try again after a few seconds if nothing appears immediately, or close and re-open the Explore tab to see the list and select an assembly. 
- 
Teardown cleanups of Data (assemblies) via the UI will not fully remove PVCs if there are active Explore tabs targeting that assembly. Close these tabs or remove their underlying sandboxes via the REST API to complete the cleanup. 
- 
On startup of pods, the following error might be observed once roughly after three minutes of a pod starting up no acct for 3x period, exiting. This stems from a temporary startup job not shutting down correctly. It's independent from the main processes and doesn't indicate any application fault.
- 
On initial startup of the kdb Insights Enterprise, there may be some noise printed in the logs while the system initializes unable to flush accounting logs. This relates to the capturing of consumption-based license logs and is thrown while all pods get into a running state. It does not indicate any fault in the application and all data should be flushed correctly after a short period.
- 
The KX ODBC driver is not currently available for use on Windows, therefore as the Java SDK requires the ODBC driver to be installed, neither SDKs are currently available on Windows. 
- 
When either the Java SDK or ODBC driver is being used, if kdb Insights Enterprise Information Service fails to respond to the SDK for at least 1 minute it will deem their own configuration too old and will disconnect and stop publisher into kdb Insights Enterprise. This can be observed when the control plane is inaccessible (for example during the default GCP maintenance window, 5am UTC, if it hasn’t been disabled). Any application using the SDKs will need to account for this and introduce some restart logic which will trigger the SDK to restart, and force a reconnect attempt by the SDK. 
Sample extract from the application log:
2022-05-24 20:30:48.103035      INFO    1       Started replicator to :34.142.40.180:5000, pid 41697
2022-05-24 20:31:48.127821      INFO    1       Process 41697 terminated
2022-05-24 20:31:48.128196      INFO    1       Started replicator to :34.142.40.180:5000, pid 41714
2022-05-24 20:36:12.700002      INFO    1       Process 41714 terminated
2022-05-24 20:36:12.700467      INFO    1       Started replicator to :34.142.40.180:5000, pid 41772
2022-05-25 05:04:50.077286      INFO    0       New configuration fetched
2022-05-25 05:04:50.092259      WARN    0       Config parse error at offset 0: Expected opening bracket
2022-05-25 05:05:50.046686      ERROR   0       Config is too old
2022-05-25 05:05:50.046813      INFO    0       Waiting for the driver to sync the data
1.1.1
kdb Insights Enterprise 1.1.1 is a patch release that improves usability and stability.
Release Date
2022-06-28
Data (Assemblies)
[FIX] Clearer tooltips for Data status to ensure users can clearly identify when their assemblies are fully deployed.
[FIX] Additional validation has been added to stop re-deployment of Data (assemblies) after schema changes – schema changes on deployed assemblies are not supported in this version of kdb Insights Enterprise.
[FIX] Additional validation has been added for schemas to ensure they can be deployed successfully.
[FIX] The serviceVolume setting is now mapped correctly in Database and Stream
[FIX] A condition where Stream log archiving could fail has been resolved, ensuring that stream log files do not grow beyond the defined limits.
[FIX] Navigation tree issues where schemas could not be opened and deletion failures were not correctly reflected are both resolved.
Pipelines
[FIX] Nodes requiring passwords no longer store them in the pipeline configuration, they must be entered during pipeline deployment.
[FIX] Mandatory fields in nodes are now enforced in pipelines before deployment.
[FIX] Pipeline re-deployments can now optionally clear state (destroying previously persisted pipeline data, but not data already in the database) to allow edits to be made and the pipeline to be restarted from scratch.
 [FIX] The error Cannot read properties of undefined (reading '0') which could be thrown when opening multiple pipeline tabs has been resolved.
[FIX] An issue where long code lines in Map nodes could cause browsers to hang has been resolved.
Explore and Queries
 [FIX] Session errors Worker has been closed and r.map are no longer thrown.
 [FIX] The error No aggregator available when changing assemblies in an Explore session is no longer thrown.
[FIX] Reference data joins which do not include the foreign column or where the foreign column has a different name are now possible.
[FIX] An issue where certain queries’ WHERE clause would work via REST but fail via Explore has been resolved.
 [FIX] An issue where certain queries using count could throw the error Error: noupdate: `.Q `pn has been resolved.
Artifacts
| type | location | 
|---|---|
| Infrastructure | kxi-terraform-1.1.0.tgz | 
| Platform | insights-1.1.1.tgz | 
| Operator | kxi-operator-1.1.0.tgz | 
| CLI | kxicli-0.9.0-py3-none-any.whl | 
| ODBC Driver | kodbc 1.1.0 | 
| Java SDK | java-sdk 1.1.0 | 
Upgrade notes
Data loss of UI assembly definitions
Assembly definitions built from the kdb Insights Enterprise UI will be lost as part of an uninstall of the application. The assembly components (assemblies, databases, pipelines, reports, schemas, streams) are stored on a PVC in the application. This storage is incorrectly torn down as part of an uninstall, resulting in data loss on re-install or upgrade.
To prevent this data loss the following commands can be run to backup the data. This should be run prior to the uninstall, with kubectl configured to the target cluster and namespace.
kubectl exec insights-kxi-controller-0 -- tar -C /kxic/data -czf - . > kxi-controller-data.tgz
To restore, the user should run the following command post-install.
cat kxi-controller-data.tgz |  kubectl exec insights-kxi-controller-0 --stdin -- tar -C /kxic/data -xzf -
kdb Insights Operator Version
As the version of the kdb Insights Operator has not changed from 1.1.0 to 1.1.1, the command for deploying kdb Insights Enterprise is slightly different than in earlier releases. The older kdb Insights Operator version must be explicitly passed to the CLI.
kxi install run --filepath values.yaml --version 1.1.1 --operator-version 1.1.0
Please see the guide to Installing kdb Insights Enterprise or Upgrading kdb Insights Enterprise for more detail.
New functionality and roles
kdb Insights Enterprise 1.1.1 includes new features permissioned by additional roles. Please see the section about authentication upgrades for more information about how to incorporate realm changes, including new roles, during an upgrade.
Known Issues
- If you request too much data in a single getData(), the request will fail. To overcome this issue you should request less data per getData() call. The error message returned will look like the example below
   {"header":{"http":"json","corr":"6dd8f0c5-1895-49c9-a87a-636a834af370","logCorr":"6dd8f0c5-1895-49c9-a87a-636a834af370","client":":10.0.10.76:5050","api":".kxi.getData","protocol":"gw","numRP":1,"ogRcID":"10.0.10.100:5060","to":"2022-04-07T11:41:35.717000000","retryCount":0,"rc":42,"ac":10,"ai":"Agg died"},"payload":[]}
- 
The user-defined variables & functions in the Explore tab are shared across users. (We recommend that you prefix all your variables with characters that are unique to your user.) 
- 
Assemblies applied directly through kubectl cannot be edited in the User Interface. However, they can be queried via the Explore tab. 
- 
Currently users will be logged out but will not be notified via the UI. If users consistently encounter errors, we suggest they log out and in again. 
- 
The Explore tab allows users to execute arbitrary code within the cluster. To lock down the environment, this can be restricted with role based authentication using Keycloak. Restrict the roles relating to insights.scratch.* 
- 
The Explore tab will not print results to the console for multi-line python code. Results are only printed if there is just one line of python code. 
- 
The drop-down list of assemblies in the first Explore tab opened after applying the first Insights assembly will take a short while to populate. Try again after a few seconds if nothing appears immediately, or close and re-open the Explore tab to see the list and select an assembly. 
- 
On startup of pods, the following error might be observed once roughly after three minutes of a pod starting up no acct for 3x period, exiting. This stems from a temporary startup job not shutting down correctly. It's independent from the main processes and doesn't indicate any application fault.
- 
On initial startup of the kdb Insights Enterprise, there may be some noise printed in the logs while the system initializes unable to flush accounting logs. This relates to the capturing of consumption-based license logs and is thrown while all pods get into a running state. It does not indicate any fault in the application and all data should be flushed correctly after a short period.
- 
The KX ODBC driver is not currently available for use on Windows, therefore as the Java SDK requires the ODBC driver to be installed, neither SDKs are currently available on Windows. 
- 
When either the Java SDK or ODBC driver is being used, if kdb Insights Enterprise Information Service fails to respond to the SDK for at least 1 minute it will deem their own configuration too old and will disconnect and stop publisher into kdb Insights Enterprise. This can be observed when the control plane is inaccessible (for example during the default GCP maintenance window, 5am UTC, if it hasn’t been disabled). Any application using the SDKs will need to account for this and introduce some restart logic which will trigger the SDK to restart, and force a reconnect attempt by the SDK. 
Sample extract from the application log:
2022-05-24 20:30:48.103035      INFO    1       Started replicator to :34.142.40.180:5000, pid 41697
2022-05-24 20:31:48.127821      INFO    1       Process 41697 terminated
2022-05-24 20:31:48.128196      INFO    1       Started replicator to :34.142.40.180:5000, pid 41714
2022-05-24 20:36:12.700002      INFO    1       Process 41714 terminated
2022-05-24 20:36:12.700467      INFO    1       Started replicator to :34.142.40.180:5000, pid 41772
2022-05-25 05:04:50.077286      INFO    0       New configuration fetched
2022-05-25 05:04:50.092259      WARN    0       Config parse error at offset 0: Expected opening bracket
2022-05-25 05:05:50.046686      ERROR   0       Config is too old
2022-05-25 05:05:50.046813      INFO    0       Waiting for the driver to sync the data
Backward Compatibility
Please see the release notes for kdb Insights Enterprise 1.1.0 if you're upgrading from an earlier version, for notes about:
1.1.0
Release for kdb Insights Enterprise.
Release Date
2022-06-07
Features
[NEW] Storage and Query
- Late and out-of-order data handling- Data received out of order is recorded with an appropriate ingest timestamp
- Late data is recorded, irrespective of where its correct destination is in the lifecycle (RDB, IDB, HDB)
- Late data is included by default for all requests, q (getData) and ANSI SQL
- Late data can be filtered out (for example, to see only data present in the system at a particular point in time)
- Performance is not significantly impacted by late data arrival, including for object storage tiers
 
- Reference data can be queried in the Explore Window, in a data pipeline and as part of the getData() API
- Support for non time-series reference data in Database
- Data in reference tables can be joined to time-series tables in free-form q queries
- Improved SQL support for queries (joins and complex queries, except for reference tables)
- Compression support, including object storage
- Improved resiliency and performance
[NEW] User Interface
- 
Scratchpads - Data can be pulled into the scratchpad using either sql or getData()
- Freeform q, SQL or Python code can be execute on that data to further filter, aggregate and join data to explore specific records
- Python/q functions or a model can be applied to that data to gain insights
- A model can be fitted using that data
 
- 
Machine Learning plugins can be added to a Pipeline created from the user interface 
- More intuitive creation of data ingest pipelines
- Observability embedded into the UI (events and logs tab)
- Log forwarding to each providers' log aggregator is now enabled by default in the Terraform scripts.
[NEW] Reports
- Visualization is available for ingested data using the getData() API
[NEW] Observability
- View Database and Pipeline logs and events from the UI
- Ability to Export Diagnostics, including the logs, events and state for further diagnosis
- Further integration with cloud monitoring tools
- Additional performance metrics collected
[NEW] Reliable Transport Stream
- Subscribers have the option to override the detail truncation options for the stream logs that they have processed
- Improved recovery and performance
Artifacts
| type | location | 
|---|---|
| Infrastructure | kxi-terraform-1.1.0.tgz | 
| Platform | insights-1.1.0.tgz | 
| Operator | kxi-operator-1.1.0.tgz | 
| CLI | kxicli-0.9.0-py3-none-any.whl | 
| ODBC Driver | kodbc 1.1.0 | 
| Java SDK | java-sdk 1.1.0 | 
Upgrade notes
Data loss of UI assembly definition
Data loss of UI assembly definitions
Assembly definitions built from the kdb Insights Enterprise UI will be lost as part of an uninstall of the application. The assembly components (assemblies, databases, pipelines, reports, schemas, streams) are stored on a PVC in the application. This storage is incorrectly torn down as part of an uninstall, resulting in data loss on re-install or upgrade.
To prevent this data loss the following commands can be run to backup the data. This should be run prior to the uninstall, with kubectl configured to the target cluster and namespace.
kubectl exec insights-kxi-controller-0 -- tar -C /kxic/data -czf - . > kxi-controller-data.tgz
To restore, the user should run the following command post-install.
cat kxi-controller-data.tgz |  kubectl exec insights-kxi-controller-0 --stdin -- tar -C /kxic/data -xzf -
Known Issues
- If you request too much data in a single getData(), the request will fail. To overcome this issue you should request less data per getData() call. The error message returned will look like the example below
   {"header":{"http":"json","corr":"6dd8f0c5-1895-49c9-a87a-636a834af370","logCorr":"6dd8f0c5-1895-49c9-a87a-636a834af370","client":":10.0.10.76:5050","api":".kxi.getData","protocol":"gw","numRP":1,"ogRcID":"10.0.10.100:5060","to":"2022-04-07T11:41:35.717000000","retryCount":0,"rc":42,"ac":10,"ai":"Agg died"},"payload":[]}
- getDatadoes not support connecting reference data column names that do not match. If the name of a column does not match the name of the column it is a foreign key for, then the- getDatareference join will fail. Example: The trade table has a column- symwhich is a foreign key to the- msymcolumn in the table market. The join will run into an issue since the column names are different.
- 
The user-defined variables & functions in the Explore tab are shared across users. (We recommend that you prefix all your variables with characters that are unique to your user.) 
- 
Assemblies applied directly through kubectl cannot be edited in the User Interface. However, they can be queried via the Explore tab. 
- 
Passwords used for authenticating to third-party services are currently stored as part of the pipeline configuration. This will be corrected in the next release. It is recommended that instead of using a password directly that a Kubernetes secret is used whenever possible. 
- 
Currently users will be logged out but will not be notified via the UI. If users consistently encounter errors, we suggest they log out and in again. 
- 
The Explore tab allows users to execute arbitrary code within the cluster. To lock down the environment, this can be restricted with role based authentication using Keycloak. Restrict the roles relating to insights.scratch.* 
- 
The Explore tab will not print results to the console for multi-line python code. Results are only printed if there is just one line of python code. 
- 
On startup of pods, the following error might be observed once roughly after three minutes of a pod starting up no acct for 3x period, exiting. This stems from a temporary startup job not shutting down correctly. It's independent from the main processes and doesn't indicate any application fault.
- 
On initial startup of the kdb Insights Enterprise, there may be some noise printed in the logs while the system initializes unable to flush accounting logs. This relates to the capturing of consumption-based license logs and is thrown while all pods get into a running state. It does not indicate any fault in the application and all data should be flushed correctly after a short period.
- 
The KX ODBC driver is not currently available for use on Windows, therefore as the Java SDK requires the ODBC driver to be installed, neither SDKs are currently available on Windows. 
- 
When either the Java SDK or ODBC driver is being used, if kdb Insights Information Service fails to respond to the SDK for at least 1 minute it will deem their own configuration too old and will disconnect and stop publisher into kdb Insights Enterprise. This can be observed when the control plane is inaccessible (for example during the default GCP maintenance window, 5am UTC, if it hasn’t been disabled). Any application using the SDKs will need to account for this and introduce some restart logic which will trigger the SDK to restart, and force a reconnect attempt by the SDK. 
Sample extract from the application log:
``` 2022-05-24 20:30:48.103035 INFO 1 Started replicator to :34.142.40.180:5000, pid 41697 2022-05-24 20:31:48.127821 INFO 1 Process 41697 terminated 2022-05-24 20:31:48.128196 INFO 1 Started replicator to :34.142.40.180:5000, pid 41714 2022-05-24 20:36:12.700002 INFO 1 Process 41714 terminated 2022-05-24 20:36:12.700467 INFO 1 Started replicator to :34.142.40.180:5000, pid 41772
e set for the deployment. 2022-05-25 05:04:50.077286 INFO 0 New configuration fetched 2022-05-25 05:04:50.092259 WARN 0 Config parse error at offset 0: Expected opening bracket 2022-05-25 05:05:50.046686 ERROR 0 Config is too old 2022-05-25 05:05:50.046813 INFO 0 Waiting for the driver to sync the data ```
Backward Compatibility
- If you're upgrading from a previous version or the CRD is already installed, helm will not update the definition automatically. See Operator Overview Helm Warning for details on how to rectify this.
License changes
From 1.1.0 kdb Insights has moved to consumption-based licensing using a new license file, kx.lic.
The user should generate the license themselves using the klic self-service tool. The documentation for this
is available here.
After following the klic docs, a new kx.lic should be available for your cluster.
Then you can upload it as a Kubernetes secret using the following command.
kubectl create secret generic kxi-license --from-file=license=kx.lic
Alternatively delete your existing license secret and re-run the CLI install (kxi install ..),
choosing the N when prompted if you have an existing license secret. Assuming the license
secret is called kxi-license, the command below will delete it.
kubectl delete secret kxi-license
To revert to the pre-1.1.0 behavior, the following Helm values should be set for the deployment. For details on this file see here.
global:
  license:
    ..
    onDemand: true
    asFile: false
kxi-acc-svc:
  enabled: false
Single pod Storage Manager
By default, when upgrading to 1.1.0 the Storage Manager will no longer create independent containers for the various processes used to manage data persistence. These processes now all run under a single container as child processes. As part of the upgrade, it is optionally encouraged that any assembly data workflows deployed should be upgraded to align any resources with this change.
The change requires the user to remove resources configuration for eoi, eod and dbm sections of an assembly and update the sm.k8sPolicy with a resources configuration for all these processes which will run as a single container within the sm pod.
For example
  sm:
    ..
    k8sPolicy:
      resources:
        requests:
          memory: "14Gi"
          cpu: "2000m"
        limits:
          memory: "14Gi"
          cpu: "4000m"
However if no actions are taken, kdb Insights will remain backwards compatible with the existing configuration and will use the sum of all CPU and memory resources under the sm element, using this sum to populate the sm.k8sPolicy.resources section under the sm element.
1.0.0
Release for kdb Insights Enterprise.
Release Date
2022-03-14
Features
[NEW] UI allows storage and reload of data assemblies.
[NEW] Schemas can be created and deleted in the kdb Insights Enterprise user interface.
[NEW] Assemblies can be created, saved and deployed in the kdb Insights Enterprise user interface.
[NEW] Ability to Export Assembly Definitions.
[NEW] Integration with the new License Management system. Due to these changes, existing licenses will need to be re-issued. Please contact your KX representative for more information.
Artifacts
| type | location | 
|---|---|
| Infrastructure | kxi-terraform-1.0.0.tgz | 
| Platform | insights-1.0.0.tgz | 
| CLI | kxicli-0.4.0-py3-none-any.whl | 
| Operator | kxi-operator | 
| ODBC Driver | kodbc 1.0.0 | 
| Java SDK | java-sdk 1.0.0 | 
Known Issues
- 
The Service Gateway may repeatably print a NullPointerExceptionunder certain conditions. If this should occur the Kubernetes pod that the service gateway process is running on should be bounced.
- 
An OOM event may be triggered when repeatedly bombarded with requests that return a large result set. In the event where an OOM occurs the client will not receive a response; the request may be retried and serviced by other gateways. 
- 
When choosing an assembly in the Explore Window a ‘500 Internal Server Error’ can be returned if no labels are included in the labels section of the assembly definition. 
- 
In the prospective menu (the customizable navigation toolbar) not all options available in the menu selector are currently supported, we recommend keeping the default menu options. However, all options are included in the Entity Tree shown when the Home menu is selected. 
- 
When exporting an Assembly definition from the kdb Insights Enterprise UI the file requires some cleaning before it can be imported into another environment. - Remove id entry from tables.
- Remove apiVersion entry from pipelines and sequencers.
- Remove line breaks from pipeline specs.
 
- 
When saving a pipeline in the UI on AWS or Azure you need to change the Storage Class from “standard” (which is the default for GCP) to a storage class which exists on AWS or Azure. For example, to “gp2" for AWS, or "default" for Azure. This is done in the Persistence tab when saving. Note, the Storage Class is set separately for the controller and worker. Both must be set correctly. Scroll down to set the worker Storage Class too. Otherwise, the pipeline pod and pvc deployment will get stuck in the “pending” state as no “standard” storage class can be found. Alternatively, create a “standard” storage class per the link storage class resource. 
- 
Assemblies applied directly through kubectl cannot be edited in the User Interface. However, they can be queried via the Explore tab. 
- 
Not all stream log files written by the Reliable Transport mechanism (RT) are deleted once the stream has been replicated to the subscriber as the RT stream log archival rules are not being applied to all processes. This will cause the disk space of certain volumes associated with the kdb Insights Enterprise cluster to fill up over time. The more data that is sent through the system the faster this will occur. This may result in out of disk space issues at the producer/subscriber and in the raft cluster. We recommend that you monitor the disk usage and manually delete old stream logs regularly to prevent the disks from filling up. A tool that monitors the disk space could be used to alert you when this intervention is required (for example: Google's Cloud Watch on GCP, or Prometheus). See the section RT Logs for locations of the stream log files and how to delete old stream logs that are not longer required. 
- 
If a publisher is running and either the out directory on any of your 3 nodes in the RT cluster stops growing, or your Stream Processor is not receiving data, you should restart your publisher. To investigate the progress of messages in the RT cluster stream logs and look at the RT application logs see the section RT Logs. 
- If a user leaves trailing spaces after CLI fields, such as secrets, then the trailing spaces are preserved in the values.yaml file leading to errors on deployment. For example, kxi-certificatein below yaml:
global:
caIssuer:
name: 'kxi-certificate '
secretName: 'kxi-certificate '
- The  CLI error handling is currently limited.  If necessary use the underlying kubectl command to see the issue more clearly.  For example, to see a yaml syntax error returned by a modified  sdk_sample_assembly.yaml file, run: kubectl apply -f sdk_sample_assembly.yaml.
- 
The KX ODBC driver is not currently available for use on Windows, therefore as the Java SDK requires the ODBC driver to be installed, neither SDKs are currently available on Windows. 
- 
When using the Sample Java program, provided as part of the Java SDK, replace valFloat:float with valFloat:double in the first line of the sample.csv file before running the program. 
- The Controller expects you to call your idb, myidb, under instances if you set mounts to use different keynames than your instances an error occurs.
dap:
  instances:
    idb:
      size: 1
      mountName: myidb
      gwAssembly: insights
- Enabling .z handler metrics accumulates memory over time and may cause containers to restart if they hit their memory resource limit.
Backward Compatibility
- If you're upgrading from a previous version or the CRD is already installed, helm will not update the definition automatically. See Operator Overview Helm Warning for details on how to rectify this.
0.9.0
Beta 1 Release for kdb Insights Enterprise.
Release Date
2021-12-09
Features
[NEW] Run Python and q Machine Learning Models.
- 
Users can add a q or Python based model to the ML registry. 
- 
Users can use q to retrieve either a q or a Python based model from the ML registry. 
- 
Users can deploy a Stream Processor pipeline that includes ML models from the ML Registry. 
[NEW] Run Python functions on streaming data. Users can add Python functions into a Stream Processor pipeline to apply transformations (for example: windowing and filtering) to the streaming data.
[NEW] Support for the Kafka Schema Registry (dynamic schema updates are not yet supported).
[NEW] Users have access a single OpenAPI document. This provides documentation for the following endpoints:
- 
Service Gateway 
- 
Client Controller 
- 
Information Service 
- 
Stream Processor 
All available operations and authentication methods are documented.
[NEW] The User interface supports using ANSI SQL queries on a single database. These queries are made available via a sandbox to ensure the live database is not modified by the queries.
[NEW] Command line interface for:
- 
Installation setup. 
- 
Enrolling and removing clients. 
- 
Creating and deleting assemblies. 
- 
Querying data. 
[NEW] Login screens include KX themes
Artifacts
Known Issues
- 
Creating a pipeline in the UI that contains an Expression node must be done through the Pipeline editor, the Import screen does not allow correct configuration of an Expression node. 
- 
If one of the nodes in an RT sequencer is killed or restarts, data may no longer flow through that RT. If the issue occurs on north and south sequencer, it may be sufficient to restart the assembly. Otherwise, the cluster needs to be restarted. 
- 
RT nodes can under certain conditions consume excessive CPU causing the cluster CPU go up to >95%. If the issue occurs open a shell to the affected node(s) and kill all the pull_server processes. They will be automatically restarted and the CPU usage will drop. 
- 
RT occasionally reports an inotify error. This is a resource exhaustion issue. If the issue occurs on north and south sequencer, it may be sufficient to restart the assembly. Otherwise, the cluster needs to be restarted. 
- 
Both SQL and q queries work with assemblies. However, when running a query against a html5evalcongroup process in the UI, SQL is not supported and q must be used instead. 
- 
Programmatic OpenAPI kdb Insights client generation currently fails due to an issue with the Stream Processor. 
Backward Compatibility
- If you're upgrading from a previous version or the CRD is already installed, helm will not update the definition automatically. See Operator Overview Helm Warning for details on how to rectify this.
0.8.0
Initial Alpha Release for kdb Insights Enterprise.
Release Date
2021-10-27
Features
[NEW] Secure login & authentication using Keycloak, enabling enrollment and removal of client publishers.
[NEW] Role Based Access Control with roles for pipeline viewing and editing, access to the user interface and the ability to query data.
[NEW] Licensing is via a base install key.
[NEW] Data ingestion via:
- 
Publishing from the RT command line interface. 
- 
Reading from Kafka. 
- 
Publishing using direct qIPC. 
- 
Batch ingestion from S3 buckets. 
[NEW] The User interface supports creation of stream processor pipelines; including data ingestion and transformation, and presentation in grids/charts. For this release, pipelines can be published, but drafts are only saved to the user’s browser - not to kdb Insights Enterprise.
[NEW] Data transformations can use q
[NEW] Data transformations can use a limited Python API (built on embedPy)
[NEW] Data can be streamed out via Kafka.
[NEW] Data can be visualized using the kdb Insights user interface
[NEW] Data stored in the kdb databases can be accessed via:
- 
The user interface using q 
- 
A REST API 
[NEW] Application Metrics can be generated which can be monitored via Prometheus and Grafana.
Artifacts
| type | location | 
|---|---|
| infrastructure | https://nexus.dl.kx.com/repository/kx-insights-packages/kxi-terraform/0.1.7/kxi-terraform-0.1.7.tgz | 
| installation | https://nexus.dl.kx.com/repository/kx-insights-charts/insights-0.8.0.tgz | 
Known Issues
- 
On AWS - deployment of infrastructure needs to be targeted at a region that has 3 availability zones - see https://aws.amazon.com/about-aws/global-infrastructure/regions_az/ 
- 
On AWS(us-east-2) - Due to an issue specific to us-east-2 terraform tries to fetch ec2 information by hitting ec2.us-east-2.amazonaws.com normally this url should return a single public ip address but within an ec2 instance on us-east-2 region it returns 3 private ips which are not accessible via https. For this reason the application should not be deployed to us-east-2. 
0.10.0
Beta 2 Release for kdb Insights Enterprise.
Release Date
2022-02-04
Features
[NEW] Support for the Kafka Schema Registry has been extended to include dynamic schema updates.
[NEW] Defining ML models can be done using Python.
- 
Users can use Python to retrieve either a q or a Python based model from the ML registry. 
- 
Users can use Python to save either a q or a Python based model from the ML registry. 
[NEW] The ANSI SQL support has been extended to include distributed databases. Currently joins are not supported and tables with the same names in different databases MUST have the same columns and properties. As in the previous release these queries are made available via a sandbox to ensure the live database is not modified by the queries.
[NEW] REST API getData function has been enhanced to include:
- Basic aggregation functions on individual columns (for example: min, max, avg, stdev)
- Racking and Filling
- Filtering
- Time range options, including temporaility
[NEW] Schemas, Streams and Databases can be created and deleted in the kdb Insights Enterprise user interface.
[NEW] KX ODBC driver for data ingestion. Enabling data ingestion by applications that support ODBC.
[NEW] KX Java SDK for data ingestion.
Artifacts
| type | location | 
|---|---|
| infrastructure | kxi-terraform-0.1.12.tgz | 
| installation | insights-0.10.0.tgz | 
| cli | kxicli-0.2.0-py3-none-any.whl | 
| operator | kxi-operator-0.2.0-rc.19.tgz | 
| ODBC driver RPM package | kodbc-0.1.52-rhel.x86_64.rpm | 
| ODBC driver Debian | kodbc-0.1.52.deb | 
| ODBC driver Windows executable | kodbc-0.1.52.exe | 
| ODBC driver Windows msi | kodbc-0.1.52.msi | 
| ODBC driver sample program | kodbc-0.1.52.zip | 
| Java SDK | rt_client-1.0.0rc6.jar | 
| Java SDK sample program | rtdemo-1.0.0rc6-all.jar | 
| Java SDK sample csv file | sample.csv | 
Known Issues
- 
The sample assembly yaml files provided specify the same subTopic: "data". To start multiple assemblies in parallel, change the subTopic to a unique value, such as subTopic: "odbc-assembly". The corresponding change will also need to be made when enrolling the client. For example: curl https://${INSIGHTS_HOSTNAME}/clientcontroller/enrol -H "Authorization: Bearer " -d '{ "name": "my-client", "topics": { "insert": "odbc-assembly", "query": "requests" }}' 
- 
The UI may produce pop-up error messages in various scenarios. 
- 
The UI does not have Reports available. 
- 
kdb Insights CLI error handling is currently basic. If the CLI throws a stack trace, use the underlying kubectl command to see the issue more clearly. For example, to see a yaml syntax error returned by a modified basic_assembly.yaml file, run: kubectl apply -f basic_assembly.yaml.
- KX ODBC driver and Java SDK do not work when using kdb Insights Enterprise installed on an AWS cluster.
Backward Compatibility
- If you're upgrading from a previous version or the CRD is already installed, helm will not update the definition automatically. See Operator Overview Helm Warning for details on how to rectify this.