Multiseat configuration explained

A multiseat, multi-station or multiterminal system is a single computer which supports multiple independent local users at the same time. A "seat" consists of all hardware devices assigned to a specific workplace at which one user sits at and interacts with the computer. It consists of at least one graphics device (graphics card or just an output (e.g. HDMI/VGA/DisplayPort port) and the attached monitor/video projector) for the output and a keyboard and a mouse for the input. It can also include video cameras, sound cards and more.

Motivation

Since the 1960s computers have been shared between users. Especially in the early days of computing when computers were extremely expensive the usual paradigm was a central mainframe computer connected to numerous terminals. With the advent of personal computing this paradigm has been largely replaced by personal computers (or one computer per user).

Multiseat setups are a return to this multiuser paradigm but based around a PC which supports a number of zero-clients usually consisting of a terminal per user (screen, keyboard, mouse).

In some situations a multiseat setup is more cost-effective because it is not necessary to buy separate motherboards, microprocessors, RAM, hard disks and other components for each user. For example, buying one high speed CPU, usually costs less than buying several slower CPUs.

History

In the 1970s, it was very commonplace to connect multiple computer terminals to a single mainframe computer, even graphical terminals. Early terminals were connected with RS-232 type serial connections, either directly, or through modems. With the advent of Internet Protocol based networking, it became possible for multiple users to log into a host using telnet or – for a graphic environment – an X Window System "server". These systems would retain a physically secure "root console" for system administration and direct access to the host machine.

Support for multiple consoles in a PC running the X interface was implemented in 2001 by Miguel Freitas, using the Linux operating system and the X11 graphical system (at the time maintained by XFree86).[1] This was done using a patch in the display server to execute several instances of X at the same time such that each one captures specific mouse and keyboard events and the graphical content. This method received the name of multiseat or multiterminal.

In 2001, Thinsoft BeTwin offered a multiseat solution for Windows, utilizing multiple graphics cards and peripherals attached to a single host PC.[2]

In 2002 a Canadian company, Userful Corporation, released Userful Multiplier, a multiseat Linux software solution that enables up to 10 users to simultaneously share one computer.[3] Earlier they worked on a kernel-based approach to a multi-station platform computer, but abandoned the idea due to a problem with multiple video card support.

Other solutions appeared in 2003, such Svetoslav Slavtchev, Aivils Stoss and James Simmons worked, with the evdev and Faketty[4] [5] approach modifying the Linux kernel and letting more than one user independently use the same machine. In that time, the Linux Console Project[6] also proposed an idea to use multiple independent consoles and then multiple independent keyboards and mice in a project called "Backstreet Ruby".[7] Backstreet Ruby is a kernel patch for the Linux kernel. It is a back port to Linux-2.4 of the Ruby kernel tree. The aim of the Linux Console developers is to enhance and reorganize the input, the console and the framebuffer subsystems in the Linux kernel, so they can work independent from each other and to allow multi-desktop operation. The Backstreet Ruby idea was never finished.

In 2005, the C3SL team (Center for Scientific Computing and Free Software),[8] from the Federal University of Parana in Brazil, created a solution based on nested display servers, such as Xnest and Xephyr.[9] With this solution, each nested display server runs in each screen of a host display server (e.g. Xorg) and a modification to the nested servers let each one exclusively acquire its mouse and keyboard. In 2008, the C3SL group released the Multiseat Display Manager (MDM)[10] to ease the process of installation and configuration of a multiseat box. This group, also in 2008, conceived a live-CD[11] for test purposes.

In 2007, NComputing entered the market with a Windows-based multiseat product, the X-series[12] or Xtenda system, which uses a PCI add-in card to connect terminal units containing video, keyboard, mouse, and audio jacks, allowing 3 to 6 additional user seats to be added to a PC.[13] The X-series also offered Linux compatibility.[14]

In 2010, Microsoft began offering Windows MultiPoint Server, allowing one machine to host multiple users utilizing separate graphics cards and peripherals.

Automatic multiseat with USB docking stations is a feature of Fedora 17.[15] [16]

Time line, commercial multiseat software evolution

Requirements

Hardware requirements

Each user will require a monitor, keyboard and mouse connected to the host machine. For example, to make a four-head (four users) system would require four monitors, four keyboards, four mice and two dual-output, or one quad-output video card. USB keyboards and mice are typically recommended instead of PS/2 connections, as they can be connected to a USB hub. Additional devices and peripherals such as cameras, flash storage drives, card readers and touch screens could also be assigned to each seat. An alternative to multiple physical video cards and connections is DisplayLink over USB.

Software requirements

Linux

Multiseat on modern Linux systems is provided by systemd-logind[19] and configured through the loginctl command [20] or through ID_SEAT or ID_AUTOSEAT udev variables.[21]

Certain specialized USB hubs, when connected, automatically results in a seat without any configuration required.[22]

Microsoft Windows

For Windows 2000, XP and Vista operating systems, there are several commercial products to implement multiseat configurations for two or more seats.

An operating system designed specifically for multiseat setups entitled Windows MultiPoint Server was announced on February 24, 2010. It uses Remote Desktop (Terminal Services) technologies in Windows Server 2008 R2 to provide multiseat functionality. This functionality was incorporated into Windows Server proper as of Windows Server 2016 in a new server role entitled MultiPoint Services, but this server role was removed in Windows Server 2019 owing to Microsoft ceasing development of the service in 2018.

Virtualization-based setup

