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:

85495

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-06-01
catch - 3.15.0
Ebuild name:

dev-cpp/catch-3.15.0

Description

Modern C++ header-only framework for unit-tests

Added to portage

2026-06-01

dulwich - 1.2.6
Ebuild name:

dev-python/dulwich-1.2.6

Description

Pure-Python implementation of the Git file formats and protocols

Added to portage

2026-06-01

ensurepip-pip - 26.1.2
Ebuild name:

dev-python/ensurepip-pip-26.1.2

Description

Shared pip wheel for ensurepip Python module

Added to portage

2026-06-01

fastapi - 0.136.3
Ebuild name:

dev-python/fastapi-0.136.3

Description

High performance framework, easy to learn, fast to code, ready for produ

Added to portage

2026-06-01

fifo-cronolog - 1.3.0
Ebuild name:

app-admin/fifo-cronolog-1.3.0

Description

cronolog wrapper for use with dumb daemons like squid, varnish and so

Added to portage

2026-06-01

gcc - 17.0.0_p20260531
Ebuild name:

sys-devel/gcc-17.0.0_p20260531

Description

The GNU Compiler Collection

Added to portage

2026-06-01

gentoo-kernel-modprep - 7.0.10_p1
Ebuild name:

sys-kernel/gentoo-kernel-modprep-7.0.10_p1

Description

Minimal subset of gentoo-kernel-bin for building modules

Added to portage

2026-06-01

gentoolkit - 0.7.4
Ebuild name:

app-portage/gentoolkit-0.7.4

Description

Collection of administration scripts for Gentoo

Added to portage

2026-06-01

git-sources - 7.1_rc6
Ebuild name:

sys-kernel/git-sources-7.1_rc6

Description

The very latest -git version of the Linux kernel

Added to portage

2026-06-01

glances - 4.5.4
Ebuild name:

sys-process/glances-4.5.4

Description

CLI curses based monitoring tool

Added to portage

2026-06-01

gokrazy-rsync - 0.3.3
Ebuild name:

net-misc/gokrazy-rsync-0.3.3

Description

rsync in Go

Added to portage

2026-06-01

hatchling - 1.30.0
Ebuild name:

dev-python/hatchling-1.30.0

Description

Modern, extensible Python build backend

Added to portage

2026-06-01

less - 702
Ebuild name:

sys-apps/less-702

Description

Excellent text file viewer

Added to portage

2026-06-01

libsdl3 - 3.4.10
Ebuild name:

media-libs/libsdl3-3.4.10

Description

Simple Direct Media Layer

Added to portage

2026-06-01

libsearpc - 3.3.0-r5
Ebuild name:

net-libs/libsearpc-3.3.0-r5

Description

Simple C language RPC framework

Added to portage

2026-06-01

linux-sources - 3-r9
Ebuild name:

virtual/linux-sources-3-r9

Description

Virtual for Linux kernel sources

Added to portage

2026-06-01

mocker - 0.5.0
Ebuild name:

app-emacs/mocker-0.5.0

Description

Simple mocking framework for Emacs

Added to portage

2026-06-01

modus-themes - 5.1.0
Ebuild name:

app-emacs/modus-themes-5.1.0

Description

Highly accessible themes for GNU Emacs

Added to portage

2026-06-01

modus-themes - 5.2.0
Ebuild name:

app-emacs/modus-themes-5.2.0

Description

Highly accessible themes for GNU Emacs

Added to portage

2026-06-01

pip - 26.1.2
Ebuild name:

dev-python/pip-26.1.2

Description

The PyPA recommended tool for installing Python packages

Added to portage

2026-06-01

portage - 3.0.79-r1
Ebuild name:

sys-apps/portage-3.0.79-r1

Description

The package management and distribution system for Gentoo

Added to portage

2026-06-01

pyaudio - 0.2.14-r1
Ebuild name:

dev-python/pyaudio-0.2.14-r1

Description

Python bindings for PortAudio

Added to portage

2026-06-01

python-multipart - 0.0.30
Ebuild name:

dev-python/python-multipart-0.0.30

Description

A streaming multipart parser for Python

Added to portage

2026-06-01

qgis - 4.0.2
Ebuild name:

sci-geosciences/qgis-4.0.2

Description

User friendly Geographic Information System

Added to portage

2026-06-01

scotch - 7.0.11
Ebuild name:

sci-libs/scotch-7.0.11

Description

Software for graph, mesh and hypergraph partitioning

Added to portage

2026-06-01

seafile - 9.0.18
Ebuild name:

net-misc/seafile-9.0.18

Description

File syncing and sharing software with file encryption and group sharing

Added to portage

2026-06-01

seafile-client - 9.0.18
Ebuild name:

net-misc/seafile-client-9.0.18

Description

Seafile desktop client

Added to portage

2026-06-01

sphinx-autodoc-typehints - 3.10.4
Ebuild name:

dev-python/sphinx-autodoc-typehints-3.10.4

Description

Type hints support for the Sphinx autodoc extension

Added to portage

2026-06-01

stalwart-cli - 1.0.8
Ebuild name:

net-mail/stalwart-cli-1.0.8

Description

Stalwart Mail Server command line utility

Added to portage

2026-06-01

stalwart-mail - 0.16.7
Ebuild name:

net-mail/stalwart-mail-0.16.7

Description

Stalwart Mail Server

Added to portage

2026-06-01

tavern - 3.6.0
Ebuild name:

dev-python/tavern-3.6.0

Description

A tool, library, and Pytest plugin for testing RESTful APIs

Added to portage

2026-06-01

tibs - 0.9.0
Ebuild name:

dev-python/tibs-0.9.0

Description

A sleek Python library for your binary data

Added to portage

2026-06-01

tifffile - 2026.6.1
Ebuild name:

dev-python/tifffile-2026.6.1

Description

Read and write TIFF files

Added to portage

2026-06-01

valkey - 0
Ebuild name:

acct-group/valkey-0

Description

Valkey program group

Added to portage

2026-06-01

valkey - 0
Ebuild name:

acct-user/valkey-0

Description

Valkey program user

Added to portage

2026-06-01

valkey - 9.1.0-r1
Ebuild name:

dev-db/valkey-9.1.0-r1

Description

Persistent key-value store, fork of dev-db/redis

Added to portage

2026-06-01

virtualenv - 21.4.2
Ebuild name:

dev-python/virtualenv-21.4.2

Description

Virtual Python Environment builder

Added to portage

2026-06-01

zfs - 2.3.7
Ebuild name:

sys-fs/zfs-2.3.7

Description

Userland utilities for ZFS Linux kernel module

Added to portage

2026-06-01

zfs - 2.4.2
Ebuild name:

sys-fs/zfs-2.4.2

Description

Linux kernel module and userland utilities for ZFS

Added to portage

2026-06-01

zfs-kmod - 2.3.7
Ebuild name:

sys-fs/zfs-kmod-2.3.7

Description

Linux ZFS kernel module for sys-fs/zfs

Added to portage

2026-06-01

2026-05-31
ebuild-mode - 1.83
Ebuild name:

app-xemacs/ebuild-mode-1.83

Description

Emacs modes for editing ebuilds and other Gentoo specific files

Added to portage

2026-05-31

esptool - 5.2.0
Ebuild name:

dev-embedded/esptool-5.2.0

Description

Serial utility for flashing and interacting with Espressif ESP8266 and E

Added to portage

2026-05-31

gcc - 16.1.1_p20260530
Ebuild name:

sys-devel/gcc-16.1.1_p20260530

Description

The GNU Compiler Collection

Added to portage

2026-05-31

getuto - 2.0
Ebuild name:

app-portage/getuto-2.0

Description

Standalone Gentoo gpg trust anchor generation tool for binpkgs

Added to portage

2026-05-31

gnome-shell - 49.7
Ebuild name:

gnome-base/gnome-shell-49.7

Description

Provides core UI functions for the GNOME desktop

Added to portage

2026-05-31

gnome-user-docs - 49.7
Ebuild name:

gnome-extra/gnome-user-docs-49.7

Description

GNOME end user documentation

Added to portage

2026-05-31

grass - 8.5.0-r1
Ebuild name:

sci-geosciences/grass-8.5.0-r1

Description

Free GIS with raster and vector functionality, as well as 3D vizuali

Added to portage

2026-05-31

libadwaita - 1.8.6
Ebuild name:

gui-libs/libadwaita-1.8.6

Description

Building blocks for modern GNOME applications

Added to portage

2026-05-31

libcdada - 0.6.4
Ebuild name:

dev-libs/libcdada-0.6.4

Description

Basic data structures in C

Added to portage

2026-05-31

mit-krb5 - 1.22.2
Ebuild name:

app-crypt/mit-krb5-1.22.2

Description

MIT Kerberos V

Added to portage

2026-05-31

mit-krb5 - 1.22.2-r1
Ebuild name:

app-crypt/mit-krb5-1.22.2-r1

Description

MIT Kerberos V

Added to portage

2026-05-31

octave-kernel - 1.0.4
Ebuild name:

dev-python/octave-kernel-1.0.4

Description

Jupyter kernel for octave

Added to portage

2026-05-31

pdf-tools - 1.3.0-r1
Ebuild name:

app-emacs/pdf-tools-1.3.0-r1

Description

Emacs Lisp support library for PDF documents

Added to portage

2026-05-31

pycargoebuild - 0.15.2
Ebuild name:

app-portage/pycargoebuild-0.15.2

Description

A generator for Rust/Cargo ebuilds written in Python

Added to portage

2026-05-31

raspberrypi-utils - 0_p20260527
Ebuild name:

dev-embedded/raspberrypi-utils-0_p20260527

Description

Raspberry Pi userspace utilities

Added to portage

2026-05-31

roundcube - 1.6.16
Ebuild name:

mail-client/roundcube-1.6.16

Description

Browser-based multilingual IMAP client with an application-like user i

Added to portage

2026-05-31

serpent - 1.43
Ebuild name:

dev-python/serpent-1.43

Description

A simple serialization library based on ast.literal_eval

Added to portage

2026-05-31

service-identity - 26.1.0
Ebuild name:

dev-python/service-identity-26.1.0

Description

Service identity verification for pyOpenSSL

Added to portage

2026-05-31

shell-maker - 0.89.2-r1
Ebuild name:

app-emacs/shell-maker-0.89.2-r1

Description

Interaction mode for making comint shells for GNU Emacs

Added to portage

2026-05-31

shell-maker - 0.90.1-r1
Ebuild name:

app-emacs/shell-maker-0.90.1-r1

Description

Interaction mode for making comint shells for GNU Emacs

Added to portage

2026-05-31

shell-maker - 0.91.2-r1
Ebuild name:

app-emacs/shell-maker-0.91.2-r1

Description

Interaction mode for making comint shells for GNU Emacs

Added to portage

2026-05-31

starlette - 1.2.1
Ebuild name:

dev-python/starlette-1.2.1

Description

The little ASGI framework that shines

Added to portage

2026-05-31

typer - 0.26.4
Ebuild name:

dev-python/typer-0.26.4

Description

Build great CLIs. Easy to code. Based on Python type hints

Added to portage

2026-05-31

wine-staging - 11.10
Ebuild name:

app-emulation/wine-staging-11.10

Description

Free implementation of Windows(tm) on Unix, with Wine-Staging patc

Added to portage

2026-05-31

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