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:

83735

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-03-13
awscli - 1.44.57
Ebuild name:

app-admin/awscli-1.44.57

Description

Universal Command Line Environment for AWS

Added to portage

2026-03-13

bitstring - 4.4.0
Ebuild name:

dev-python/bitstring-4.4.0

Description

A pure Python module for creation and analysis of binary data

Added to portage

2026-03-13

boto3 - 1.42.67
Ebuild name:

dev-python/boto3-1.42.67

Description

The AWS SDK for Python

Added to portage

2026-03-13

botocore - 1.42.67
Ebuild name:

dev-python/botocore-1.42.67

Description

Low-level, data-driven core of boto 3

Added to portage

2026-03-13

claude-code - 2.1.74
Ebuild name:

dev-util/claude-code-2.1.74

Description

Claude Code - an agentic coding tool by Anthropic

Added to portage

2026-03-13

google-auth - 2.49.1
Ebuild name:

dev-python/google-auth-2.49.1

Description

Google Authentication Library

Added to portage

2026-03-13

mu-cite - 8.1_p202011031127
Ebuild name:

app-emacs/mu-cite-8.1_p202011031127

Description

Message citation utilities for emacsen

Added to portage

2026-03-13

nuitka - 4.0.5
Ebuild name:

dev-python/nuitka-4.0.5

Description

Python to native compiler

Added to portage

2026-03-13

openapi-core - 0.23.0
Ebuild name:

dev-python/openapi-core-0.23.0

Description

Client-side and server-side support for the OpenAPI Specification v3

Added to portage

2026-03-13

org-modern - 1.13
Ebuild name:

app-emacs/org-modern-1.13

Description

Modern style for your GNU Emacs Org buffers

Added to portage

2026-03-13

pecan - 1.8.0
Ebuild name:

dev-python/pecan-1.8.0

Description

A WSGI object-dispatching web framework, lean, fast, with few dependencies

Added to portage

2026-03-13

postfix - 3.11.1-r1
Ebuild name:

mail-mta/postfix-3.11.1-r1

Description

A fast and secure drop-in replacement for sendmail

Added to portage

2026-03-13

postfix - 3.12_pre20260312
Ebuild name:

mail-mta/postfix-3.12_pre20260312

Description

A fast and secure drop-in replacement for sendmail

Added to portage

2026-03-13

pyjwt - 2.12.0
Ebuild name:

dev-python/pyjwt-2.12.0

Description

JSON Web Token implementation in Python

Added to portage

2026-03-13

pytest-env - 1.6.0
Ebuild name:

dev-python/pytest-env-1.6.0

Description

pytest plugin that allows you to add environment variables

Added to portage

2026-03-13

tempel - 1.12
Ebuild name:

app-emacs/tempel-1.12

Description

Templates with in-buffer field editing for GNU Emacs

Added to portage

2026-03-13

tibs - 0.5.7
Ebuild name:

dev-python/tibs-0.5.7

Description

A sleek Python library for your binary data

Added to portage

2026-03-13

vertico - 2.8
Ebuild name:

app-emacs/vertico-2.8

Description

Vertical interactive completion

Added to portage

2026-03-13

yt-dlp - 2026.03.13
Ebuild name:

net-misc/yt-dlp-2026.03.13

Description

youtube-dl fork with additional features and fixes

Added to portage

2026-03-13

yt-dlp-ejs - 0.7.0
Ebuild name:

dev-python/yt-dlp-ejs-0.7.0

Description

External JavaScript for yt-dlp supporting many runtimes

Added to portage

2026-03-13

zsnes - 2.1.0
Ebuild name:

games-emulation/zsnes-2.1.0

Description

Fork of the classic Super Nintendo emulator

Added to portage

2026-03-13

2026-03-12
ant - 1.10.15-r1
Ebuild name:

dev-java/ant-1.10.15-r1

Description

Java-based build tool similar to 'make' that uses XML configuration files

Added to portage

2026-03-12

apsw - 3.52.0.0
Ebuild name:

dev-python/apsw-3.52.0.0

Description

APSW - Another Python SQLite Wrapper

Added to portage