Instead of relying on operating system support for multiseat configuration, a hypervisor can be configured to run multiple virtual machines, each configured to interface one connected seat by I/O virtualization methods. Input devices can be attached to the virtual machines through USB Redirection, and entire GPUs can be attached through Intel VT-d.

The virtualization-based 2-seat and 7-seat systems with Unraid as the host operating system has been demonstrated. Each seat has exclusive control of one of the Windows guest operating systems running on the host. There is a dedicated high-end graphics card for each guest, which it takes full advantage of via the use of VT-d, making the system capable of hosting demanding video game sessions at full quality simultaneously on all seats.

Case studies

World's largest multiseat computer deployment

In February, 2009, The Brazil Ministry of Education committed to deploy 350,000 Linux-based multiseat computing stations in more than 45,000 rural and urban schools across the country. The chosen companies to implement this project were the Canadian multiseat Linux software company Userful Corporation, and its Brazilian IT partner ThinNetworks.[23]

Paraná Digital project

One of multiterminal's successful cases is happening at Paraná Digital project. It is creating multiterminal laboratories on 2000 public schools of the state of Paraná (Brazil). More than 1.5 million users will benefit from the 40,000 terminals when the project is finished. The laboratories have four-head multiterminals running Debian. The cost of all the hardware is 50% less than the normal price, and there is absolutely no cost with software. This project developer is C3SL (Center for Scientific Computing and Free Software).

Michigan State University research in Tanzania

Since 2008, electrical and computer engineering students from Michigan State University have installed multiterminal systems with internet access in three schools in Mto wa Mbu, Tanzania. The purpose of the project is to study the impact of having computer systems with internet access in an education system that cannot afford other educational resources such as books. The computer systems run Ubuntu 8.04 32-bit and utilize the open source Multiseat Display Manager created by C3SL. The research will eventually be used to present to government officials of third world countries in effort to showcase the positive impact of having cost-effective computing systems in schools. The project is sponsored by George and Vickie Rock and the Dow Chemical Company.[24] [25] [26]

Notable installations

See also

Notes and References

  1. http://cambuca.ldhs.cetuc.puc-rio.br/multiuser/ Multiuser PUC-RIO - Pontifícia Universidade Católica do Rio de Janeiro
  2. Book: ThinSoft Annual Report. 2001. 11.
  3. https://web.archive.org/web/20120229005514/http://www.echannelline.com/usa/story.cfm?item=25455 eChannel Line - Userful Upgrades Multi-Seat Linux Desktop Virtualization Solution
  4. http://www.ltn.lv/~aivils/index.php?proj_id=faketty Faketty LTN - SigmaNet klientu mājas lapas
  5. http://www.tldp.org/HOWTO/XFree-Local-multi-user-HOWTO/ XFree Local Multi-User HOWTO
  6. http://linuxconsole.sourceforge.net/ Linux Console
  7. http://www.ltn.lv/~aivils/?proj_id=ruby LTN - LATNET klientu mâjas lapas
  8. http://www.c3sl.ufpr.br/en/ Universidade Federal do Paraná
  9. http://wiki.c3sl.ufpr.br/multiseat/index.php/Xephyr_Solution Multiterminal com Xephyr
  10. http://wiki.c3sl.ufpr.br/multiseat/index.php/Mdm MDM Universidade Federal do Paraná
  11. http://wiki.c3sl.ufpr.br/multiseat/index.php/Live-CD Multiterminal live-cd from C3SL/UFPR for tests
  12. Book: Inc, Ziff Davis. PC Mag. 2007-11-06. Ziff Davis, Inc.. en.
  13. Web site: Abate. Tom. 2007-07-08. A lesson in technology sharing / Many PCs can use one microprocessor, helping schools reduce computer costs. 2021-09-14. SFGATE. en-US.
  14. Web site: Dawson. Christopher. NComputing X350 = classroom labs in a snap. 2021-09-14. ZDNet. en.
  15. http://fedoraproject.org/wiki/Features/ckremoval ConsoleKit Removal / Automatic Multi-Seat Support
  16. Web site: The Most Awesome, Least-Advertised Fedora 17 Feature.
  17. Web site: Open-sense Solutions . Nov 6, 2010.
  18. Web site: BoXedVDI . LISTEQ . 2014-03-25.
  19. Web site: . systemd-logind.service(8) . . 5 March 2022.
  20. Web site: . loginctl(1), Seat Commands . . 5 March 2022.
  21. Web site: sd-login(3), udev Rules . . . 5 March 2022.
  22. Web site: src/login/71-seat.rules.in . . . 5 March 2022.
  23. Web site: Backbone Magazine - Green Teach: Canadian virtualization technology for students in Brazil . Backbonemag.com . 2014-02-17 . https://web.archive.org/web/20140221222455/http://www.backbonemag.com/Magazine/Green_Trends_05270902.asp . 2014-02-21 . dead .
  24. Web site: ECE 480 Team 3 - Project Overview . msu.edu . Jun 16, 2010.
  25. Web site: ECE 480 Team 4 - Project Overview . msu.edu . Jun 16, 2010.
  26. Web site: Michigan State University College of Engineering Study Abroad ICT Development in Tanzania . msu.edu . Jul 19, 2010.
  27. Web site: Userful and ThinNetworks today announce that they have been selected to supply 356,800 virtualized desktops to schools in all of Brazil's 5,560 municipalities. . Userful.com . Feb 17, 2008.
  28. Web site: All Macedonian students to use Linux desktops . 2009-05-24 . https://web.archive.org/web/20081220125238/http://www.desktoplinux.com/news/NS7546509093.html . 2008-12-20 . dead .