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:

85713

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-09
binutils - 2.46.1
Ebuild name:

sys-devel/binutils-2.46.1

Description

Tools necessary to build programs

Added to portage

2026-06-09

binutils - 2.46.9999
Ebuild name:

sys-devel/binutils-2.46.9999

Description

Tools necessary to build programs

Added to portage

2026-06-09

binutils-hppa64 - 2.46.1
Ebuild name:

sys-devel/binutils-hppa64-2.46.1

Description

Tools necessary to build programs

Added to portage

2026-06-09

binutils-libs - 2.46.1
Ebuild name:

sys-libs/binutils-libs-2.46.1

Description

Core binutils libraries (libbfd, libopcodes, libiberty) for external

Added to portage

2026-06-09

glibc - 2.43.9999
Ebuild name:

sys-libs/glibc-2.43.9999

Description

GNU libc C library

Added to portage

2026-06-09

haruna - 1.7.1-r2
Ebuild name:

media-video/haruna-1.7.1-r2

Description

Video player built with Qt/QML and libmpv

Added to portage

2026-06-09

haruna - 1.8.1-r1
Ebuild name:

media-video/haruna-1.8.1-r1

Description

Video player built with Qt/QML and libmpv

Added to portage

2026-06-09

kdeconnect - 26.04.1-r1
Ebuild name:

kde-misc/kdeconnect-26.04.1-r1

Description

Adds communication between KDE Plasma and your smartphone

Added to portage

2026-06-09

kdeconnect - 26.04.2-r1
Ebuild name:

kde-misc/kdeconnect-26.04.2-r1

Description

Adds communication between KDE Plasma and your smartphone

Added to portage

2026-06-09

magit-popup - 2.13.3-r1
Ebuild name:

app-emacs/magit-popup-2.13.3-r1

Description

Define prefix-infix-suffix command combos

Added to portage

2026-06-09

mailcrypt - 3.5.9-r3
Ebuild name:

app-emacs/mailcrypt-3.5.9-r3

Description

Provides a simple interface to public key cryptography with OpenPGP

Added to portage

2026-06-09

marginalia - 2.10
Ebuild name:

app-emacs/marginalia-2.10

Description

Marginalia in the minibuffer

Added to portage

2026-06-09

pdns - 5.1.1
Ebuild name:

net-dns/pdns-5.1.1

Description

The PowerDNS Daemon

Added to portage

2026-06-09

php - 8.5.7
Ebuild name:

dev-lang/php-8.5.7

Description

The PHP language runtime engine

Added to portage

2026-06-09

transient - 0.13.4
Ebuild name:

app-emacs/transient-0.13.4

Description

Transient commands abstraction for GNU Emacs

Added to portage

2026-06-09

vertico - 2.10
Ebuild name:

app-emacs/vertico-2.10

Description

Vertical interactive completion

Added to portage

2026-06-09

ytmusicapi - 1.12.1-r1
Ebuild name:

dev-python/ytmusicapi-1.12.1-r1

Description

Unofficial API for YouTube Music

Added to portage

2026-06-09

2026-06-08
aiohttp - 3.14.1
Ebuild name:

dev-python/aiohttp-3.14.1

Description

HTTP client/server for asyncio

Added to portage

2026-06-08

array-api-compat - 1.15.0
Ebuild name:

dev-python/array-api-compat-1.15.0

Description

Array API standard compatibility wrapper over NumPy and others

Added to portage

2026-06-08

asyncssh - 2.23.1
Ebuild name:

dev-python/asyncssh-2.23.1

Description

Asynchronous SSHv2 client and server library

Added to portage

2026-06-08

beautifulsoup4 - 4.15.0
Ebuild name:

dev-python/beautifulsoup4-4.15.0

Description

Pythonic idioms for iterating, searching, and modifying an HTML/XM

Added to portage

2026-06-08

bugbite-cli - 0.0.15
Ebuild name:

dev-util/bugbite-cli-0.0.15

Description

A command line tool for bug, issue, and ticket mangling

Added to portage

2026-06-08

caddy - 2.11.4
Ebuild name:

www-servers/caddy-2.11.4

