from small one page howto to huge articles all in one place

search text in:




Other .linuxhowtos.org sites: www.linuxhowtos.org
toolsntoys.linuxhowtos.org



Last additions:
How to make X listen on port 6000

How to make X listen on port 6000

words:

34

views:

85202

userrating:

average rating: 1.2 (52 votes) (1=very good 6=terrible)


May, 25th 2007:
April, 26th 2007:
Apr, 10th. 2007:
Druckversion . pdf icon
You are here: Tutorials per portage category->net-misc->openssh

Create a chrooted ssh user

This tutorial explains how to install and configure a chroot enviroment for an ssh user. This setup enables you to give out ssh accounts without having to fear that this user can see all files on the system.

Installing ssh

First you need to have a patched version of the sshd server. Luckily these patches can be enabled with the use flag "chroot" in the sshd use flags.
#echo "net-misc/openssh chroot" >> /etc/portage/package.use
#emerge openssh

creating the chroot enviroment

We will create our chroot enviroment in /home/chroot.
To make the chroot work, run the following commands to make the needed directories and devices for the chrooted user.
mkdir /home/chroot/
mkdir /home/chroot/home/
cd /home/chroot
mkdir etc
mkdir bin
mkdir lib
mkdir usr
mkdir usr/bin
mkdir dev
mknod dev/null c 1 3
mknod dev/zero c 1 5

Now we need to populate the directories with some binaries.
copy the following script into a file. If you need more apps, add them
to the APPS line.

APPS="/bin/bash /bin/ls /bin/mkdir /bin/mv /bin/pwd /bin/rm /usr/bin/id /usr/bin/ssh /bin/ping /usr/bin/dircolors"
for prog in $APPS; do
cp $prog ./$prog

# obtain a list of related libraries
ldd $prog > /dev/null
if [ "$?" = 0 ] ; then
LIBS=`ldd $prog | awk '{ print $3 }'`
for l in $LIBS; do
mkdir ./`dirname $l` > /dev/null 2>&1
cp $l ./$l
done
fi
done

After you have run the script, your chroot enviroment is almost done.
run

cp /lib/libnss_compat.so.2 /lib/libnsl.so.1 /lib/libnss_files.so.2 ./lib/
echo '#!/bin/bash' > usr/bin/groups
echo "id -Gn" >> usr/bin/groups
touch etc/passwd
grep /etc/passwd -e "^root" > etc/passwd
to copy some libraries and user information into the chroot.
You should also copy the line of the group in which you will create new users from /etc/group to /home/chroot/etc/group. In this tutorial we will create users in the group users, so we do this:
grep /etc/group -e "^root" -e "^users" > etc/group

and restart SSH:
/etc/init.d/ssh restart

Creating chrooted users

ssh decides which user should be chrooted and which not by the "home directory" entry in the /etc/passwd.
Example for a non-chrooted user:
user_a:x:2002:100:User A:/home/user_a:/bin/bash
This user will be chrooted:
user_b:x:2003:100:User B:/home/chroot/./home/user_b:/bin/bash
Now lets add a testuser to the chrooted user list:
useradd -s /bin/bash -m -d /home/chroot/./home/testuser -c "testuser" -g users testuser

Then we give testuser a password:
passwd testuser

Finally, we have to copy the line for testuser in /etc/passwd to /home/chroot/etc/passwd:
grep /etc/passwd -e "^testuser" >> /home/chroot/etc/passwd


Now log in as testuser and see if everything worked.

Have fun
back



Support us on Content Nation

New Packages

- as rdf newsfeed
- as rss newsfeed
- as Atom newsfeed
2026-05-18
bird - 2.17.3-r1
Ebuild name:

net-misc/bird-2.17.3-r1

Description

A routing daemon implementing OSPF, RIPv2 & BGP for IPv4 & IPv6

Added to portage

2026-05-18

bird - 2.17.4
Ebuild name:

net-misc/bird-2.17.4

Description

A routing daemon implementing OSPF, RIPv2 & BGP for IPv4 & IPv6

Added to portage

2026-05-18

bird - 2.18.1
Ebuild name:

net-misc/bird-2.18.1

Description

A routing daemon implementing OSPF, RIPv2 & BGP for IPv4 & IPv6

Added to portage

2026-05-18

bird - 3.1.5-r1
Ebuild name:

net-misc/bird-3.1.5-r1

Description

A routing daemon implementing OSPF, RIPv2 & BGP for IPv4 & IPv6

Added to portage

2026-05-18

bird - 3.1.6
Ebuild name:

net-misc/bird-3.1.6

Description

A routing daemon implementing OSPF, RIPv2 & BGP for IPv4 & IPv6

Added to portage

2026-05-18

bird - 3.2.1
Ebuild name:

net-misc/bird-3.2.1

Description