2026-03-12

awscli - 1.44.56
Ebuild name:

app-admin/awscli-1.44.56

Description

Universal Command Line Environment for AWS

Added to portage

2026-03-12

black - 26.3.1
Ebuild name:

dev-python/black-26.3.1

Description

The uncompromising Python code formatter

Added to portage

2026-03-12

boto3 - 1.42.66
Ebuild name:

dev-python/boto3-1.42.66

Description

The AWS SDK for Python

Added to portage

2026-03-12

botocore - 1.42.66
Ebuild name:

dev-python/botocore-1.42.66

Description

Low-level, data-driven core of boto 3

Added to portage

2026-03-12

chrome-binary-plugins - 147.0.7727.3_beta
Ebuild name:

www-plugins/chrome-binary-plugins-147.0.7727.3_beta

Description

Binary plugins from Google Chrome for use in Ch

Added to portage

2026-03-12

chromium - 147.0.7727.3
Ebuild name:

www-client/chromium-147.0.7727.3

Description

Open-source version of Google Chrome web browser

Added to portage

2026-03-12

commons-logging - 1.3.6
Ebuild name:

dev-java/commons-logging-1.3.6

Description

Thin adapter allowing configurable bridging to other well known logg

Added to portage

2026-03-12

cvector - 1.0.4.1
Ebuild name:

dev-libs/cvector-1.0.4.1

Description

An ANSI C implementation of dynamic arrays (approximation of C++ vectors)

Added to portage

2026-03-12

deno-bin - 2.7.5
Ebuild name:

dev-lang/deno-bin-2.7.5

Description

Modern runtime for JavaScript and TypeScript

Added to portage

2026-03-12

dist-kernel - 6.18.17
Ebuild name:

virtual/dist-kernel-6.18.17

Description

Virtual to depend on any Distribution Kernel

Added to portage

2026-03-12

dist-kernel - 6.19.7
Ebuild name:

virtual/dist-kernel-6.19.7

Description

Virtual to depend on any Distribution Kernel

Added to portage

2026-03-12

dotnet-outdated - 4.7.1
Ebuild name:

dev-dotnet/dotnet-outdated-4.7.1

Description

Display and update outdated NuGet packages in a project

Added to portage

2026-03-12

filelock - 3.25.2
Ebuild name:

dev-python/filelock-3.25.2

Description

A platform independent file lock for Python

Added to portage

2026-03-12

gentoo-kernel - 6.18.17
Ebuild name:

sys-kernel/gentoo-kernel-6.18.17

Description

Linux kernel built with Gentoo patches

Added to portage

2026-03-12

gentoo-kernel - 6.19.7
Ebuild name:

sys-kernel/gentoo-kernel-6.19.7

Description

Linux kernel built with Gentoo patches

Added to portage

2026-03-12

gentoo-kernel-bin - 6.18.17
Ebuild name:

sys-kernel/gentoo-kernel-bin-6.18.17

Description

Pre-built Linux kernel with Gentoo patches

Added to portage

2026-03-12

gentoo-kernel-bin - 6.19.7
Ebuild name:

sys-kernel/gentoo-kernel-bin-6.19.7

Description

Pre-built Linux kernel with Gentoo patches

Added to portage

2026-03-12

ghdl - 6.0.0
Ebuild name:

sci-electronics/ghdl-6.0.0

Description

Open-source analyzer, compiler, and simulator for VHDL 2008/93/87

Added to portage

2026-03-12

ghostty - 1.3.0-r1
Ebuild name:

x11-terms/ghostty-1.3.0-r1

Description

Fast, feature-rich, and cross-platform terminal emulator

Added to portage

2026-03-12

google-chrome-beta - 147.0.7727.3
Ebuild name:

www-client/google-chrome-beta-147.0.7727.3

Description

The web browser from Google

Added to portage

2026-03-12

ig - 0.50.1
Ebuild name:

app-admin/ig-0.50.1

Description

Tools and framework for data collection and system inspection using eBPF

Added to portage

2026-03-12

jupyterlab - 4.5.6
Ebuild name:

dev-python/jupyterlab-4.5.6

Description

