-
Notifications
You must be signed in to change notification settings - Fork 0
Commands
- 1 ltsp-info
- 2 ltsp-build-client
- 3 ltsp-update-image
- 4 ltsp-update-sshkeys
- 5 ltsp-update-kernels
- 6 ltsp-config
- 7 ltsp-chroot
- 8 ltsp-local-apps
- 9 ltsp-remoteapps
- 10 nbdswapd
This server command shows information about your LTSP installation, server packages, and related client packages from each chroot in $BASE.
root@server #``ltsp-info
Retrieving package information is distro specific. For this command to fully work on a distro, some distro-specific functions have to written to retrieve this package information. These functions are server_packages(), chroot_packages() and chroot_release().
/usr/share/ltsp/ltsp-info-functions
# Debian-specific function overrides for ltsp-info
server_packages() {
echo server packages:
COLUMNS=200 dpkg -l 'ltsp*' 'ldm*' | awk '/ltsp|ldm/{print ,,}'
echo
}
chroot_packages() {
chroot=
if [ -f $chroot/var/lib/dpkg/status ]; then
echo "packages in chroot: $chroot"
COLUMNS=200 dpkg --root=$chroot -l 'ltsp*' 'ldm*' | awk '/ltsp-client|ldm|ltspfs/{print ,,}'
echo
fi
}
chroot_release() {
if [ -x $chroot/usr/bin/lsb_release ]; then
echo "chroot information: $chroot"
ROOT=$chroot ltsp-chroot lsb_release --all
echo
fi
}
commandline option | config option | description | notes |
---|---|---|---|
arch | ARCH | set the target architecture | |
base | BASE | set the default base install directory | preferably, set this config in ltsp-server.conf |
chroot | CHROOT | set the name of the chroot | if not set, the value for arch becomes the name |
config | - | load a user specific configuration file | |
debug | DEBUG | enable debug support | |
exclude | EXCLUDE | exclude packages from the initial chroot | |
purge-chroot | PURGE_CHROOT | purge existing LTSP chroot if present | think twice to set in config file |
The possible full usage is different for each distribution, refer to your distro's installation page for those details. Also, the following command shows all distro specific options:
user@server $``ltsp-build-client --extra-help
The command is able to perform a distro specific client installation by making use of plugins. When starting, plugins are called by the "load_plugins" function. Common plugins are located in /usr/share/ltsp/plugins/ltsp-build-client/common, while vendor-specific plugins are defined in /usr/share/ltsp/plugins/ltsp-build-client/$DISTRO. If a distro plugin has the same filename as a common plugin, it will override the common plugin. The plugin code is used in different phases. A plugin typically only uses some of the available phases.
- commandline
- configure
- before-install
- install
- after-install
- finalization
Any commandline options for ltsp-build-client are defined here. The commandline argument itself can be specified as well as the value type (string or boolean). Also a description and an "advanced" flag for display in the regular help section or the advanced help section. The syntax is as follows:
add_option "" "eval_gettext "<description>"
" "<help section (advanced or regular)>" "<value type (false for string, true for boolean)>"
Any commandline or config file options can be processed here. The commandline options will be available as $option__value, where any dashes in the option name will be converted to underscores. The config file variables are available as is.
In this phase the initial chroot is built. This will obviously vary greatly for each distro.
In the finalization phase, you may want to install additional packages that needed custom configurations to other software before installing, such as a kernel (which may require certain initramfs tweaks). you may also want to copy the kernel images into a location accessible by tftp at this phase, or seed the chroot's /etc/ssh/ssh_known_hosts file with your server's public ssh keys.
/usr/share/ltsp/plugins/ltsp-build-client/Gentoo/020-rootpath
case "$MODE" in
commandline)
add_option "purge-chroot" "
eval_gettext "purge existing LTSP chroot if present"" "advanced" "false"
;;
configure)
if [ "true" = "$option_purge_chroot_value" ]; then
PURGE_CHROOT="true"
fi
;;
before-install)
export ROOT=$BASE/$CHROOT
if [ -d $ROOT ] ; then
if [ "true" = "$PURGE_CHROOT" ]; then
# wipe it out, so we can try again
rm --force --recursive --one-file-system "$ROOT"
else
echo "NOTE: Root directory $ROOT already exists, this will lead to problems, please remove it before trying again. Exiting."
exit 0
fi
fi
mkdir -p "$ROOT"
;;
esac
\
This command creates an nbd bootable squashfs image for the specified chroot name or architecture. By default this should be a directory in /opt/ltsp.
root@server #``ltsp-update-image <name or arch>
This command updates the client chroots with the server's public ssh keys. Normally, when building a chroot with ltsp-build-client, this is done automatically. You have to use this command when your server changes its IP address.
root@server #``ltsp-update-sshkeys
This command copies the boot/ directory from LTSP chroots to the TFTP directories in order to make them available to PXE clients. Copying kernels from inside NBD images is also supported. CHROOT can be a full path or a subdirectory of the /opt/ltsp base directory, and if it's unset, all available chroots are processed.
root@server #``ltsp-update-kernels i686
Running an LTSP server requires certain other tools like a DHCP or NBD server, with specific configurations. With ltsp-config you can generate or update these configuration files based on your current setup.
The ltsp-config command accepts several options to generate the files: dnsmasq, isc-dhcp-server, lts.conf and nbd-server. The first three should be run manually, the configuration of nbd-server is called automatically at the end of ltsp-update-image. For instance, to generate a dnsmasq config file do:
root@server #``ltsp-config dnsmasq
Updating or generating a configuration file for a service, requires the service to be restarted. Because the various distro's use different methods for initializing service scripts, the function to call a service can be distro specific.
/usr/share/ltsp/ltsp-config-functions
# Gentoo-specific function overrides for ltsp-config
\
service() {
if [ -x /sbin/rc-service ]; then
rc-service "$@"
fi
}
When chrooting into the client, you don't have your package tree in the client chroot by default. In the installation, the server package tree (among others) is bind mounted in the client tree, which means the client chroot actually uses the server's copied package tree. The command ltsp-chroot can be used to chroot into a specified chroot.
By default it chroots into /opt/ltsp/ and mounts nothing. Default behavior can be changed by using the ltsp-chroot.conf file, or by using command line arguments. The following example mounts the package dirs and chroots into /opt/ltsp-dev/amd64.
root@server #``ltsp-chroot -a amd64 -b /opt/ltsp-dev --mount-package-cache
Typically mounting the package cache is distribution specific. This function typically bind mounts the server directories containing the available packages. The mount_package_cache() function can be defined in the distro specific extension for ltsp-chroot.
/usr/share/ltsp/ltsp-chroot-functions
# Gentoo-specific function overrides for ltsp-chroot
\
mount_package_cache() {
mark_mount --bind /usr/portage "$ROOT/usr/portage"
mark_mount --bind "/usr/portage/packages/${ARCH}" "$ROOT/usr/portage/packages"
# remove if ltsp ever in portage tree
mark_mount --bind "/var/lib/layman" "$ROOT/var/lib/layman"
}
Applications typically run on the server, and display their output on the thin client display. With LTSP, it is possible to run an application on the thin client, thereby utilizing more of the local resources and putting less of a load on the server. We call this Local Apps.
If you want apps to run on the client itself, a few changes need to be made. First of all, an extra line in your lts.conf.
lts.conf
LOCAL_APPS = True
Each application which has to run locally, needs to be installed in the client chroot. You can do this by updating your client chroot environment and installing the desired packages. It is also possible to combine this with your ltsp-build-client by adding the packages to the build client configuration. After rebooting the client you can now run any application which is installed in the chroot by issuing the following command:
user@server $``ltsp-localapps xterm