Description

Fast and extensible multi-platform HTTP/1-2-3 web server with automatic HT

Added to portage

2026-06-08

cdemu - 3.3.1
Ebuild name:

app-cdr/cdemu-3.3.1

Description

Command-line tool for controlling cdemu-daemon

Added to portage

2026-06-08

cdemu-daemon - 3.3.1
Ebuild name:

app-cdr/cdemu-daemon-3.3.1

Description

Daemon of the CDEmu optical media image mounting suite

Added to portage

2026-06-08

citus - 13.3.0
Ebuild name:

dev-db/citus-13.3.0

Description

Open-source postgresql extension for clustering/multi-node setups

Added to portage

2026-06-08

citus - 14.1.0
Ebuild name:

dev-db/citus-14.1.0

Description

Open-source postgresql extension for clustering/multi-node setups

Added to portage

2026-06-08

coredns - 1.14.3
Ebuild name:

net-dns/coredns-1.14.3

Description

CoreDNS is a DNS server that chains plugins

Added to portage

2026-06-08

cosign - 3.1.0
Ebuild name:

app-containers/cosign-3.1.0

Description

container signing utility

Added to portage

2026-06-08

duckdb - 1.5.3
Ebuild name:

dev-db/duckdb-1.5.3

Description

high-performance analytical database system

Added to portage

2026-06-08

fakeredis - 2.36.1
Ebuild name:

dev-python/fakeredis-2.36.1

Description

Fake implementation of redis API for testing purposes

Added to portage

2026-06-08

flask-cors - 6.0.4
Ebuild name:

dev-python/flask-cors-6.0.4

Description

A Flask extension for Cross Origin Resource Sharing (CORS)

Added to portage

2026-06-08

gallery-dl - 1.32.2
Ebuild name:

net-misc/gallery-dl-1.32.2

Description

Download image galleries and collections from several image hosting site

Added to portage

2026-06-08

gcc - 17.0.0_p20260607
Ebuild name:

sys-devel/gcc-17.0.0_p20260607

Description

The GNU Compiler Collection

Added to portage

2026-06-08

gcc - 17.0.0_p20260607-r1
Ebuild name:

sys-devel/gcc-17.0.0_p20260607-r1

Description

The GNU Compiler Collection

Added to portage

2026-06-08

gcdemu - 3.3.1
Ebuild name:

app-cdr/gcdemu-3.3.1

Description

Gtk+ GUI for controlling cdemu-daemon

Added to portage

2026-06-08

git-sources - 7.1_rc7
Ebuild name:

sys-kernel/git-sources-7.1_rc7

Description

The very latest -git version of the Linux kernel

Added to portage

2026-06-08

gnuradio - 3.11_pre20260606
Ebuild name:

net-wireless/gnuradio-3.11_pre20260606

Description

Toolkit that provides signal processing blocks to implement

Added to portage

2026-06-08

gr-fosphor - 0.0_p20260330-r1
Ebuild name:

net-analyzer/gr-fosphor-0.0_p20260330-r1

Description

gnuradio fosphor block (GPU spectrum display)

Added to portage

2026-06-08

haproxy - 3.4.0
Ebuild name:

net-proxy/haproxy-3.4.0

Description

A TCP/HTTP reverse proxy for high availability environments

Added to portage

2026-06-08

haproxy - 3.4.9999
Ebuild name:

net-proxy/haproxy-3.4.9999

Description

A TCP/HTTP reverse proxy for high availability environments

Added to portage

2026-06-08

jellyfin-bin - 10.11.11
Ebuild name:

www-apps/jellyfin-bin-10.11.11

Description

Jellyfin puts you in control of managing and streaming your media

Added to portage

2026-06-08

kafka-bin - 4.2.1
Ebuild name:

net-misc/kafka-bin-4.2.1

Description

A high-throughput distributed messaging system

Added to portage

2026-06-08

kafka-bin - 4.3.0
Ebuild name:

net-misc/kafka-bin-4.3.0

Description

A high-throughput distributed messaging system

Added to portage

2026-06-08

libmirage - 3.3.2
Ebuild name:

dev-libs/libmirage-3.3.2

