Skip to content

Latest commit

 

History

History

dart

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Quick reference

Supported tags and respective Dockerfile links

Quick reference (cont.)

What is Dart?

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).

Using this image

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).

Creating a Dart server app

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

Running the server with Docker Desktop

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

Image documentation

Dockerfile

The Dockerfile created by the dart tool performs two steps:

  1. Using the Dart SDK in the dart:stable image, compiles your server (bin/server.dart) to an executable (server).

  2. 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"]

.dockerignore

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.

License

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.