Skip to content

Julia installer and version multiplexer

License

Notifications You must be signed in to change notification settings

christiangnrd/juliaup

 
 

Repository files navigation

Juliaup - Julia version manager

This repository contains a cross-platform installer for the Julia programming language.

The installer also bundles a full Julia version manager called juliaup. One can use juliaup to install specific Julia versions, it alerts users when new Julia versions are released and provides a convenient Julia release channel abstraction.

Status

This installer is considered production ready.

Installation

On all platforms it is recommended that you first uninstall any previous Julia versions and undo any modifications you might have made to put julia on the PATH before you install Julia with the installer in this repository.

Windows

On Windows Julia and Juliaup can be installed directly from the Windows store here. One can also install exactly the same version by executing

winget install julia -s msstore

on a command line.

If the Windows Store is blocked on a system, we have an alternative MSIX App Installer based setup. Note that this is currently experimental, please report back successes and failures here. To use the App Installer version, download this file and open it by double clicking on it.

If neither the Windows Store nor the App Installer version work on your Windows system, you can also use a MSI based installer. Note that this installation methods comes with serious limitations and is generally not recommended unless no other method works. For example, there is no automatic update mechanism for Juliaup with this installation method. The 64 bit version of the MSI installer can be downloaded from here and the 32 bit version from here. By default the install will be a per-user install that does not require elevation. You can also do a system install by running the following command from a shell:

msiexec /i <PATH_TO_JULIA_MSI> ALLUSERS=1

Mac, Linux, and FreeBSD

Juliaup can be installed on Unix-like platforms (currently Linux, Mac, or FreeBSD) by executing

curl -fsSL https://install.julialang.org | sh

in a shell.

Command line arguments

One can pass various command line arguments to the Julia installer. The syntax for installer arguments is

curl -fsSL https://install.julialang.org | sh -s -- <ARGS>

Here <ARGS> should be replaced with one or more of the following arguments:

  • --yes (or -y): Run the installer in a non-interactive mode. All configuration values use their default.
  • --default-channel <NAME>: Configure the default channel. For example --default-channel lts would install the lts channel and configure it as the default.
  • --path (or -p): Install juliaup in a custom location.

Software Repositories

Important note: As of now, we strongly recommend to install Juliaup via the Windows Store or curl command above rather than through OS-specific software repositories (see below) as the Juliaup variants provided by the latter currently have some drawbacks (that we hope to lift in the future).

brew install juliaup
Arch Linux - AUR

On Arch Linux, Juliaup is available in the Arch User Repository (AUR) in two packages.

  1. juliaup (locally built)
  2. juliaup-bin (binary from github releases)

On openSUSE Tumbleweed, Juliaup is available. To install, run with root privileges:

zypper install juliaup

On Solus, Juliaup is available. To install, run with root privileges:

eopkg install juliaup

To install via Rust's cargo, run:

cargo install juliaup

Continuous Integration (CI)

If you use GitHub Actions as your CI provider, you can use the julia-actions/install-juliaup action to install Juliaup in CI.

Using Juliaup

Once you have installed Juliaup, julia is on the PATH, and on Windows there is a start menu shortcut and it will show up as a profile in Windows Terminal. Any of those will start Julia. The VS Code extension will also automatically find this Julia installation.

Here are some of the things you can do with juliaup:

  • juliaup list lists all the available channels.
  • juliaup update installs the latest available Julia version for all your channels.
  • juliaup update release updates the release channel to the latest version.
  • juliaup status shows you which Julia versions you have installed and which one is configured as the default.
  • juliaup add 1.5.1 adds Julia 1.5.1 to your system (it can then be launched via the command julia +1.5.1).
  • juliaup default 1.5.3 configures the julia command to start Julia 1.5.3.
  • juliaup default 1.6 configures the julia command to start the latest 1.6.x version of Julia you have installed on your system (and inform you if there is a newer version in 1.6.x available).
  • juliaup default release configures the julia command to start the latest stable version of Julia (this is also the default value).
  • juliaup remove 1.5.3 deletes Julia 1.5.3 from your system.
  • juliaup add 1.6.1~x86 installs the 32 bit version of Julia 1.6.1 on your system.
  • juliaup default 1.6~x86 configures the julia command to start the latest 1.6.x 32 bit version of Julia you have installed on your system.
  • juliaup link dev ~/juliasrc/julia configures the dev channel to use a binary that you provide that is located at ~/juliasrc/julia. You can then use dev as if it was a system provided channel, i.e. make it the default or use it with the + version selector. You can use other names than dev and link as many versions into juliaup as you want.
  • juliaup self update installs the latest version, which is necessary if new releases reach the beta channel, etc.
  • juliaup self uninstall uninstalls Juliaup. Note that on some platforms this command is not available, in those situations one should use platform specific methods to uninstall Juliaup.
  • juliaup override status shows all configured directory overrides.
  • juliaup override set lts sets a directory override for the current working directory to the lts channel.
  • juliaup override unset removes a directory override for the current working directory.
  • juliaup override set --path foo/bar lts sets a directory override for the path foo/bar to the lts channel.
  • juliaup override unset --path foo/bar removes a directory override for the path foo/bar.
  • juliaup override unset --nonexistent removes all directory overrides for paths that no longer exist.
  • juliaup shows you what other commands are available.