A routing daemon implementing OSPF, RIPv2 & BGP for IPv4 & IPv6

Added to portage

2026-05-18

dist-kernel - 7.0.9
Ebuild name:

virtual/dist-kernel-7.0.9

Description

Virtual to depend on any Distribution Kernel

Added to portage

2026-05-18

gentoo-kernel - 7.0.9
Ebuild name:

sys-kernel/gentoo-kernel-7.0.9

Description

Linux kernel built with Gentoo patches

Added to portage

2026-05-18

gentoo-kernel-bin - 7.0.9
Ebuild name:

sys-kernel/gentoo-kernel-bin-7.0.9

Description

Pre-built Linux kernel with Gentoo patches

Added to portage

2026-05-18

gentoo-sources - 6.12.90
Ebuild name:

sys-kernel/gentoo-sources-6.12.90

Description

Full sources including the Gentoo patchset for the . kernel tree

Added to portage

2026-05-18

gentoo-sources - 6.18.32
Ebuild name:

sys-kernel/gentoo-sources-6.18.32

Description

Full sources including the Gentoo patchset for the . kernel tree

Added to portage

2026-05-18

gentoo-sources - 6.6.140
Ebuild name:

sys-kernel/gentoo-sources-6.6.140

Description

Full sources including the Gentoo patchset for the . kernel tree

Added to portage

2026-05-18

gentoo-sources - 7.0.9
Ebuild name:

sys-kernel/gentoo-sources-7.0.9

Description

Full sources including the Gentoo patchset for the . kernel tree

Added to portage

2026-05-18

libfido2 - 1.17.0
Ebuild name:

dev-libs/libfido2-1.17.0

Description

Provides library functionality for FIDO 2.0

Added to portage

2026-05-18

vanilla-kernel - 7.0.9
Ebuild name:

sys-kernel/vanilla-kernel-7.0.9

Description

Linux kernel built from vanilla upstream sources

Added to portage

2026-05-18

zedis - 0.4.0
Ebuild name:

dev-db/zedis-0.4.0

Description

Blazing-fast native Redis GUI built with Rust and GPUI

Added to portage

2026-05-18

2026-05-17
atril - 1.28.4
Ebuild name:

app-text/atril-1.28.4

Description

Atril document viewer for MATE

Added to portage

2026-05-17

black - 26.5.0
Ebuild name:

dev-python/black-26.5.0

Description

The uncompromising Python code formatter

Added to portage

2026-05-17

cachetools - 7.1.2
Ebuild name:

dev-python/cachetools-7.1.2

Description

Extensible memoizing collections and decorators

Added to portage

2026-05-17

cherrytree - 1.6.3
Ebuild name:

app-text/cherrytree-1.6.3

Description

A hierarchical note taking application (C++ version)

Added to portage

2026-05-17

cholmod - 5.3.4-r1
Ebuild name:

sci-libs/cholmod-5.3.4-r1

Description

Sparse Cholesky factorization and update/downdate library

Added to portage

2026-05-17

cli-helpers - 2.15.0
Ebuild name:

dev-python/cli-helpers-2.15.0

Description

Python helpers for common CLI tasks

Added to portage

2026-05-17

cmark - 0.31.2
Ebuild name:

app-text/cmark-0.31.2

Description

CommonMark parsing and rendering library and program in C

Added to portage

2026-05-17

corrosion - 0.6.1-r1
Ebuild name:

dev-build/corrosion-0.6.1-r1

Description

Marrying Rust and CMake - Easy Rust and C/C++ Integration

Added to portage

2026-05-17

dbus-fast - 4.2.7
Ebuild name:

dev-python/dbus-fast-4.2.7

Description

A faster version of dbus-next

Added to portage

2026-05-17

dynamips - 0.2.24
Ebuild name:

app-emulation/dynamips-0.2.24

Description

Cisco 7200/3600 Simulator

Added to portage

2026-05-17

fetchmail - 6.6.4
Ebuild name:

net-mail/fetchmail-6.6.4

Description

the legendary remote-mail retrieval and forwarding utility

Added to portage

2026-05-17

gcc - 16.1.1_p20260516
Ebuild name:

sys-devel/gcc-16.1.1_p20260516

Description

The GNU Compiler Collection

Added to portage

2026-05-17

heroic-bin - 2.22.0
Ebuild name:

games-util/heroic-bin-2.22.0

Description

GOG and Epic Games Launcher for Linux

Added to portage

2026-05-17

intellij-idea - 2026.1.2
Ebuild name:

dev-util/intellij-idea-2026.1.2

Description

A complete toolset for web, mobile and enterprise development

Added to portage

2026-05-17

iterable-io - 1.0.4
Ebuild name:

dev-python/iterable-io-1.0.4

Description

Adapt generators and other iterables to a file-like interface

Added to portage

