[ui] Improved performance for loading assets that are part of big asset graphs.
[ui] Improved performance for loading job backfills that have thousands of partitions
[ui] The code location page can now be filtered by status
[agent] K8s and ECS agent main loop writes a sentinel file that can be used for liveness checks.
[agent][experimental] ECS CloudFormation template with private IP addresses using NAT Gateways, security groups, IAM role separation, tighter permissions requirements, and improved documentation.
Ephemeral asset jobs are now supported in run status sensors (thanks @the4thamigo-uk)!
In AssetsDefinition construction, enforce single key per output name
Fixed a bug where freshness checks on assets with both observations and materializations would incorrectly miss a materialization if there’s no observation with dagster/last_updated_timestamp.
Fixed a bug with anomaly detection freshness checks where “not enough records” result would cause the sensor to crash loop.
Fixed a bug that could cause errors in the Asset Daemon if an asset using AutoMaterializeRule.skip_on_not_all_parents_updated_since_cron() rule gained a new dependency with a different PartitionsDefinition.
[ui] Fixed an issue that caused the backfill page not to be scrollable.
[ui] Fixed an issue where filtering by partition on the Runs page wouldn’t work if fetching all of your partitions timed out.
[dagster-dlt] Fixed bug with dlt integration in which partitioned assets would change the file name when using the filesystem destination.
[ui] Fixed an issue where an erroring code location would cause multiple toast popups.
Allow a string to be provided for source_key_prefix arg of load_assets_from_modules. (thanks @drjlin)!
Added a missing debug level log message when loading partitions with polars (thanks Daniel Gafni)!
Set postgres timeout via statement, which improves storage-layer compatibility with Amazon RDS (thanks @james lewis)!
In DBT integration, quote the table identifiers to handle cases where table names require quotes due to special characters. (thanks @alex launi)!
remove deprecated param usage in dagster-wandb integration (thanks @chris histe)!
Add missing QUEUED state to DatabricksRunLifeCycleState (thanks @gabor ratky)!
Fixed a bug with dbt-cloud integration subsetting implementation (thanks @ivan tsarev)!
The dagster-cloud ci init CLI will now use the --deployment argument as the base deployment when creating a branch deployment. This base deployment will be used for Change Tracking.
The BigQuery dbt insights wrapper dbt_with_bigquery_insights now respects CLI arguments for profile configuration and also selects location / dataset from the profile when available.
[experimental feature] Fixes a recent regression where the UI errored upon attempting to create an insights metric alert.
Asset search results now display compute and storage kind icons.
Asset jobs where the underlying assets have multiple backfill policies will no longer fail at definition time. Instead, the backfill policy for the job will use the minimum max_partitions_per_run from the job’s constituent assets.
[dagstermill] asset_tags can now be specified when building dagstermill assets
[dagster-embedded-elt] Custom asset tags can be applied to Sling assets via the DagsterSlingTranslator
[dagster-embedded-elt] dlt assets now automatically have dagster/storage_kind tags attached
tags passed to outs in graph_multi_asset now get correctly propagated to the resulting assets.
[ui] Fixed an issue in the where when multiple runs were started at the same time to materialize the same asset, the most recent one was not always shown as in progress in the asset graph in the Dagster UI.
The “newly updated” auto-materialize rule will now respond to either new observations or materializations for observable assets.
build_metadata_bounds_checks now no longer errors when targeting metadata keys that have special characters.
Updated the Schedule concept page to be a “jumping off” point for all-things scheduling, including a high-level look at how schedules work, their benefits, and what you need to know before diving in
[experimental] The backfill daemon can now store logs and display them in the UI for increased visibility into the daemon’s behavior. Please contact Dagster Labs if you are interested in piloting this experimental feature.
Added a --read-only flag to the dagster-cloud ci branch-deployment CLI command, which returns the current branch deployment name for the current code repository branch without update the status of the branch deployment.
Dagster will now display a “storage kind” tag on assets in the UI, similar to the existing compute kind. To set storage kind for an asset, set its dagster/storage_kind tag.
You can now set retry policy on dbt assets, to enable coarse-grained retries with delay and jitter. For fine-grained partial retries, we still recommend invoking dbt retry within a try/except block to avoid unnecessary, duplicate work.
AssetExecutionContext now exposes a has_partition_key_range property.
The owners, metadata, tags, and deps properties on AssetSpec are no longer Optional. The AssetSpec constructor still accepts None values, which are coerced to empty collections of the relevant type.
The docker_executor and k8s_job_executor now consider at most 1000 events at a time when loading events from the current run to determine which steps should be launched. This value can be tuned by setting the DAGSTER_EXECUTOR_POP_EVENTS_LIMIT environment variable in the run process.
Added a dagster/retry_on_asset_or_op_failure tag that can be added to jobs to override run retry behavior for runs of specific jobs. See the docs for more information.
Improved the sensor produced by build_sensor_for_freshness_checks to describe when/why it skips evaluating freshness checks.
A new “Runs” tab on the backfill details page allows you to see list and timeline views of the runs launched by the backfill.
[dagster-dbt] dbt will now attach relation identifier metadata to asset materializations to indicate where the built model is materialized to.
[dagster-graphql] The GraphQL Python client will now include the HTTP error code in the exception when a query fails. Thanks @yuvalgimmunai!
Fixed sensor logging behavior with the @multi_asset_sensor.
ScheduleDefinition now properly supports being passed a RunConfig object.
When an asset function returns a MaterializeResult, but the function has no type annotation, previously, the IO manager would still be invoked with a None value. Now, the IO manager is not invoked.
The AssetSpec constructor now raises an error if an invalid owner string is passed to it.
When using the graph_multi_asset decorator, the code_version property on AssetOuts passed in used to be ignored. Now, they no longer are.
[dagster-deltalake] Fixed GcsConfig import error and type error for partitioned assets (Thanks @thmswt)
The asset graph and asset catalog now show the materialization status of External assets (when manually reported) rather than showing “Never observed”
The ability to set a custom base deployment when creating a branch deployment has been enabled for all organizations.
When a code location fails to deploy, the Kubernetes agent now includes additional any warning messages from the underlying replicaset in the failure message to aid with troubleshooting.
Serverless deployments now support using a requirements.txt with hashes.
Fixed an issue where the dagster-cloud job launch command did not support specifying asset keys with prefixes in the --asset-key argument.
[catalog UI] Catalog search now allows filtering by type, i.e. group:, code location:, tag:, owner:.
New dagster+ accounts will now start with two default alert policies; one to alert if the default free credit budget for your plan is exceeded, and one to alert if a single run goes over 24 hours. These alerts will be sent as emails to the email with which the account was initially created.
The new build_metadata_bounds_checks API creates asset checks which verify that numeric metadata values on asset materializations fall within min or max values. See the documentation for more information.
Fixed an incompatibility between build_sensor_for_freshness_checks and Dagster Plus. This API should now work when used with Dagster Plus.
[ui] Billing / usage charts no longer appear black-on-black in Dagster’s dark mode.
[ui] The asset catalog is now available for teams plans.
[ui] Fixed a bug where the alert policy editor would misinterpret the threshold on a long-running job alert.
[kubernetes] Added a dagsterCloudAgent.additionalPodSpecConfig to the Kubernetes agent Helm chart allowing arbitrary pod configuration to be applied to the agent pod.
[ECS] Fixed an issue where the ECS agent would sometimes raise a “Too many concurrent attempts to create a new revision of the specified family” exception when using agent replicas.