New
- UI improvements to the backfill partition selector
- Enabled sorting of steps by failure in the partition run matrix in Dagit
Bugfixes
- [dagstermill] fixes an issue with output notebooks and s3 storage
- [dagster_celery] bug fixed in pythonpath calculation (thanks @enima2648!)
- [dagster_pandas] marked create_structured_dataframe_type and ConstraintWithMetadata as experimental APIs
- [dagster_k8s] reduced default job backoff limit to 0
Docs
- Various docs site improvements
Breaking Changes
- When using the configuredAPI on a solid or composite solid, a new solid name must be provided.
- The image used by the K8sScheduler to launch scheduled executions is now specified under the “scheduler” section of the Helm chart (previously under “pipeline_run” section).
New
- Added an experimental mode that speeds up interactions in dagit by launching a gRPC server on startup for each repository location in your workspace. To enable it, add the following to your dagster.yaml:
opt_in:
  local_servers: true
- Intermediate Storage and System Storage now default to the first provided storage definition when no configuration is provided. Previously, it would be necessary to provide a run config for storage whenever providing custom storage definitions, even if that storage required no run configuration. Now, if the first provided storage definition requires no run configuration, the system will default to using it.
- Added a timezone picker to Dagit, and made all timestamps timezone-aware
- Added solid_config to hook context which provides the access to the config schema variable of the corresponding solid.
- Hooks can be directly set on PipelineDefinitionor@pipeline, e.g.@pipeline(hook_defs={hook_a}). It will apply the hooks on every single solid instance within the pipeline.
- Added Partitions tab for partitioned pipelines, with new backfill selector.
Breaking Changes
- Removed deprecated --envflag from CLI
- The --hostCLI param has been renamed to--grpc_hostto avoid conflict with the dagit--hostparam.
New
- Descriptions for solid inputs and outputs will now be inferred from doc blocks if available (thanks @AndersonReyes !)
- Various documentation improvements (thanks @jeriscc !)
- Load inputs from pyspark dataframes (thanks @davidkatz-il !)
- Added step-level run history for partitioned schedules on the schedule view
- Added great_expectations integration, through the dagster_gelibrary. Example usage is under a new example, calledge_example, and documentation for the library can be found under the libraries section of the api docs.
- PythonObjectDagsterTypecan now take a tuple of types as well as a single type, more closely mirroring- isinstanceand allowing Union types to be represented in Dagster.
- The configuredAPI can now be used on all definition types (includingCompositeDefinition). Example usage has been updated in the configuration documentation.
- Updated Helm chart to include auto-generated user code configmap in user code deployment by default
Bugfixes
- Databricks now checks intermediate storage instead of system storage
- Fixes a bug where applying hooks on a pipeline with composite solids would flatten the top-level solids. Now applying hooks on pipelines or composite solids means attaching hooks to every single solid instance within the pipeline or the composite solid.
- Fixes the GraphQL playground hosted by dagit
- Fixes a bug where K8s CronJobs were stopped unnecessarily during schedule reconciliation
Experimental
- New dagster-k8s/configtag that lets users pass in custom configuration to the KubernetesJob,Jobmetadata,JobSpec,PodSpec, andPodTemplateSpecmetadata.- This allows users to specify settings like eviction policy annotations and node affinities.
- Example:
   @solid(
    tags = {
      'dagster-k8s/config': {
        'container_config': {
          'resources': {
            'requests': { 'cpu': '250m', 'memory': '64Mi' },
            'limits': { 'cpu': '500m', 'memory': '2560Mi' },
          }
        },
        'pod_template_spec_metadata': {
          'annotations': { "cluster-autoscaler.kubernetes.io/safe-to-evict": "true"}
        },
        'pod_spec_config': {
          'affinity': {
            'nodeAffinity': {
              'requiredDuringSchedulingIgnoredDuringExecution': {
                'nodeSelectorTerms': [{
                  'matchExpressions': [{
                    'key': 'beta.kubernetes.io/os', 'operator': 'In', 'values': ['windows', 'linux'],
                  }]
                }]
              }
            }
          }
        },
      },
    },
  )
  def my_solid(context):
    context.log.info('running')
 
 
Breaking Changes
- The --envflag no longer works for thepipeline launchorpipeline executecommands. Use--configinstead.
- The pipeline executecommand no longer accepts the--workspaceargument.
To execute pipelines in a workspace, usepipeline launchinstead.
New
- Added ResourceDefinition.mock_resourcehelper for magic mocking resources. Example usage can be found here
- Remove the row_countmetadata entry from the Dask DataFrame type check (thanks @kinghuang!)
- Add orientto the config options when materializing a Dask DataFrame tojson(thanks @kinghuang!)
Bugfixes
- Fixed a bug where applying configuredto a solid definition would overwrite inputs from run config.
- Fixed a bug where pipeline tags would not apply to solid subsets.
- Improved error messages for repository-loading errors in CLI commands.
- Fixed a bug where pipeline execution error messages were not being surfaced in Dagit.
Bugfixes
- Fixes an issue in the dagster-k8s-celeryexecutor when executing solid subsets
Breaking Changes
- Deprecated the IntermediateStoreAPI.IntermediateStoragenow wraps an ObjectStore, andTypeStoragePluginnow accepts anIntermediateStorageinstance instead of anIntermediateStoreinstance. (Noe thatIntermediateStoreandIntermediateStorageare both internal APIs that are used in some non-core libraries).