crouton is a set of scripts that bundle up into an easy-to-use, Chromium OS-centric chroot generator. Ubuntu, Debian, and Kali are supported (using debootstrap behind the scenes), but "Chromium OS Debian and Ubuntu (plus one distro) EOL'd Chroot Environment" doesn't acronymize as well (crodupodece is admittedly pretty fun to say, though).
All good things must come to an end, and considering
- Chromium OS's introduction of increasingly strict shell safeguards,
- the change in cras's build tools,
- the removal of manifest v2 extensions,
- the removal of PNaCl, breaking xiwi,
- oh, and Chromium OS being replaced by Android
there's really not much to gain from continued development. Put another way, the proverbial mixed salad is just about out of tasty crunchy bits, and the remaining morsels have gone a bit stale. And for some reason someone's about to swap all the lettuce out for onion rings? Point is, it's time to stop mixing dressings. Unless it's ranch, I guess, since that goes with just about anything. But this is crouton, not some Ready-for-Android Native Chroot Host, alas.
Anyway, this means that:
- The repo is now locked, and no further changes will be considered.
- Eventually someone will want the latest Ubuntu added to the release list. See this commit for an example of how to do it on your own copy.
- Sometime around July 2025, the GitHub project will be archived, making the issue tracker, discussions, and wiki read-only.
- For the safety of users and stability of crouton's functionality for those on EOL devices, offers to take over the dnschneid/crouton repo or extension will be declined, and requests to change link destinations will be rejected.
If you have an EOL device, though, crouton is still a great match for you!
- Chromium OS version 110 and earlier, everything should work! Breathe new life into your old devices!!
- Starting 111, crouton can't compile cras, so audio devices cannot be shared with Chromium OS
- Starting 117, sudo in crosh is disabled and you'll need to use VT-2
- Starting 133 (139 for enterprise devices), manifest v2 is disabled and you won't be able to run the extension (easy switching, clipboard sync, xiwi)
- Also starting 133 (139 for enterprise devices), pnacl is disabled, so even if you somehow got the extension working, xiwi won't function
- Beyond that, it's anybody's guess as to what will break
Chromium OS has introduced several security features over the years that impede the installation and usage of crouton. If your device is no longer receiving updates, the steps below will likely work for you. However, if you are still having trouble, please try the community-maintained instructions.
In addition, goo.gl is going away! That means the goo.gl/fd3zc you know and love has been replaced with git.io/JZEs0. That's a zero at the end, if you were wondering. Both just point to github, so you can always just memorize the full link instead, which (fun fact) does not include any numbers at all!
It stands for ChRomium Os Universal chrooT envirONment ...or something like that. Do capitals really matter if caps-lock has been (mostly) banished, and the keycaps are all lower-case?
Moving on...
Anyone who wants to run straight Linux on their Chromium OS device, and doesn't care about physical security. You're also better off having some knowledge of Linux tools and the command line in case things go funny, but it's not strictly necessary.
Like virtualization, chroots provide the guest OS with their own, segregated file system to run in, allowing applications to run in a different binary environment from the host OS. Unlike virtualization, you are not booting a second OS; instead, the guest OS is running using the Chromium OS system. The benefit to this is that there is zero speed penalty since everything is run natively, and you aren't wasting RAM to boot two OSes at the same time. The downside is that you must be running the correct chroot for your hardware, the software must be compatible with Chromium OS's kernel, and machine resources are inextricably tied between the host Chromium OS and the guest OS. What this means is that while the chroot cannot directly access files outside of its view, it can access all of your hardware devices, including the entire contents of memory. A root exploit in your guest OS will essentially have unfettered access to the rest of Chromium OS.
...but hey, you can run TuxRacer!
Crostini is an official project within Chromium OS to bring the Linux shell and apps to the platform in verified mode with clean integration, multi-layered security, and all the polish you expect from Chromium OS proper.
That means compared to crouton, Crostini has official support, competent engineers, and code that looks a little less like ramen. crouton, in its defense, has wider device compatibility, enables direct hardware access, and is named after an objectively tastier bread-based food item.
There's a solid community on Reddit if you'd like to try Crostini out. If it works for you -- great! No hard feelings. If in the end you decide that crouton suits you better, read on!
Note: you can't get the best of both worlds by installing crouton inside of Crostini. The technology (and life itself) just doesn't work that way. Not to mention a crouton Crostini would look ridiculous and be impossible to eat without getting bits everywhere.
You need a device running Chromium OS that has been switched to developer mode.
For instructions on how to do that, go to this Chromium OS wiki page, click on your device model and follow the steps in the Entering Developer Mode section.
Note that developer mode, in its default configuration, is completely insecure, so don't expect a password in your chroot to keep anyone from your data. crouton does support encrypting chroots, but the encryption is only as strong as the quality of your passphrase. Consider this your warning.
It's also highly recommended that you install the crouton extension,
which, when combined with the extension or xiwi targets, provides much
improved integration with Chromium OS.
That's it! Surprised?
crouton is a powerful tool, and there are a lot of features, but basic usage is as simple as possible by design.
If you're just here to use crouton, you can grab the latest release from
https://git.io/JZEs0. Download it, pop open a
shell (Ctrl+Alt+T, type shell and hit enter), make the installer executable
with sudo install -Dt /usr/local/bin -m 755 ~/Downloads/crouton, then launch
it with sudo crouton to see the help text. See the "examples" section for some
usage examples.
If you're modifying crouton, you'll probably want to clone or download the repo
into a subdirectory of /usr/local and then either run installer/main.sh
directly, or use make to build your very own crouton. You can also download
the latest release, install it as above and run crouton -x to extract out the
juicy scripts contained within, but you'll be missing build-time stuff like the
Makefile. You also need to remember to place the unbundled scripts somewhere in
/usr/local in order to be able to execute them.
crouton uses the concept of "targets" to decide what to install. While you will
have apt-get in your chroot, some targets may need minor hacks to avoid issues
when running in the chrooted environment. As such, if you expect to want
something that is fulfilled by a target, install that target when you make the
chroot and you'll have an easier time.  Don't worry if you forget to include a
target; you can always update the chroot later and add it. You can see the list
of available targets by running crouton -t help.
Once you've set up your chroot, you can easily enter it using the
newly-installed enter-chroot command, or one of the target-specific
start* commands. Ta-da! That was easy.
- Download crouton
- Open a shell (Ctrl+Alt+T, type shelland hit enter)
- Copy the installer to an executable location by running
sudo install -Dt /usr/local/bin -m 755 ~/Downloads/crouton
- Now that it's executable, run the installer itself: sudo crouton -t xfce
- Wait patiently and answer the prompts like a good person.
- Done! You can jump straight to your Xfce session by running
sudo enter-chroot startxfce4or, as a special shortcut,sudo startxfce4
- Cycle through Chromium OS and your running graphical chroots using Ctrl+Alt+Shift+Back and Ctrl+Alt+Shift+Forward.
- Exit the chroot by logging out of Xfce.
- Add the -eparameter when you run crouton to create an encrypted chroot or encrypt a non-encrypted chroot.
- You can get some extra protection on your chroot by storing the decryption
key separately from the place the chroot is stored. Use the -kparameter to specify a file or directory to store the keys in (such as a USB drive or SD card) when you create the chroot. Beware that if you lose this file, your chroot will not be decryptable. That's kind of the point, of course.
- The -rparameter specifies which distro release you want to use.
- Run crouton -r listto list the recognized releases and which distros they belong to.
- Install the crouton extension into Chromium OS.
- Add the extensionorxiwiversion to your chroot.
- Try some copy-pasta, or uninstall all your web browsers from the chroot.
Installing the extension and its target gives you synchronized clipboards, the option of using Chromium OS to handle URLs, and allows chroots to create graphical sessions as Chromium OS windows.
- You can save a chunk of space by ditching X and just installing
command-line tools using -t coreor-t cli-extra
- Enter the chroot in as many crosh shells as you want simultaneously using
sudo enter-chroot
- Use the Crosh Window extension to keep Chromium OS from eating standard keyboard shortcuts.
- If you installed cli-extra, startcliwill launch a new VT right into the chroot.
- Exit the chroot if you have it open.
- If you haven't already, download crouton, and copy it so it works:sudo install -Dt /usr/local/bin -m 755 ~/Downloads/crouton
- Update your chroot with sudo crouton -u -n chrootname. It will update all installed targets.
- Add 'xiwi' or any other target to an existing chroot with the -uoption:sudo crouton -t xiwi -u -n chrootname
This will also make 'xiwi' the default xmethod.
- If you want to keep the 'xorg' xmethod as the default then pick it first:
sudo sh crouton -t xorg,xiwi -u -n chrootname
- sudo edit-chroot -b chrootnamebacks up your chroot to a timestamped tarball in the current directory. Chroots are named either via the- -nparameter when created or by the release name if -n was not specified.
- sudo edit-chroot -r chrootnamerestores the chroot from the most recent timestamped tarball. You can explicitly specify the tarball with- -f
- If your machine is new, powerwashed, or held upside-down and shaken, you
can use the crouton installer to restore a chroot and relevant scripts:
sudo crouton -f mybackup.tar.gz
Unlike with Chromium OS, the data in your chroot isn't synced to the cloud.
- Check out the edit-chrootcommand; it likely does what you need it to do.
- If you set a Chromium OS root password, you can change it with
sudo chromeos-setdevpasswd
- You can change the password inside your chroot with passwd
- Use -pto specify the directory in which to install the chroot and scripts. Be sure to quote or escape spaces.
- When entering the chroot for the first time each boot, you will first need
to ensure the place you've installed the scripts is in a place that allows
executables to run. Determine the mountpoint by running
df --output=target /path/to/enter-chroot, then mark the mount exec withsudo mount -o remount,exec /path/to/mountpoint.
- You can then launch the chroot by specifying the full path of any of the
enter-chroot or start* scripts (i.e. sudo /path/to/enter-chroot), or use the-cparameter to explicitly specify the chroots directory.
If for some reason you have to run the installer without touching the local
disk, you can (for the time being) run
curl -fL https://git.io/JZEs0 | sudo sh -s -- options_for_crouton_installer.
Note that this will definitely break in the near future, so don't depend on it.
- Download crouton
- Open a shell (Ctrl+Alt+T, type shelland hit enter)
- Copy the installer to an executable location by running
sudo install -Dt /usr/local/bin -m 755 ~/Downloads/crouton
- Now that it's executable, use the installer to build a bootstrap tarball:
sudo crouton -d -f ~/Downloads/mybootstrap.tar.bz2
- Include the -rparameter if you want to specify for which release to prepare a bootstrap.
- You can then create chroots using the tarball by running
sudo crouton -f ~/Downloads/mybootstrap.tar.bz2. Make sure you also specify the target environment with-t.
This is the quickest way to create multiple chroots at once, since you won't have to determine and download the bootstrap files every time.
- You can make your own target files (start by copying one of the existing
ones) and then use them with any version of crouton via the -Tparameter.
This is great for automating common tasks when creating chroots.
- The delete-chroot command is your sword, shield, and only true friend.
sudo delete-chroot evilchroot
- It's actually just a shortcut to sudo edit-chroot -d evilchroot, which I suppose makes it a bit of a deceptive Swiss Army knife friend...still good?
- Chroots are cheap! Create multiple ones using -n, break them, then make new, better ones!
- You can change the distro mirror from the default by using -m
- Want to use a proxy? -Plets you specify one (or disable it).
- A script is installed in your chroot called brightness. You can assign this to keyboard shortcuts to adjust the brightness of the screen (e.g.brightness up) or keyboard (e.g.brightness k down).
- Multiple monitors will work fine in the chroot, but you may have to switch to Chromium OS and back to enable them.
- You can make commands run in the background so that you can close the
terminal. This is particularly useful for desktop environments: try running
sudo startxfce4 -b
- Want to disable Chromium OS's power management? Run croutonpowerd -i
- Only want power management disabled for the duration of a command?
croutonpowerd -i command and argumentswill automatically stop inhibiting power management when the command exits.
- Have a Pixel or two or 4.352 million? -t touchimproves touch support.
- Want to share some files and/or folders between Chromium OS and your chroot?
Check out the /etc/crouton/sharesfile, or read all about it in the wiki.
- Want more tips? Check the wiki.
Running another OS in a chroot is a pretty messy technique (although it's hidden
behind very pretty scripts), and while these scripts are relatively mature,
Chromium OS is changing all the time so problems are not surprising. Check the
issue tracker and file a bug if your issue isn't there. When filing a new bug,
include the output of croutonversion run from inside the chroot or, if you
cannot mount your chroot, include the output of cat /etc/lsb-release from Crosh.
That's great! But before your code can be merged, you'll need to have signed the Individual Contributor License Agreement. Don't worry, it only takes a minute and you'll definitely get to keep your firstborn, probably. If you've already signed it for contributing to Chromium or Chromium OS, you're already done.
If you don't know what to do with your time as an official Contributor, keep in mind that crouton is maintenance-only and will only be accepting a limited amount of changes. That having been said, here's some suggestions:
- Really like a certain desktop environment? Fork crouton, add the target, and let people know in the discussions area.
- Is your distro underrepresented? Want to contribute to the elusive and mythical beast known as "croagh"? Fork crouton, add the distro, and people will come.
- Discovered a bug lurking within the scripts, or a papercut that bothers you just enough to make you want to actually do something about it? You guessed it: fork crouton, fix everything, and create a pull request.
- Are most bugs too high-level for you to defeat? Grind up some EXP by using your fork to eat pie.
Yes!
There's a way For Everyone to help!
- Something broken? File a bug! Bonus points if you try to fix it. It helps if
you provide the output of croutonversion(or the output ofcat /etc/lsb-releasefrom Crosh) when you submit the bug.
- Look through open issues and see if there's a topic or application you happen to have experience with. And then, preferably, share that experience with others.
- Find issues that need wiki entries and add the relevant info to the wiki. Or just add things to/improve things in the wiki in general, but do try to keep it relevant and organized.
- Really like a certain desktop environment, but not up for coding? Open or comment on a bug with steps to get things working well.
crouton (including this eloquently-written README) is copyright © 2016 The crouton Authors. All rights reserved. Use of the source code included here is governed by a BSD-style license that can be found in the LICENSE file in the source tree.