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:

82317

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
2025-12-07
evolution - 3.58.2-r1
Ebuild name:

mail-client/evolution-3.58.2-r1

Description

Integrated mail, addressbook and calendaring functionality

Added to portage

2025-12-07

meson - 1.9.2
Ebuild name:

dev-build/meson-1.9.2

Description

Open source build system

Added to portage

2025-12-07

2025-12-06
aardvark-dns - 1.17.0
Ebuild name:

app-containers/aardvark-dns-1.17.0

Description

A container-focused DNS server

Added to portage

2025-12-06

aiodns - 3.6.0
Ebuild name:

dev-python/aiodns-3.6.0

Description

Simple DNS resolver for asyncio

Added to portage

2025-12-06

awscli - 1.43.10
Ebuild name:

app-admin/awscli-1.43.10

Description

Universal Command Line Environment for AWS

Added to portage

2025-12-06

bcc - 0.35.0-r2
Ebuild name:

dev-util/bcc-0.35.0-r2

Description

Tools for BPF-based Linux IO analysis, networking, monitoring, and more

Added to portage

2025-12-06

bcrypt_pbkdf - 1.1.2
Ebuild name:

dev-ruby/bcrypt_pbkdf-1.1.2

Description

Implements bcrypt_pdkfd (a variant of PBKDF2 with bcrypt-based PRF)

Added to portage

2025-12-06

blas-lapack-aux-wrapper - 3
Ebuild name:

sci-libs/blas-lapack-aux-wrapper-3

Description

BLAS/LAPACK wrappers for FlexiBLAS

Added to portage

2025-12-06

boto3 - 1.42.4
Ebuild name:

dev-python/boto3-1.42.4

Description

The AWS SDK for Python

Added to portage

2025-12-06

botocore - 1.42.4
Ebuild name:

dev-python/botocore-1.42.4

Description

Low-level, data-driven core of boto 3

Added to portage

2025-12-06

fastfetch - 2.56.0
Ebuild name:

app-misc/fastfetch-2.56.0

Description

Fast neofetch-like system information tool

Added to portage

2025-12-06

gcc - 13.4.1_p20251204
Ebuild name:

sys-devel/gcc-13.4.1_p20251204

Description

The GNU Compiler Collection

Added to portage

2025-12-06

gcc - 14.3.1_p20251205
Ebuild name:

sys-devel/gcc-14.3.1_p20251205

Description

The GNU Compiler Collection

Added to portage

2025-12-06

gnatmem - 2021-r6
Ebuild name:

dev-ada/gnatmem-2021-r6

Description

Monitors dynamic allocation and deallocation activity in a program

Added to portage

2025-12-06

go - 1.24.11
Ebuild name:

dev-lang/go-1.24.11

Description

A concurrent garbage collected and typesafe programming language

Added to portage

2025-12-06

go - 1.25.5
Ebuild name:

dev-lang/go-1.25.5

Description

A concurrent garbage collected and typesafe programming language

Added to portage

2025-12-06

hotspot - 1.5.1_p20250907
Ebuild name:

dev-debug/hotspot-1.5.1_p20250907

Description

Linux perf GUI for performance analysis

Added to portage

2025-12-06

hotspot - 9999
Ebuild name:

dev-debug/hotspot-9999

Description

Linux perf GUI for performance analysis

Added to portage

2025-12-06

knot - 3.4.9-r1
Ebuild name:

net-dns/knot-3.4.9-r1

Description

High-performance authoritative-only DNS server

Added to portage

2025-12-06

knot - 3.5.2-r1
Ebuild name:

net-dns/knot-3.5.2-r1

Description

High-performance authoritative-only DNS server

Added to portage

2025-12-06

libgit2 - 1.9.2
Ebuild name:

dev-libs/libgit2-1.9.2

Description

A linkable library for Git

Added to portage

2025-12-06

librt - 0.7.2
Ebuild name:

dev-python/librt-0.7.2

Description

Mypyc runtime library

Added to portage

2025-12-06

libtmux - 0.50.1
Ebuild name:

dev-python/libtmux-0.50.1

Description

Typed library that provides an ORM wrapper for tmux, a terminal multiplex

Added to portage

2025-12-06

marshmallow - 4.1.1
Ebuild name:

dev-python/marshmallow-4.1.1

Description

A library for converting to and from native Python datatypes

Added to portage

2025-12-06

netavark - 1.17.0
Ebuild name:

app-containers/netavark-1.17.0

Description

A container network stack

Added to portage

2025-12-06

openblas - 0.3.30-r4
Ebuild name:

sci-libs/openblas-0.3.30-r4

Description

Optimized BLAS library based on GotoBLAS2

Added to portage

2025-12-06

orjson - 3.11.5
Ebuild name:

dev-python/orjson-3.11.5

Description

Fast, correct Python JSON library supporting dataclasses, datetimes, and n

Added to portage

2025-12-06

pbs-installer - 2025.12.5
Ebuild name:

dev-python/pbs-installer-2025.12.5

Description

Installer for Python Build Standalone

Added to portage

2025-12-06

phonenumbers - 9.0.20
Ebuild name:

dev-python/phonenumbers-9.0.20

Description

Python port of Google's libphonenumber

Added to portage

2025-12-06

platformdirs - 4.5.1
Ebuild name:

dev-python/platformdirs-4.5.1

Description

A small Python module for determining appropriate platform-specific d

Added to portage

2025-12-06

postfix - 3.11_pre20251205
Ebuild name:

mail-mta/postfix-3.11_pre20251205

Description

A fast and secure drop-in replacement for sendmail

Added to portage

2025-12-06

protobuf - 6.33.2
Ebuild name:

dev-python/protobuf-6.33.2

Description

Google's Protocol Buffers - Python bindings

Added to portage

2025-12-06

psycopg - 3.3.2
Ebuild name:

dev-python/psycopg-3.3.2

Description

PostgreSQL database adapter for Python

Added to portage

2025-12-06

ptools - 1.5.2
Ebuild name:

dev-ruby/ptools-1.5.2

Description

Several handy methods to Ruby's core File class

Added to portage

2025-12-06

pyqt-builder - 1.19.1
Ebuild name:

dev-python/pyqt-builder-1.19.1

Description

The PEP 517 compliant PyQt build system

Added to portage

2025-12-06

pyqt6 - 6.10.1
Ebuild name:

dev-python/pyqt6-6.10.1

Description

Python bindings for the Qt framework

Added to portage

2025-12-06

pytest-jobserver - 1.0.0
Ebuild name:

dev-python/pytest-jobserver-1.0.0

Description

Limit parallel tests with POSIX jobserver

Added to portage

2025-12-06

python - 0.3.13.11
Ebuild name:

dev-lang/python-0.3.13.11

Description

Freethreading (no-GIL) version of Python programming language

Added to portage

2025-12-06

python - 0.3.14.2
Ebuild name:

dev-lang/python-0.3.14.2

Description

Freethreading (no-GIL) version of Python programming language

Added to portage

2025-12-06

python - 3.13.11
Ebuild name:

dev-lang/python-3.13.11

Description

An interpreted, interactive, object-oriented programming language

Added to portage

2025-12-06

python - 3.14.2
Ebuild name:

dev-lang/python-3.14.2

Description

An interpreted, interactive, object-oriented programming language

Added to portage

2025-12-06

python-lsp-server - 1.14.0
Ebuild name:

dev-python/python-lsp-server-1.14.0

Description

Python Language Server for the Language Server Protocol

Added to portage

2025-12-06

python-tests - 0.3.13.11
Ebuild name:

dev-python/python-tests-0.3.13.11

Description

Test modules from dev-lang/python

Added to portage

2025-12-06

python-tests - 0.3.14.2
Ebuild name:

dev-python/python-tests-0.3.14.2

Description

Test modules from dev-lang/python

Added to portage

2025-12-06

python-tests - 3.13.11
Ebuild name:

dev-python/python-tests-3.13.11

Description

Test modules from dev-lang/python

