All Projects → JJ → alpine-raku

JJ / alpine-raku

Licence: GPL-3.0 license
A docker container with Raku using the minimalist distro Alpine

Programming Languages

Dockerfile
14818 projects
perl
6916 projects
Raku
181 projects

Alpine containers for Raku Test-create and publish a Docker image

Create and push to GHCR a multiarch image

A Docker container with Raku using the minimalist Linux distro Alpine, essentially the Raku baseline with zef.

It includes

  • Raku (Rakudo - NQP - MoarVM), latest version, as well as older versions in tags/subdirectories as a base image.
  • zef for module installation
  • Linenoise for REPL easiness.
  • User raku is defined from version/tag 2020.07, and the Raku process is run as a non-privileged user. zef is installed for that non-privileged user, it will not work if you use root

New images should be automatically available at Docker hub.

This comes in three flavors:

  • regular
  • gha. Main difference is that the second uses 1001 as UID for the raku user, and then theoretically can be used as a GitHub action runner.
  • multiarch, a multiarch version that includesarv/v7 arm64 and ppc64le.

Working with this container

Use

docker run -it jjmerelo/alpine-raku

to get into the raku interpreter REPL. Can also be used as a "binary" this way

docker run -t jjmerelo/alpine-raku -e "say 'hello þor'"

or you can get into the container by running

docker run -it --entrypoint sh -l -c jjmerelo/alpine-raku

You can also run external scripts via the mounted /app volume. After changing to this directory

docker run -v `pwd`:/app -it  jjmerelo/alpine-raku /app/heloþor.p6

This heloþor.p6 is the example provided in this repo, which you should have cloned or downloaded in the usual way. Check out the use of þ. Cool, isn't it? You can use any other directory instead of /app

For instance, we can create a directory this way

docker run --rm -t jjmerelo/alpine-raku -e "mkdir 'raku-app'; say 'raku-app'.IO.absolute;"

This will return

/home/raku/raku-app

And then

docker run -t -v `pwd`:/home/raku/raku-app jjmerelo/alpine-raku /home/raku/raku-app/pell.p6 6

which would return the first 6 Pell numbers. Or

docker run -t -v `pwd`:/home/raku/raku-app jjmerelo/alpine-raku /home/raku/raku-app/horadam.p6 10

which will return the 10 first elements of the Horadam sequence for p=0, q=1, r= 0.25, s=0.75.

Install new modules

Since zef is included in the image, you can use it to install new modules. You can do it by getting into the container and running the shell:

docker run -it --entrypoint="/bin/sh" jjmerelo/alpine-raku

and then

$ zef install Math::Constants

Or directly in a single command

docker run -it  --entrypoint=/bin/sh jjmerelo/alpine-raku -c "zef install Math::Sequences"

This overrides the default entrypoint and, instead, runs zef as a shell command, installing the module within the container.

More one-liners for demos

Check out the Madhava-Leibniz series that computes the digits of Pi or the binomial coefficients. Run them directly thus:

docker run -t --rm jjmerelo/alpine-raku -e "say π  - 4 * ([+]  <1 -1> <</<<  (1,3,5,7,9...10000))  "

Contributions

Contributions, suggestions and patches are welcome. Please go to the GitHub repo.

Previous versions

Previous versions of raku are available also as image tags. For instance, you can do

docker run -t jjmerelo/alpine-raku:2019.07 -e "'hello þor'.say"

to download and/or run the 2019.07 version of this container.

Additionally, a nightly tag contains a fresh image, built every night from Rakudo HEAD.

See also

The raku-test image can be used directly for tests, no need to build your own based on this one.

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].