Description

CD and DVD image access library

Added to portage

2026-06-08

libslirp - 4.9.3
Ebuild name:

net-libs/libslirp-4.9.3

Description

A TCP-IP emulator used to provide virtual networking services

Added to portage

2026-06-08

libxfce4ui - 4.21.8
Ebuild name:

xfce-base/libxfce4ui-4.21.8

Description

Unified widget and session management libs for Xfce

Added to portage

2026-06-08

marginalia - 2.11
Ebuild name:

app-emacs/marginalia-2.11

Description

Marginalia in the minibuffer

Added to portage

2026-06-08

openpgp-keys-dougmassay - 20260608
Ebuild name:

sec-keys/openpgp-keys-dougmassay-20260608

Description

OpenPGP key used by Doug Massay

Added to portage

2026-06-08

passt - 2026.05.26
Ebuild name:

net-misc/passt-2026.05.26

Description

User-mode networking daemons for VMs and namespaces, replacement for Slir

Added to portage

2026-06-08

platyps - 0.14.2-r1
Ebuild name:

app-shells/platyps-0.14.2-r1

Description

Generate PowerShell external help files from Markdown

Added to portage

2026-06-08

postgresql - 19_beta1
Ebuild name:

dev-db/postgresql-19_beta1

Description

PostgreSQL RDBMS

Added to portage

2026-06-08

pytest-aiohttp - 1.1.1
Ebuild name:

dev-python/pytest-aiohttp-1.1.1

Description

pytest plugin for aiohttp support

Added to portage

2026-06-08

python-debian - 1.1.1
Ebuild name:

dev-python/python-debian-1.1.1

Description

Python modules to work with Debian-related data formats

Added to portage

2026-06-08

qbe - 1.3-r1
Ebuild name:

sys-devel/qbe-1.3-r1

Description

Pure-C embeddable compiler backend

Added to portage

2026-06-08

rsync - 3.4.4
Ebuild name:

net-misc/rsync-3.4.4

Description

File transfer program to keep remote files into sync

Added to portage

2026-06-08

sanlock - 5.1.0-r2
Ebuild name:

sys-cluster/sanlock-5.1.0-r2

Description

shared storage lock manager

Added to portage

2026-06-08

sigil - 2.8.0
Ebuild name:

app-text/sigil-2.8.0

Description

Multi-platform WYSIWYG ebook editor for ePub format

Added to portage

2026-06-08

sqlite - 3.53.2-r1
Ebuild name:

dev-db/sqlite-3.53.2-r1

Description

SQL database engine

Added to portage

2026-06-08

stalwart-mail - 0.16.8
Ebuild name:

net-mail/stalwart-mail-0.16.8

Description

Stalwart Mail Server

Added to portage

2026-06-08

syd - 3.55.0
Ebuild name:

sys-apps/syd-3.55.0

Description

seccomp and landlock based application sandbox with support for namespaces

Added to portage

2026-06-08

timescaledb - 2.27.2
Ebuild name:

dev-db/timescaledb-2.27.2

Description

Open-source time-series SQL database

Added to portage

2026-06-08

virt-firmware - 26.2-r1
Ebuild name:

app-emulation/virt-firmware-26.2-r1

Description

Tools for ovmf/armvirt firmware volumes

Added to portage

2026-06-08

vscode-dark-plus-emacs-theme - 2.1.0_p20260606
Ebuild name:

app-emacs/vscode-dark-plus-emacs-theme-2.1.0_p20260606

Description

Accurate port of the default Visual Studio C

Added to portage

2026-06-08

websocat - 1.14.1
Ebuild name:

net-misc/websocat-1.14.1

Description

Command-line client for WebSockets, like netcat, with socat-like functions

Added to portage

2026-06-08

xfce4-panel - 4.21.2
Ebuild name:

xfce-base/xfce4-panel-4.21.2

Description

Panel for the Xfce desktop environment

Added to portage

2026-06-08

zedis - 0.4.2
Ebuild name:

dev-db/zedis-0.4.2

Description

Blazing-fast native Redis GUI built with Rust and GPUI

Added to portage

2026-06-08

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