Added to portage

2025-12-06

python-tests - 3.14.2
Ebuild name:

dev-python/python-tests-3.14.2

Description

Test modules from dev-lang/python

Added to portage

2025-12-06

rackup - 2.3.1
Ebuild name:

dev-ruby/rackup-2.3.1

Description

A general server command for Rack applications

Added to portage

2025-12-06

rdoc - 6.16.1
Ebuild name:

dev-ruby/rdoc-6.16.1

Description

An extended version of the RDoc library from Ruby 1.8

Added to portage

2025-12-06

recog - 3.1.24
Ebuild name:

dev-ruby/recog-3.1.24

Description

Pattern recognition for hosts, services, and content

Added to portage

2025-12-06

ssss - 0.5.7-r3
Ebuild name:

app-crypt/ssss-0.5.7-r3

Description

Shamir's Secret Sharing Scheme

Added to portage

2025-12-06

stan - 0.4.1-r1
Ebuild name:

app-crypt/stan-0.4.1-r1

Description

Stan analyzes binary streams and calculates statistical information

Added to portage

2025-12-06

statsmodels - 0.14.6
Ebuild name:

dev-python/statsmodels-0.14.6

Description

Statistical computations and models for use with SciPy

Added to portage

2025-12-06

stoken - 0.92-r3
Ebuild name:

app-crypt/stoken-0.92-r3

Description

Software Token for Linux/UNIX

Added to portage

2025-12-06

stringio - 3.1.9
Ebuild name:

dev-ruby/stringio-3.1.9

Description

Pseudo IO class from/to String.

Added to portage

2025-12-06

swtpm - 0.10.0
Ebuild name:

app-crypt/swtpm-0.10.0

Description

Libtpms-based TPM emulator

Added to portage

2025-12-06

test-unit - 3.7.3
Ebuild name:

dev-ruby/test-unit-3.7.3

Description

An xUnit family unit testing framework for Ruby

Added to portage

2025-12-06

test-unit-ruby-core - 1.0.14
Ebuild name:

dev-ruby/test-unit-ruby-core-1.0.14

Description

Additional test assertions for Ruby standard libraries

Added to portage

2025-12-06

transformers - 4.57.3
Ebuild name:

sci-ml/transformers-4.57.3

Description

State-of-the-art Machine Learning for JAX, PyTorch and TensorFlow

Added to portage

2025-12-06

tree-sitter-bash - 0.25.1
Ebuild name:

dev-libs/tree-sitter-bash-0.25.1

Description

Bash grammar for Tree-sitter

Added to portage

2025-12-06

tree-sitter-cmake - 0.7.2
Ebuild name:

dev-libs/tree-sitter-cmake-0.7.2

Description

CMake grammar for tree-sitter

Added to portage

2025-12-06

tree-sitter-query - 0.8.0
Ebuild name:

dev-libs/tree-sitter-query-0.8.0

Description

Tree-sitter query grammar for Tree-sitter

Added to portage

2025-12-06

urllib3 - 2.6.0
Ebuild name:

dev-python/urllib3-2.6.0

Description

HTTP library with thread-safe connection pooling, file post, and more

Added to portage

2025-12-06

uv - 0.9.16
Ebuild name:

dev-python/uv-0.9.16

Description

A Python package installer and resolver, written in Rust

Added to portage

2025-12-06

uv-build - 0.9.16
Ebuild name:

dev-python/uv-build-0.9.16

Description

PEP517 uv build backend

Added to portage

2025-12-06

vivaldi - 7.7.3851.58
Ebuild name:

www-client/vivaldi-7.7.3851.58

Description

A browser for our friends

Added to portage

2025-12-06

vivaldi-snapshot - 7.8.3885.4
Ebuild name:

www-client/vivaldi-snapshot-7.8.3885.4

Description

A browser for our friends

Added to portage

2025-12-06

xarray - 2025.12.0
Ebuild name:

dev-python/xarray-2025.12.0

Description

N-D labeled arrays and datasets in Python

Added to portage

2025-12-06

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