Communities

Writing
Writing
Codidact Meta
Codidact Meta
The Great Outdoors
The Great Outdoors
Photography & Video
Photography & Video
Scientific Speculation
Scientific Speculation
Cooking
Cooking
Electrical Engineering
Electrical Engineering
Judaism
Judaism
Languages & Linguistics
Languages & Linguistics
Software Development
Software Development
Mathematics
Mathematics
Christianity
Christianity
Code Golf
Code Golf
Music
Music
Physics
Physics
Linux Systems
Linux Systems
Power Users
Power Users
Tabletop RPGs
Tabletop RPGs
Community Proposals
Community Proposals
tag:snake search within a tag
answers:0 unanswered questions
user:xxxx search by author id
score:0.5 posts with 0.5+ score
"snake oil" exact phrase
votes:4 posts with 4+ votes
created:<1w created < 1 week ago
post_type:xxxx type of post
Search help
Notifications
Mark all as read See all your notifications »
Q&A

Post History

71%
+3 −0
Q&A Run programs of normal OS from a live USB

It sounds like what you want is: There is a program installed in the regular OS on my hard drive, but I am booted into a live OS. How do I run that program? The common way to do this is to us...

posted 6mo ago by matthewsnyder‭  ·  edited 6mo ago by matthewsnyder‭