JupyterLab computational environment

Added to portage

2026-03-12

man-pages-ja - 20260115-r1
Ebuild name:

app-i18n/man-pages-ja-20260115-r1

Description

Collection of manual pages translated into Japanese

Added to portage

2026-03-12

maven-bin - 3.9.13
Ebuild name:

dev-java/maven-bin-3.9.13

Description

Project Management and Comprehension Tool for Java

Added to portage

2026-03-12

microsoft-edge-beta - 146.0.3856.54
Ebuild name:

www-client/microsoft-edge-beta-146.0.3856.54

Description

The web browser from Microsoft

Added to portage

2026-03-12

multi-term - 1.4-r1
Ebuild name:

app-emacs/multi-term-1.4-r1

Description

Manage multiple terminal buffers in Emacs

Added to portage

2026-03-12

notebook - 7.5.5
Ebuild name:

dev-python/notebook-7.5.5

Description

Jupyter Interactive Notebook

Added to portage

2026-03-12

nvc - 1.19.3
Ebuild name:

sci-electronics/nvc-1.19.3

Description

NVC is a VHDL compiler and simulator

Added to portage

2026-03-12

openpgp-keys-apache-maven - 20250309
Ebuild name:

sec-keys/openpgp-keys-apache-maven-20250309

Description

OpenPGP keys used by maven.apache.org

Added to portage

2026-03-12

qlementine - 1.4.2
Ebuild name:

dev-qt/qlementine-1.4.2

Description

Modern QStyle for desktop Qt6 applications.

Added to portage

2026-03-12

qt-creator - 19.0.0
Ebuild name:

dev-qt/qt-creator-19.0.0

Description

Lightweight IDE for C++/QML development centering around Qt

Added to portage

2026-03-12

simpleeval - 1.0.4
Ebuild name:

dev-python/simpleeval-1.0.4

Description

A simple, safe single expression evaluator library

Added to portage

2026-03-12

socket_wrapper - 1.5.2
Ebuild name:

net-libs/socket_wrapper-1.5.2

Description

Library passing all socket communications through unix sockets

Added to portage

2026-03-12

solarus - 2.0.3-r1
Ebuild name:

games-engines/solarus-2.0.3-r1

Description

An open-source Zelda-like 2D game engine

Added to portage

2026-03-12

solarus-quest-editor - 2.0.3
Ebuild name:

games-misc/solarus-quest-editor-2.0.3

Description

Quest editor for Solarus game engine

Added to portage

2026-03-12

sqlite - 3.52.0-r1
Ebuild name:

dev-db/sqlite-3.52.0-r1

Description

SQL database engine

Added to portage

2026-03-12

thunderbird - 140.8.1
Ebuild name:

mail-client/thunderbird-140.8.1

Description

Thunderbird Mail Client

Added to portage

2026-03-12

thunderbird-bin - 140.8.1
Ebuild name:

mail-client/thunderbird-bin-140.8.1

Description

Thunderbird Mail Client

Added to portage

2026-03-12

tmuxp - 1.67.0
Ebuild name:

app-misc/tmuxp-1.67.0

Description

tmux session manager. built on libtmux

Added to portage

2026-03-12

ujson - 5.12.0
Ebuild name:

dev-python/ujson-5.12.0

Description

Ultra fast JSON encoder and decoder for Python

Added to portage

2026-03-12

vanilla-kernel - 6.18.17
Ebuild name:

sys-kernel/vanilla-kernel-6.18.17

Description

Linux kernel built from vanilla upstream sources

Added to portage

2026-03-12

vanilla-kernel - 6.19.7
Ebuild name:

sys-kernel/vanilla-kernel-6.19.7

Description

Linux kernel built from vanilla upstream sources

Added to portage

2026-03-12

vanilla-sources - 6.18.17
Ebuild name:

sys-kernel/vanilla-sources-6.18.17

Description

Full sources for the Linux kernel

Added to portage

2026-03-12

vanilla-sources - 6.19.7
Ebuild name:

sys-kernel/vanilla-sources-6.19.7

Description

Full sources for the Linux kernel

Added to portage

2026-03-12

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