The available system provided channels are:

  • release: always points to the latest stable version.
  • lts: always points to the latest long term supported version.
  • alpha: always points to the latest alpha version if one exists. If a newer beta or release candidate exists, it will point to that, and if there is no alpha, beta, or rc candidate available it will point to the same version as the release channel.
  • beta: always points to the latest beta version if one exists. If a newer release candidate exists, it will point to that, and if there is neither a beta or rc candidate available it will point to the same version as the release channel.
  • rc: same as beta, but only starts with release candidate versions.
  • nightly: always points to the latest build from the master branch in the Julia repository.
  • pr{number} (e.g. pr123): points to the latest successful build of a PR branch (https://github.com/JuliaLang/julia/pull/{number}). Only available if CI has recently and successfully built Julia on that branch.
  • specific versions, e.g. 1.5.4.
  • minor version channels, e.g. 1.5.
  • major version channels, e.g. 1.

All of these channels can be combined with the ~x86, ~x64 or ~aarch64 suffix to download a specific platform version.

Using installed Julia versions

To launch the default Julia version simply run julia in your terminal.

To launch a specific Julia version, say in channel release, run julia +release.

Overrides

The Julia launcher julia automatically determines which specific version of Julia to launch. There are several ways to control and override which Juliaup channel should be used:

  1. A command line Julia version specifier, such as julia +release.
  2. The JULIAUP_CHANNEL environment variable.
  3. A directory override, set with the juliaup override set command.
  4. The default Juliaup channel.

The channel is used in the order listed above, using the first available option.

Path used by Juliaup

Juliaup will by default use the Julia depot at ~/.julia to store Julia versions and configuration files. This can be changed by setting the JULIAUP_DEPOT_PATH environment variable. Caution: Previous versions of Juliaup used the content of the environment variable JULIA_DEPOT_PATH to locate Juliaup files, the current version changed this behavior and no longer depends on JULIA_DEPOT_PATH.

Juliaup server

Juliaup by default downloads julia binary tarballs from the official server "https://julialang-s3.julialang.org". If requested, the environment variable JULIAUP_SERVER can be used to tell Juliaup to use a third-party mirror server.

Shell completions

To generate shell completions, load COMPLETE=$SHELL juliaup at shell launch. For example, with bash, it could look like source <(COMPLETE=bash juliaup).

For more specific information on adding completions to your shell, see https://docs.rs/clap_complete/latest/clap_complete/env/index.html

Note: MacOS ships with an ancient version of bash that does not support process substitution. To work around this, you can create a temporary file and source that instead like:

COMPLETE=bash juliaup > /tmp/juliaup_completion.sh
source /tmp/juliaup_completion.sh

Development guides

For juliaup developers, information on how to build juliaup locally, update julia versions, and release updates can be found in the wiki https://github.com/JuliaLang/juliaup/wiki

To use unstable preview versions of juliaup (e.g. to get a patch before it makes it into the latest release), use

curl -fsSL https://install.julialang.org/releasepreview | sh

More information

This JuliaCon 2021 talk is a short introduction to Juliaup. Note that the video was recorded before the Linux and Mac versions were finished, but all the information about juliaup itself applies equally on Linux and Mac.

This JuliaCon 2022 talk provides some background on the design of Juliaup.

About

Julia installer and version multiplexer

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Rust 84.4%
  • Shell 9.0%
  • Julia 5.0%
  • PowerShell 1.6%