Merge pull request #533 from vsoch/tweak/ci

Updating Docker Build instructions in README, and fixing tags for CircleCI
This commit is contained in:
Jonathan Turner 2019-08-30 12:32:52 +12:00 committed by GitHub
commit f81dbee5f9
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 28 additions and 6 deletions

View file

@ -116,7 +116,7 @@ workflows:
- run:
name: Build Multistage (smaller) container
command: |
docker build -f docker/Dockerfile -t nushell/nu:devel .
docker build --build-arg FROMTAG=devel -f docker/Dockerfile -t nushell/nu:devel .
- run:
name: Publish Development Docker Tags
command: |

View file

@ -51,19 +51,40 @@ The following optional features are currently supported:
## Docker
Optionally, you can build a container with nu installed using the [Dockerfile](Dockerfile):
If you want to pull a pre-built container, you can browse tags for the [nushell organization](https://quay.io/organization/nushell)
on Quay.io. Pulling a container would come down to:
```bash
$ docker build -t nu .
$ docker pull quay.io/nushell/nu
$ docker pull quay.io/nushell/nu-base
```
Both "nu-base" and "nu" provide the nu binary, however nu-base also includes the source code at `/code`
in the container and all dependencies.
Optionally, you can also build the containers locally using the [dockerfiles provided](docker):
To build the base image:
```bash
$ docker build -f docker/Dockerfile.nu-base -t nushell/nu-base .
```
And then run the container:
And then to build the smaller container (using a Multistage build):
```bash
$ docker run -it nu
$ docker build -f docker/Dockerfile -t nushell/nu .
```
Either way, you can run either container as follows:
```bash
$ docker run -it nushell/nu-base
$ docker run -it nushell/nu
/> exit
```
The second container is a bit smaller, if size is important to you.
# Philosophy
Nu draws inspiration from projects like PowerShell, functional programming languages, and modern cli tools. Rather than thinking of files and services as raw streams of text, Nu looks at each input as something with structure. For example, when you list the contents of a directory, what you get back is a list of objects, where each object represents an item in that directory. These values can be piped through a series of steps, in a series of commands called a 'pipeline'.

View file

@ -1,4 +1,5 @@
FROM nushell/nu-base as base
ARG FROMTAG=latest
FROM nushell/nu-base:${FROMTAG} as base
FROM rust:1.37-slim
COPY --from=base /usr/local/bin/nu /usr/local/bin/nu
ENTRYPOINT ["nu"]