2026-05-17

libei - 1.6.0
Ebuild name:

dev-libs/libei-1.6.0

Description

Library for Emulated Input, primarily aimed at the Wayland stack

Added to portage

2026-05-17

libinput - 1.31.2
Ebuild name:

dev-libs/libinput-1.31.2

Description

Library to handle input devices in Wayland

Added to portage

2026-05-17

libusb1 - 3.4.0
Ebuild name:

dev-python/libusb1-3.4.0

Description

Python ctype-based wrapper around libusb1

Added to portage

2026-05-17

libva-intel-media-driver - 26.2.0
Ebuild name:

media-libs/libva-intel-media-driver-26.2.0

Description

Intel Media Driver for VA-API (iHD)

Added to portage

2026-05-17

master-pdf-editor - 5.9.98-r1
Ebuild name:

app-text/master-pdf-editor-5.9.98-r1

Description

A complete solution for viewing and editing PDF files

Added to portage

2026-05-17

mgorny-dev-scripts - 73
Ebuild name:

app-portage/mgorny-dev-scripts-73

Description

Handy scripts for ebuild development and more

Added to portage

2026-05-17

narwhals - 2.21.2
Ebuild name:

dev-python/narwhals-2.21.2

Description

Extremely lightweight compatibility layer between dataframe libraries

Added to portage

2026-05-17

nct6687d - 0_pre20260313
Ebuild name:

sys-power/nct6687d-0_pre20260313

Description

Kernel module for the Nuvoton NCT6687-R

Added to portage

2026-05-17

nct6687d - 9999
Ebuild name:

sys-power/nct6687d-9999

Description

Kernel module for the Nuvoton NCT6687-R

Added to portage

2026-05-17

nmap - 7.99
Ebuild name:

net-analyzer/nmap-7.99

Description

Network exploration tool and security / port scanner

Added to portage

2026-05-17

prismlauncher - 11.0.2
Ebuild name:

games-action/prismlauncher-11.0.2

Description

Custom, open source Minecraft launcher

Added to portage

2026-05-17

suitesparseconfig - 7.12.2-r1
Ebuild name:

sci-libs/suitesparseconfig-7.12.2-r1

Description

Common configurations for all packages in suitesparse

Added to portage

2026-05-17

teamspeak-client - 6.0.0_beta4
Ebuild name:

media-sound/teamspeak-client-6.0.0_beta4

Description

A client software for quality voice communication via the

Added to portage

2026-05-17

tvheadend - 4.3_p20260516
Ebuild name:

media-tv/tvheadend-4.3_p20260516

Description

Tvheadend is a TV streaming server and digital video recorder

Added to portage

2026-05-17

uhd - 4.9.0.1-r1
Ebuild name:

net-wireless/uhd-4.9.0.1-r1

Description

Universal Software Radio Peripheral (USRP) Hardware Driver

Added to portage

2026-05-17

vanilla-kernel - 6.18.9999
Ebuild name:

sys-kernel/vanilla-kernel-6.18.9999

Description

Linux kernel built from vanilla upstream sources

Added to portage

2026-05-17

vanilla-sources - 6.12.90
Ebuild name:

sys-kernel/vanilla-sources-6.12.90

Description

Full sources for the Linux kernel

Added to portage

2026-05-17

vanilla-sources - 6.18.32
Ebuild name:

sys-kernel/vanilla-sources-6.18.32

Description

Full sources for the Linux kernel

Added to portage

2026-05-17

vanilla-sources - 6.6.140
Ebuild name:

sys-kernel/vanilla-sources-6.6.140

Description

Full sources for the Linux kernel

Added to portage

2026-05-17

vanilla-sources - 7.0.9
Ebuild name:

sys-kernel/vanilla-sources-7.0.9

Description

Full sources for the Linux kernel

Added to portage

2026-05-17

vlc - 3.0.23-r1
Ebuild name:

media-video/vlc-3.0.23-r1

Description

Media player and framework with support for most multimedia files and str

Added to portage

2026-05-17

webkit-gtk - 2.52.3-r411
Ebuild name:

net-libs/webkit-gtk-2.52.3-r411

Description

Open source web browser engine

Added to portage

2026-05-17

webkit-gtk - 2.52.3-r601
Ebuild name:

net-libs/webkit-gtk-2.52.3-r601

Description

Open source web browser engine

Added to portage

2026-05-17

zeroconf - 0.149.3
Ebuild name:

dev-python/zeroconf-0.149.3

Description

Pure Python Multicast DNS Service Discovery Library (Bonjour/Avahi comp

Added to portage

2026-05-17

rdf newsfeed | rss newsfeed | Atom newsfeed
Copyright 2004-2025 Sascha Nitsch Unternehmensberatung GmbH
- Copyright and legal notices -
Time to create this page: 74.5 ms