Answer
#4: Post edited by user avatar matthewsnyder‭ · 2024-07-18T23:06:13Z (6 months ago)
  • It sounds like what you want is:
  • >There is a program installed in the regular OS on my hard drive, but I am booted into a live OS. How do I run that program?
  • The common way to do this is to use [chroot](https://man.archlinux.org/man/chroot.1).
  • Linux looks for programs under certain standard paths like `/usr/bin`. If you're in a live OS, your `/usr/bin` will be on a virtual disk (which uses your RAM) and will contain programs that came with the live USB. The normal OS's files are in the `/usr/bin` of the drive, which is not active in the live OS.
  • Let's say you mounted your main OS partition at `/mnt`, so that you see `/mnt/usr/games/steam`. You can't run `steam` because Linux will look for it in `/usr` not `/mnt/usr`. If you do `chroot /mnt` this will make it so that instead of looking in `/usr`, it looks in `/mnt/usr` as if that was actually `/usr`. When you run the chroot, it will alter your shell, and everything else you run in that shell will be "inside" `/mnt` (or whatever argument you use). In your case, you would run something like:
  • ```
  • chroot /media/pop-os/$SOME_UUID/
  • ```
  • And after that, trying to do `steam` should actually execute `/media/pop-os/$SOME_UUID/usr/games/steam`
  • Chroot is a bit like running one Linux inside another. However, keep in mind that it's not like a true virtual machine, just some trickery with paths. You will still be using the kernel and device drivers of the host OS. Just the programs being executed will change. Depending on the complexity of the program you run, you may need to set up additional virtual directories like `/tmp` (chroot won't create these for you, it only covers real directories and files). This is why with just a basic chroot, GUI programs like Steam might not run, because they're not properly connected to the live OS's graphics server.
  • Arch Linux has a slightly extended version called [arch-chroot](https://man.archlinux.org/man/arch-chroot.8). This sets up some extra stuff so you don't have to do it manually. However, to use this, you'll probably need to boot from the Arch ISO, which has no graphics and might be difficult to use if you're not comfortable in the terminal. As a workaround, you can try the Manjaro ISO which has a similar `manjaro-chroot` but also comes with a GUI.
  • But if the program you are trying to run is specifically Steam or a Wine game, I think you might find that challenging. These rely on many specialized and obscure system features, and it's hard to provide all of those in a chroot, without booting into the regular OS. IMO running Steam/Wine inside chroot should be its own question, because it's very specialized and not the same as running simpler programs (CLI).
  • Normally what people do is boot from live USB, mount their hard drive, chroot into their normal system, use terminal commands to do fix it just enough to be bootable, then boot into the regular OS and troubleshoot further from there. You only really need to chroot from a live USB when the normal OS is unbootable. Once it boots, even just into a console, you don't need the live USB. As an aside, Arch Linux is even installed in the same way through a chroot, so you might find their [install guide](https://wiki.archlinux.org/title/Installation_guide) helpful. If you need a "working reference configuration", it's better to create a virtual machine inside your normal OS.
  • Good luck, and if you can narrow down to a more specific issue, try asking it as a separate question.
  • It sounds like what you want is:
  • >There is a program installed in the regular OS on my hard drive, but I am booted into a live OS. How do I run that program?
  • The common way to do this is to use [chroot](https://man.archlinux.org/man/chroot.1).
  • Linux looks for programs under certain standard paths like `/usr/bin`. If you're in a live OS, your `/usr/bin` will be on a virtual disk (which uses your RAM) and will contain programs that came with the live USB. The normal OS's files are in the `/usr/bin` of the drive, which is not active in the live OS.
  • Let's say you mounted your main OS partition at `/mnt`, so that you see `/mnt/usr/games/steam`. You can't run `steam` because Linux will look for it in `/usr` not `/mnt/usr`. If you do `chroot /mnt` this will make it so that instead of looking in `/usr`, it looks in `/mnt/usr` as if that was actually `/usr`. When you run the chroot, it will alter your shell, and everything else you run in that shell will be "inside" `/mnt` (or whatever argument you use). In your case, you would run something like:
  • ```
  • chroot /media/pop-os/$SOME_UUID/
  • ```
  • And after that, trying to do `steam` should actually execute `/media/pop-os/$SOME_UUID/usr/games/steam`
  • Chroot is a bit like running one Linux inside another. However, keep in mind that it's not like a true virtual machine, just some trickery with paths. You will still be using the kernel and device drivers of the host OS. Just the programs being executed will change. Depending on the complexity of the program you run, you may need to set up additional virtual directories like `/tmp` (chroot won't create these for you, it only covers real directories and files). This is why with just a basic chroot, GUI programs like Steam might not run, because they're not properly connected to the live OS's graphics server.
  • Arch Linux has a slightly extended version called [arch-chroot](https://man.archlinux.org/man/arch-chroot.8). This sets up some extra stuff so you don't have to do it manually. However, to use this, you'll probably need to boot from the Arch ISO, which has no graphics and might be difficult to use if you're not comfortable in the terminal. As a workaround, you can try the Manjaro ISO which has a similar `manjaro-chroot` but also comes with a GUI.
  • But if the program you are trying to run is specifically Steam or a Wine game, I think you might find that challenging. These rely on many specialized and obscure system features, and it's hard to provide all of those in a chroot, without booting into the regular OS. IMO running Steam/Wine inside chroot should be its own question, because it's very specialized and not the same as running simpler programs (CLI).
  • Normally what people do is boot from live USB, mount their hard drive, chroot into their normal system, use terminal commands to do fix it just enough to be bootable, then boot into the regular OS and troubleshoot further from there. You only really need to chroot from a live USB when the normal OS is unbootable. Once it boots, even just into a console, you don't need the live USB. As an aside, Arch Linux is even installed in the same way through a chroot, so you might find their [install guide](https://wiki.archlinux.org/title/Installation_guide) helpful. If you need a "working reference configuration", it's better to create a virtual machine inside your normal OS, or dual boot.
  • Good luck, and if you can narrow down to a more specific issue, try asking it as a separate question.
#3: Post edited by user avatar matthewsnyder‭ · 2024-07-18T23:05:58Z (6 months ago)
  • It sounds like what you want is:
  • >There is a program installed in the regular OS on my hard drive, but I am booted into a live OS. How do I run that program?
  • The common way to do this is to use [chroot](https://man.archlinux.org/man/chroot.1).
  • Linux looks for programs under certain standard paths like `/usr/bin`. If you're in a live OS, your `/usr/bin` will be on a virtual disk (which uses your RAM) and will contain programs that came with the live USB. The normal OS's files are in the `/usr/bin` of the drive, which is not active in the live OS.
  • Let's say you mounted your main OS partition at `/mnt`, so that you see `/mnt/usr/games/steam`. You can't run `steam` because Linux will look for it in `/usr` not `/mnt/usr`. If you do `chroot /mnt` this will make it so that instead of looking in `/usr`, it looks in `/mnt/usr` as if that was actually `/usr`. When you run the chroot, it will alter your shell, and everything else you run in that shell will be "inside" `/mnt` (or whatever argument you use). In your case, you would run something like:
  • ```
  • chroot /media/pop-os/$SOME_UUID/
  • ```
  • And after that, trying to do `steam` should actually execute `/media/pop-os/$SOME_UUID/usr/games/steam`
  • Chroot is a bit like running one Linux inside another. However, keep in mind that it's not like a true virtual machine, just some trickery with paths. You will still be using the kernel and device drivers of the host OS. Just the programs being executed will change. Depending on the complexity of the program you run, you may need to set up additional virtual directories like `/tmp` (chroot won't create these for you, it only covers real directories and files). This is why with just a basic chroot, GUI programs like Steam might not run, because they're not properly connected to the live OS's graphics server.
  • Arch Linux has a slightly extended version called [arch-chroot](https://man.archlinux.org/man/arch-chroot.8). This sets up some extra stuff so you don't have to do it manually. However, to use this, you'll probably need to boot from the Arch ISO, which has no graphics and might be difficult to use if you're not comfortable in the terminal. As a workaround, you can try the Manjaro ISO which has a similar `manjaro-chroot` but also comes with a GUI.
  • But if the program you are trying to run is specifically Steam or a Wine game, I think you might find that challenging. These rely on many specialized and obscure system features, and it's hard to provide all of those in a chroot, without booting into the regular OS. IMO running Steam/Wine inside chroot should be its own question, because it's very specialized and not the same as running simpler programs (CLI).
  • Normally what people do is boot from live USB, mount their hard drive, chroot into their normal system, use terminal commands to do fix it just enough to be bootable, then boot into the regular OS and troubleshoot further from there. You only really need to chroot from a live USB when the normal OS is unbootable. Once it boots, you don't need the live USB. As an aside, Arch Linux is even installed in the same way through a chroot, so you might find their [install guide](https://wiki.archlinux.org/title/Installation_guide) helpful. If you need a "working reference configuration", it's better to create a virtual machine inside your normal OS.
  • Good luck, and if you can narrow down to a more specific issue, try asking it as a separate question.
  • It sounds like what you want is:
  • >There is a program installed in the regular OS on my hard drive, but I am booted into a live OS. How do I run that program?
  • The common way to do this is to use [chroot](https://man.archlinux.org/man/chroot.1).
  • Linux looks for programs under certain standard paths like `/usr/bin`. If you're in a live OS, your `/usr/bin` will be on a virtual disk (which uses your RAM) and will contain programs that came with the live USB. The normal OS's files are in the `/usr/bin` of the drive, which is not active in the live OS.
  • Let's say you mounted your main OS partition at `/mnt`, so that you see `/mnt/usr/games/steam`. You can't run `steam` because Linux will look for it in `/usr` not `/mnt/usr`. If you do `chroot /mnt` this will make it so that instead of looking in `/usr`, it looks in `/mnt/usr` as if that was actually `/usr`. When you run the chroot, it will alter your shell, and everything else you run in that shell will be "inside" `/mnt` (or whatever argument you use). In your case, you would run something like:
  • ```
  • chroot /media/pop-os/$SOME_UUID/
  • ```
  • And after that, trying to do `steam` should actually execute `/media/pop-os/$SOME_UUID/usr/games/steam`
  • Chroot is a bit like running one Linux inside another. However, keep in mind that it's not like a true virtual machine, just some trickery with paths. You will still be using the kernel and device drivers of the host OS. Just the programs being executed will change. Depending on the complexity of the program you run, you may need to set up additional virtual directories like `/tmp` (chroot won't create these for you, it only covers real directories and files). This is why with just a basic chroot, GUI programs like Steam might not run, because they're not properly connected to the live OS's graphics server.
  • Arch Linux has a slightly extended version called [arch-chroot](https://man.archlinux.org/man/arch-chroot.8). This sets up some extra stuff so you don't have to do it manually. However, to use this, you'll probably need to boot from the Arch ISO, which has no graphics and might be difficult to use if you're not comfortable in the terminal. As a workaround, you can try the Manjaro ISO which has a similar `manjaro-chroot` but also comes with a GUI.
  • But if the program you are trying to run is specifically Steam or a Wine game, I think you might find that challenging. These rely on many specialized and obscure system features, and it's hard to provide all of those in a chroot, without booting into the regular OS. IMO running Steam/Wine inside chroot should be its own question, because it's very specialized and not the same as running simpler programs (CLI).
  • Normally what people do is boot from live USB, mount their hard drive, chroot into their normal system, use terminal commands to do fix it just enough to be bootable, then boot into the regular OS and troubleshoot further from there. You only really need to chroot from a live USB when the normal OS is unbootable. Once it boots, even just into a console, you don't need the live USB. As an aside, Arch Linux is even installed in the same way through a chroot, so you might find their [install guide](https://wiki.archlinux.org/title/Installation_guide) helpful. If you need a "working reference configuration", it's better to create a virtual machine inside your normal OS.
  • Good luck, and if you can narrow down to a more specific issue, try asking it as a separate question.
#2: Post edited by user avatar matthewsnyder‭ · 2024-07-18T23:03:17Z (6 months ago)
  • It sounds like what you want is:
  • >There is a program installed in the regular OS on my hard drive, but I am booted into a live OS. How do I run that program?
  • The common way to do this is to use [chroot](https://man.archlinux.org/man/chroot.1).
  • Linux looks for programs under certain standard paths like `/usr/bin`. If you're in a live OS, your `/usr/bin` will be on a virtual disk (which uses your RAM) and will contain programs that came with the live USB. The normal OS's files are in the `/usr/bin` of the drive, which is not active in the live OS.
  • First you have to make sure the normal OS drive/partition is mounted. In some GUI distro live USBs, you will see your drives in the file manager, and when you click they will automount at something like `/media/my_drive`. Others expect you to manually run [mount](https://man.archlinux.org/man/mount.8), which traditionally mounts at `/mnt`.
  • Let's say you mounted your main OS partition at `/mnt`, so that you see `/mnt/usr/games/steam`. You can't run `steam` because Linux will look for it in `/usr` not `/mnt/usr`. If you do `chroot /mnt` this will make it so that instead of looking in `/usr`, is looks in `/mnt/usr` as if that was actually `/usr`. When you run the chroot, it will alter your shell, and everything else you run in that shell will be "inside" `/mnt` (or whatever argument you use).
  • Chroot is a bit like running one Linux inside another. However, keep in mind that it's not like a true virtual machine, just some trickery with paths. You will still be using the kernel and device drivers of the host OS. Just the programs being executed will change. Depending on the complexity of the program you run, you may need to set up additional virtual directories like `/tmp` (chroot won't create these for you, it only covers real directories and files). This is why with just a basic chroot, GUI programs like Steam might not run, because they're not properly connected to the live OS's graphics server.
  • Arch Linux has a slightly extended version called [arch-chroot](https://man.archlinux.org/man/arch-chroot.8). This sets up some extra stuff so you don't have to do it manually. However, to use this, you'll probably need to boot from the Arch ISO, which has no graphics and might be difficult to use if you're not comfortable in the terminal. As a workaround, you can try the Manjaro ISO which has a similar `manjaro-chroot` but also comes with a GUI.
  • But if the program you are trying to run is specifically Steam or a Wine game, I think you might find that challenging. These rely on many specialized and obscure system features, and it's hard to provide all of those in a chroot, without booting into the regular OS. IMO running Steam/Wine inside chroot should be its own question, because it's very specialized and not the same as running simpler programs (CLI).
  • Normally what people do is boot from live USB, mount their hard drive, chroot into their normal system, use terminal commands to do fix it just enough to be bootable, then boot into the regular OS and troubleshoot further from there. You only really need to chroot from a live USB when the normal OS is unbootable. Once it boots, you don't need the live USB. As an aside, Arch Linux is even installed in the same way through a chroot, so you might find their [install guide](https://wiki.archlinux.org/title/Installation_guide) helpful. If you need a "working reference configuration", it's better to create a virtual machine inside your normal OS.
  • Good luck, and if you can narrow down to a more specific issue, try asking it as a separate question.
  • It sounds like what you want is:
  • >There is a program installed in the regular OS on my hard drive, but I am booted into a live OS. How do I run that program?
  • The common way to do this is to use [chroot](https://man.archlinux.org/man/chroot.1).
  • Linux looks for programs under certain standard paths like `/usr/bin`. If you're in a live OS, your `/usr/bin` will be on a virtual disk (which uses your RAM) and will contain programs that came with the live USB. The normal OS's files are in the `/usr/bin` of the drive, which is not active in the live OS.
  • Let's say you mounted your main OS partition at `/mnt`, so that you see `/mnt/usr/games/steam`. You can't run `steam` because Linux will look for it in `/usr` not `/mnt/usr`. If you do `chroot /mnt` this will make it so that instead of looking in `/usr`, it looks in `/mnt/usr` as if that was actually `/usr`. When you run the chroot, it will alter your shell, and everything else you run in that shell will be "inside" `/mnt` (or whatever argument you use). In your case, you would run something like:
  • ```
  • chroot /media/pop-os/$SOME_UUID/
  • ```
  • And after that, trying to do `steam` should actually execute `/media/pop-os/$SOME_UUID/usr/games/steam`
  • Chroot is a bit like running one Linux inside another. However, keep in mind that it's not like a true virtual machine, just some trickery with paths. You will still be using the kernel and device drivers of the host OS. Just the programs being executed will change. Depending on the complexity of the program you run, you may need to set up additional virtual directories like `/tmp` (chroot won't create these for you, it only covers real directories and files). This is why with just a basic chroot, GUI programs like Steam might not run, because they're not properly connected to the live OS's graphics server.
  • Arch Linux has a slightly extended version called [arch-chroot](https://man.archlinux.org/man/arch-chroot.8). This sets up some extra stuff so you don't have to do it manually. However, to use this, you'll probably need to boot from the Arch ISO, which has no graphics and might be difficult to use if you're not comfortable in the terminal. As a workaround, you can try the Manjaro ISO which has a similar `manjaro-chroot` but also comes with a GUI.
  • But if the program you are trying to run is specifically Steam or a Wine game, I think you might find that challenging. These rely on many specialized and obscure system features, and it's hard to provide all of those in a chroot, without booting into the regular OS. IMO running Steam/Wine inside chroot should be its own question, because it's very specialized and not the same as running simpler programs (CLI).
  • Normally what people do is boot from live USB, mount their hard drive, chroot into their normal system, use terminal commands to do fix it just enough to be bootable, then boot into the regular OS and troubleshoot further from there. You only really need to chroot from a live USB when the normal OS is unbootable. Once it boots, you don't need the live USB. As an aside, Arch Linux is even installed in the same way through a chroot, so you might find their [install guide](https://wiki.archlinux.org/title/Installation_guide) helpful. If you need a "working reference configuration", it's better to create a virtual machine inside your normal OS.
  • Good luck, and if you can narrow down to a more specific issue, try asking it as a separate question.
#1: Initial revision by user avatar matthewsnyder‭ · 2024-07-18T22:59:52Z (6 months ago)
It sounds like what you want is:

>There is a program installed in the regular OS on my hard drive, but I am booted into a live OS. How do I run that program?

The common way to do this is to use [chroot](https://man.archlinux.org/man/chroot.1).

Linux looks for programs under certain standard paths like `/usr/bin`. If you're in a live OS, your `/usr/bin` will be on a virtual disk (which uses your RAM) and will contain programs that came with the live USB. The normal OS's files are in the `/usr/bin` of the drive, which is not active in the live OS.

First you have to make sure the normal OS drive/partition is mounted. In some GUI distro live USBs, you will see your drives in the file manager, and when you click they will automount at something like `/media/my_drive`. Others expect you to manually run [mount](https://man.archlinux.org/man/mount.8), which traditionally mounts at `/mnt`. 

Let's say you mounted your main OS partition at `/mnt`, so that you see `/mnt/usr/games/steam`. You can't run `steam` because Linux will look for it in `/usr` not `/mnt/usr`. If you do `chroot /mnt` this will make it so that instead of looking in `/usr`, is looks in `/mnt/usr` as if that was actually `/usr`. When you run the chroot, it will alter your shell, and everything else you run in that shell will be "inside" `/mnt` (or whatever argument you use).

Chroot is a bit like running one Linux inside another. However, keep in mind that it's not like a true virtual machine, just some trickery with paths. You will still be using the kernel and device drivers of the host OS. Just the programs being executed will change. Depending on the complexity of the program you run, you may need to set up additional virtual directories like `/tmp` (chroot won't create these for you, it only covers real directories and files). This is why with just a basic chroot, GUI programs like Steam might not run, because they're not properly connected to the live OS's graphics server.

Arch Linux has a slightly extended version called [arch-chroot](https://man.archlinux.org/man/arch-chroot.8). This sets up some extra stuff so you don't have to do it manually. However, to use this, you'll probably need to boot from the Arch ISO, which has no graphics and might be difficult to use if you're not comfortable in the terminal. As a workaround, you can try the Manjaro ISO which has a similar `manjaro-chroot` but also comes with a GUI.

But if the program you are trying to run is specifically Steam or a Wine game, I think you might find that challenging. These rely on many specialized and obscure system features, and it's hard to provide all of those in a chroot, without booting into the regular OS. IMO running Steam/Wine inside chroot should be its own question, because it's very specialized and not the same as running simpler programs (CLI).

Normally what people do is boot from live USB, mount their hard drive, chroot into their normal system, use terminal commands to do fix it just enough to be bootable, then boot into the regular OS and troubleshoot further from there. You only really need to chroot from a live USB when the normal OS is unbootable. Once it boots, you don't need the live USB. As an aside, Arch Linux is even installed in the same way through a chroot, so you might find their [install guide](https://wiki.archlinux.org/title/Installation_guide) helpful. If you need a "working reference configuration", it's better to create a virtual machine inside your normal OS.

Good luck, and if you can narrow down to a more specific issue, try asking it as a separate question.