-
Maintained by:
The Dart Docker Team -
Where to get help:
the Docker Community Forums, the Docker Community Slack, or Stack Overflow
2.16.1-sdk
,2.16-sdk
,2-sdk
,stable-sdk
,sdk
,2.16.1
,2.16
,2
,stable
,latest
2.17.0-69.2.beta-sdk
,beta-sdk
,2.17.0-69.2.beta
,beta
-
Where to file issues:
https://github.com/dart-lang/dart-docker/issues -
Supported architectures: (more info)
amd64
,arm32v7
,arm64v8
-
Published image artifact details:
repo-info repo'srepos/dart/
directory (history)
(image metadata, transfer size, etc) -
Image updates:
official-images repo'slibrary/dart
label
official-images repo'slibrary/dart
file (history) -
Source of this description:
docs repo'sdart/
directory (history)
Dart is a client-optimized language for developing fast apps on any platform. Its goal is to offer the most productive programming language for multi-platform development, paired with a flexible execution runtime platform for app frameworks. For more details, see https://dart.dev.
By utilizing Dart's support for ahead-of-time (AOT) compilation to executables, you can create very small runtime images (~10 MB).
We recommend using small runtime images that leverage Dart's support for ahead-of-time (AOT) compilation to executables. This enables creating small runtime images (~10 MB).
After installing the Dart SDK, version 2.14 or later, use the dart
command to create a new server app:
$ dart create -t server-shelf myserver
If you have Docker Desktop installed, you can build and run on your machine with the docker
command:
$ docker build -t dart-server .
$ docker run -it --rm -p 8080:8080 --name myserver dart-server
When finished, you can stop the container using the name you provided:
$ docker kill myserver
The Dockerfile
created by the dart
tool performs two steps:
-
Using the Dart SDK in the
dart:stable
image, compiles your server (bin/server.dart
) to an executable (server
). -
Assembles the runtime image by combining the compiled server with the Dart VM runtime and it's needed dependencies located in
/runtime/
.
# Specify the Dart SDK base image version using dart:<version> (ex: dart:2.12)
FROM dart:stable AS build
# Resolve app dependencies.
WORKDIR /app
COPY pubspec.* ./
RUN dart pub get
# Copy app source code and AOT compile it.
COPY . .
# Ensure packages are still up-to-date if anything has changed
RUN dart pub get --offline
RUN dart compile exe bin/server.dart -o bin/server
# Build minimal serving image from AOT-compiled `/server` and required system
# libraries and configuration files stored in `/runtime/` from the build stage.
FROM scratch
COPY --from=build /runtime/ /
COPY --from=build /app/bin/server /app/bin/
# Start server.
EXPOSE 8080
CMD ["/app/bin/server"]
Additionally it creates a recommended .dockerignore
file, which enumarates files that should be omitted from the built Docker image:
.dockerignore
Dockerfile
build/
.dart_tool/
.git/
.github/
.gitignore
.packages
--
Maintained with ❤️ by the Dart team.
View license information for the software contained in this image.
As with all Docker images, these likely also contain other software which may be under other licenses (such as Bash, etc from the base distribution, along with any direct or indirect dependencies of the primary software being contained).
Some additional license information which was able to be auto-detected might be found in the repo-info
repository's dart/
directory.
As for any pre-built image usage, it is the image user's responsibility to ensure that any use of this image complies with any relevant licenses for all software contained within.