mirror of
https://github.com/nushell/nushell
synced 2025-01-28 04:45:18 +00:00
Merge pull request #533 from vsoch/tweak/ci
Updating Docker Build instructions in README, and fixing tags for CircleCI
This commit is contained in:
commit
f81dbee5f9
3 changed files with 28 additions and 6 deletions
|
@ -116,7 +116,7 @@ workflows:
|
||||||
- run:
|
- run:
|
||||||
name: Build Multistage (smaller) container
|
name: Build Multistage (smaller) container
|
||||||
command: |
|
command: |
|
||||||
docker build -f docker/Dockerfile -t nushell/nu:devel .
|
docker build --build-arg FROMTAG=devel -f docker/Dockerfile -t nushell/nu:devel .
|
||||||
- run:
|
- run:
|
||||||
name: Publish Development Docker Tags
|
name: Publish Development Docker Tags
|
||||||
command: |
|
command: |
|
||||||
|
|
29
README.md
29
README.md
|
@ -51,19 +51,40 @@ The following optional features are currently supported:
|
||||||
|
|
||||||
## Docker
|
## 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
|
```bash
|
||||||
$ docker build -t nu .
|
$ docker pull quay.io/nushell/nu
|
||||||
|
$ docker pull quay.io/nushell/nu-base
|
||||||
```
|
```
|
||||||
|
|
||||||
And then run the container:
|
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
|
```bash
|
||||||
$ docker run -it nu
|
$ docker build -f docker/Dockerfile.nu-base -t nushell/nu-base .
|
||||||
|
```
|
||||||
|
|
||||||
|
And then to build the smaller container (using a Multistage build):
|
||||||
|
|
||||||
|
```bash
|
||||||
|
$ 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
|
/> exit
|
||||||
```
|
```
|
||||||
|
|
||||||
|
The second container is a bit smaller, if size is important to you.
|
||||||
|
|
||||||
# Philosophy
|
# 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'.
|
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'.
|
||||||
|
|
|
@ -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
|
FROM rust:1.37-slim
|
||||||
COPY --from=base /usr/local/bin/nu /usr/local/bin/nu
|
COPY --from=base /usr/local/bin/nu /usr/local/bin/nu
|
||||||
ENTRYPOINT ["nu"]
|
ENTRYPOINT ["nu"]
|
||||||
|
|
Loading…
Reference in a new issue