How to Run a Headless Parallella08 Dec 2015
Running a computer “headless” means running it with no display, no keyboard, no mouse. The only directly attached cables are power and a network connection.
Why would you run a computer headless? Headless configurations are typically used in a data center with hundreds of servers and limited space. Since a well-running server rarely needs direct interaction, you can save space (and money) by skipping the monitor/mouse/keyboard installation, and only connecting these devices when needed.
Even better: Don’t connect via USB/HDMI. Why spend time walking to a server and connecting via USB when you can connect electronically over the network? Headless servers rock!
This post tells how to connect to a headless Parallella from a Mac. The procedure should work with other Linux/Unix systems with minor minor modifications, depending on the distribution in use.
(You can skip this step if you’re connecting from a Unix or Linux system. Linux/Unix already have X Window installed. Mac OS X does not.)
If you only want to run terminal-based programs via
ssh, you will not need to install XQuartz. Since Parallella’s GUI programs are X Window based, installing XQuartz will let you run the Parallella’s GUI programs on your Mac.
Mac OS X is a variation of Unix, but it does not include the Unix X Window environment. Download and install XQuartz onto the Mac OS X machine. XQuartz will give your Mac the X Window environment needed for this process to work.
Configure Host Machine (Parallella) to Allow X Over SSH
/etc/ssh/ssh_config controlls the behavior of the SSH server on the Parallella. By default, SSH does now allow X Window information to flow to/from the Parallella. To enable X Window support, here’s what you have to do.
(Be sure to read the sudo disclaimer before executing the rest of these instructions. We’re using
sudo in this case because
ssh_config can only be modified with root priviledges.)
/etc/ssh/ssh_config in a text editor like Vim. You’ll need to use
sudo so that the file system allows you to write the file after you modify it.
$ sudo vim /etc/ssh/ssh_config
Two parameters in the
ssh_config file need to be changed on the Parallella host. Add the following lines to the bottom of the
ssh_config file on the Parallella:
ForwardAgent yes ForwardX11 yes
Save the file and re-start the Parallella so that the new parameters can take effect.
Confirm the X Window Connection
To test the new configuration, first log into the Parallella from the Mac using the
-X flag (note that “X” is capitalized) like so:
~$ ssh -X linaro@[IP address of the Parallella] linaro@[IP address of the Parallella]'s password:
And then, from a Mac terminal window, run an X Window program like
XClock should appear on your Mac display. Success!
Setting Up Xvfb
Xvfb is the X virtual frame buffer. It lets you view the Parallella’s frame buffer through X, either locally or remotely. To set it up, first install
Xvfb on the Parallella.
$ sudo apt-get install xvfb Reading package lists... Done Building dependency tree Reading state information... Done The following NEW packages will be installed: xvfb 0 upgraded, 1 newly installed, 0 to remove and 0 not upgraded. Need to get 629 kB of archives. After this operation, 1351 kB of additional disk space will be used. Get:1 http://ports.ubuntu.com/ubuntu-ports/ trusty/main xvfb armhf 2:1.15.1-0ubuntu2 [629 kB] Fetched 629 kB in 1s (406 kB/s) Selecting previously unselected package xvfb. (Reading database ... 83530 files and directories currently installed.) Preparing to unpack .../xvfb_2%3a1.15.1-0ubuntu2_armhf.deb ... Unpacking xvfb (2:1.15.1-0ubuntu2) ... Processing triggers for man-db (22.214.171.124-1) ... Setting up xvfb (2:1.15.1-0ubuntu2) ...
Here’s something weird. When you install
Xvfb on the Parallella via
sudo apt-get, the
x is lower case. But after installation, when you run the program from the Parallella’s command line, the
Xvfb is capitalized.
$ which xvfb xvfb: Command not found. $ which Xvfb /usr/bin/Xvfb $
I don’t know why this is true. I only know that it caught me. Now it won’t catch you!
Eliminating Barriers to Entry
I am grateful to other members of the Parallella community who write articles and blog posts about their experiences with the device. Together, we are working to make parallel programming accessible to as many people as possible. Maybe you will contribute next? I look forward to reading about your work with Parallella and parallel programming in general.