Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mefellows/docker-mono-static
My public Docker images
https://github.com/mefellows/docker-mono-static
Last synced: 14 days ago
JSON representation
My public Docker images
- Host: GitHub
- URL: https://github.com/mefellows/docker-mono-static
- Owner: mefellows
- License: mit
- Created: 2015-03-19T20:44:16.000Z (almost 10 years ago)
- Default Branch: master
- Last Pushed: 2016-01-06T11:57:18.000Z (about 9 years ago)
- Last Synced: 2024-11-06T16:50:22.451Z (2 months ago)
- Size: 3.91 KB
- Stars: 3
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
## Mono Static
This image contains the full Mono development environment and a gcc environment, which can be used to create a statically compiled Mono binary.
As part of the build, it expects a `build.sh` to be present in the working directory to compile the app.
An example `buildi-app.sh` file:
```
#!/bin/bash# This is used from the CI image to compile and build the app into a static binary.
nuget restore -NonInteractivePACKAGES_DIR=$(find /usr/src/app/source/packages/ -name *.dll)
PACKAGES=""for f in $PACKAGES_DIR; do
PACKAGES="$PACKAGES $f"
doneecho "Found packages: ${PACKAGES}"
xbuild /p:Configuration=Release /property:OutDir=/usr/src/app/build/ ./console.sln
mkbundle --deps --static ./obj/x86/Release/console.exe $PACKAGES -o consoleapp
```## Usage
This image uses the `ONBUILD` Docker feature which is great for use as an intermediate / CI container to produce your static artifacts
for use in smaller containers.### Create your CI
Assuming you have the `build-app.sh` from above in the root dir, you can now build an intermediate image containing your app:Dockerfile
```
FROM mefellows/mono-staticMAINTAINER Matt Fellows
ONBUILD WORKDIR /usr/src/app/build
CMD [ "sleep", "600" ]
```This will produce a container with a compiled binary in the `/usr/src/app/build` directory with the name `consoleapp`.
Extract the binary from the container for embedding into a smaller runtime container, such as busybox:```
# Run the CI Build
docker build -t tmp-build .# Run the container
docker run -d --name tmp-build tmp-build# This is sort of a package caching mechanism
docker cp tmp-build:/usr/src/app/source/packages .# Extract static binary into distribution folder
docker cp tmp-build:/usr/src/app/source/consoleapp ./distribution/# Close off temporary container
docker rm -f tmp-build
```Now create `distribution\Dockerfile`:
```
FROM progrium/busybox
RUN opkg-install libc-dev
ADD ./consoleapp console
CMD [ "./console" ]
```You can build this with `docker build -t mefellows/mono-api distribution`
## Tutorial
See [A Nancy .NET Microservice running on Docker in under 20mb](http://www.onegeek.com.au/articles/a-nancy-net-microservice-running-on-docker-in-under-20mb) for a walkthrough.