COMP 3000 2011 Report: CrunchBang
The Linux distribution I chose is CrunchBang which is commonly referred to as '#!'. CrunchBang is "designed to offer a modern, full-featured GNU/Linux system without sacrificing performance."<ref name="About CrunchBang">About Crunchbang Linux. (2011, Feb. 18). Retrieved October 14, 2011 from http://crunchbanglinux.org/wiki/about</ref> CrunchBang boasts that it is faster than Debian, while still being compatible with all Debian packages. Another key feature is that it is highly configurable due to its usage of several highly-customizable components (Openbox window manager, Thunar file manager and Conky system monitor in particular are all mentioned on the about page)<ref name="About CrunchBang"/>.
From browsing the forums, it appears that CrunchBang appeals to users who like to customize their desktop appearance. Some of the most popular threads on the forums are those for screenshots of the users' desktops. In fact, they have monthly threads solely for this purpose, and the threads for August 2011 and September 2011 had over 1000 replies each. There is also a DeviantArt page for users of CrunchBang to post their themes, screenshots, desktops and such.
CrunchBang was created and continues to be developed by Philip Newborough<ref name="wiki">CrunchBang Linux. (2011, Sep. 26). Retrieved October 14, 2011 from http://en.wikipedia.org/wiki/CrunchBang_Linux</ref> who goes by the name "corenominal" on the CrunchBang forums and on his blog. Philip does all of the development himself.
The latest release of CrunchBang, called CrunchBang 10 "Statler" R20110207, is available in 32-bit and 64-bit versions with either the Openbox window manager or the Xfce4 desktop manager. They are available for download as torrents from the CrunchBang downloads page. The installation CD images are between 640-690MB in size, while a fresh installation of 64-bit CrunchBang took about 1.7 GB of hard disk space.
After booting CrunchBang from an installation image, it gives you the option of running it as one of two live sessions, performing a text-based installation, or a graphical installation (as well as running a memory test). As there were two versions of CrunchBang, one using the Openbox window manager, and another using xfce4, I chose to install both, doing the graphical installation for the Openbox version, and text-based for xfce.
I performed both installations from VirtualBox, giving both systems identical hardware (16 GB hard disks, 512 MB of memory). Aside from the obvious difference in appearance between the two installation methods, there was no difference in the installation.
The time taken for both installation methods was roughly 10 minutes and, just after installation, used roughly 1.7 GB of space on the virtual hard drive (though their virtual disk files on the host operating system were around 1.9 GB). No problems were experienced during either installation of CrunchBang, though there were problems installing the VirtualBox guest additions afterwards. Following the steps listed on their how-to wiki page did not work. Even after installing the appropriate packages as instructed, running the VBoxLinuxAdditions.run script simply produced no output. Following the instructions found on their forums at http://crunchbanglinux.org/forums/post/129314/#p129314 solved the issue. The same issue occurred in Debian, so it is not just a CrunchBang issue.
One feature I particularly liked was the startup script that it came with. Upon the first launch of a CrunchBang installation, a terminal is open running a script to automatically install a number of extra pieces of software, such as Java, OpenOffice, printer drivers, LAMP, an optional upgrade to the Liquorix/Zen kernel, as well as performing software updates.
The main menu can be reached by a keyboard shortcut (super+space with openbox, super+alt with xfce), while the xfce version also has a small menu that pops open from the left side of the screen when the mouse is brought near.
Comparison to Debian
As CrunchBang boasts that it is a fast distribution, and since it is based upon Debian, I installed Debian in VirtualBox, giving it the same amount of memory as CrunchBang so as to compare the two. The Debian installation was much slower and larger, taking about an hour to install and occupying 3.2 GB of hard disk space. To be fair, Debian's installation disk was smaller (172 MB) and it had to download more than CrunchBang did which accounts for some of the difference in installation time.
To compare the speed of the two distributions I timed how long they took to compile the Linux kernel, using the latest stable release: 3.0.4. CrunchBang took 2 hours, 53 minutes and 4.917 seconds to compile while Debian took 2 hours, 39 minutes and 11.651 seconds to compile which somewhat belies CrunchBang's claim of being faster than Debian.
CrunchBang does boot up significantly faster than Debian. It took about 19 seconds for CrunchBang to boot to the login screen, whereas Debian took about 37 seconds. With only the startup processes and terminal running, Debian hovered around 324 MB of memory usage and 0.3-1.0% CPU usage, while CrunchBang used 267 MB of memory and 2-3% CPU usage. Killing the Conky process (which displays system information on the desktop) dropped CrunchBang to roughly 1% CPU usage.
CrunchBang boasts that it is highly configurable, so I took a look at some of the things that can be customized. The menu does not automatically add programs when they are installed but items can be added to it by editing an xml file or from a GUI utility. Using the GUI utility, obconf, it was easy to add new items to the menu. One neat thing it could do is have scripts run from the menu, for example to list all the files that had recently been opened.
New themes for the window borders are basically a text file that contains colors and border sizes, similar to CSS, and images to be used as the icons on a window. The content of windows can by styled with GTK themes.
Other things, such as the login screen, Conky information and menus can all be configured. The learning curve for getting getting started with customization can be steep. The Openbox theme guide alone is over 5500 words. Since each of these custom elements use their own specification, changing all of them to one's liking would take a not insignificant amount of time to develop proficiency.
CrunchBang is a nice platform for those who like customizing the look of their system. That is not to say that the same could not be done on other systems. All of the customizable pieces of software contained in CrunchBang could be installed on Debian or other Linux distributions allowing for the same level of customization. CrunchBang itself does not actually help with the configuration, aside from including the different packages as part of the installation.
I really liked the startup script that goes lets the user pick a number of commonly-used packages to install. I wish other platforms had this; it would make installing Windows quite a bit faster.
One funny feature of the latest version of CrunchBang is related to its release name, Statler, who is a character on the Muppets. Periodically, a little window will appear on the desktop delivering insults and backhanded compliments to the user.
CrunchBang is almost as easy to use as some of the more popular distributions, such as Debian and Ubuntu. The only thing I've found to be less intuitive was the main menu since it is accessed via a keyboard shortcut or a right mouse click, as opposed to the normal way of having the menu open by clicking on a button on a task bar, as in Windows, Ubuntu, Debia, etc. It might not look as pretty out of the box as more popular distributions, but that is easily remedied by applying custom themes. Personally, I like the clean, minimalist appearance it presents.
Packaging Format and Utilities
As a distribution based off of Debian, it is not surprising that CrunchBang uses the same package format, .deb, and the same package manager, dpkg. This package manager installs, removes and supplies information about .deb packages<ref name=dpkg>dpkg. (2011, 16 Sept.). Retrieved November 3, 2011 from http://en.wikipedia.org/wiki/Dpkg</ref>. CrunchBang comes installed with several higher level package management tool that rely on dpkg and other tools, including Advanced Packaging Tool (APT), [wiki.debian.org/Aptitude aptitude], synaptic and tasksel. It also contains two utilities for manipulating .deb files: dpkg-deb and dpkg-split.
Listing Installed Packages
Using the tools that come with CrunchBang there are several ways to get of installed packages. From the command line, you can use "dpkg --list" or "aptitude search '~i'". Aptitude can also open in a text-based shellby typing just 'aptitude' and from within there it all installed software can be listed. Alternatively, open the Synaptic package manager, click on the status button and then select 'Installed' from the list on the left.
Adding and Removing Packages
Packages can be added with dpkg by using 'dpkg --install <package_name>.deb' where the package is a file in your current working directory. They can be removed by using 'dpkg --remove <package_name>' (which will leave its configuration file) or 'dpkg --purge <package_name>' (which will remove the configuration file as well). This method is somewhat inconvenient for adding packages since they must first be downloaded. Using APT, 'apt-get install <package_name>' will install a particular package along with all of its dependencies, while 'apt-get remove <package_name>' will remove the package. Apt-get remove has an optional --purge flag (apt-get --purge remove <package_name>) that will remove configuration files, similar to dpkg --purge<ref name=pkgtools>The Debian Package Management Tools. Debian GNU/Linux FAQ. (2011, 27 Aug.). Retrieved November 3, 2011 from http://www.debian.org/doc/manuals/debian-faq/ch-pkgtools.en.html</ref>.
Without adding any update sites manually, Synaptic found 28751 packages, of which 1168 were installed. Note that this is after the post-installation script ran, which did update the list of available packages (apt-get update). To compare, I ran apt-get update on Debian and then checked the number of packages known by my Debian installation and Synaptic listed 28130, of which 1304 were installed. CrunchBang had mostly the same packages available as Debian, with the addition of having some closed source software that Debian excludes, such as Java. That being said, very few packages have been modified specifically for CrunchBang. Most of the CrunchBang-specific packages are extras such as wallpapers and Openbox themes.
I checked if the package list contained developer software that I had used in the past, and it had Git (already installed), Eclipse, Mercurial, Python, QT libraries and QT creator, Boost libraries and Java in many flavors (J2EE, OpenJDK, etc.) and many libraries and services used with Java (Glassfish, Spring, JBoss). Some of these were not the most recent versions. For example, the version of Eclipse listed was 3.5.2 whereas the latest release is at 3.7.1, and for the Java JDK only J2EE 6u26 was listed which is three updates behind, as well as Java 7 having been released.
Major Package Versions
Here are the version numbers and upstream sources of various major software packages included in CrunchBang, and packages that are central to the system. Notably, CrunchBang comes with no email client. The Liquorix/Zen Kernel is not part of the installation itself, but is included as an option in the post-installation script so I included it in this list.
|Package||Version||Latest Official Release||Upstream Source||Fork Source (If different)|
|Linux Kernel||2.6.32-38||3.1.2<ref>The Linux Kernel Archives. (No date). Retrieved November 23, 2011 from http://www.kernel.org/</ref>||http://www.kernel.org/||http://packages.debian.org/squeeze/kernel/linux-base|
|libc||2.11.2-10||2.14<ref>GNU C Library. (2011, Oct. 29). Retrieved on November 5, 2011 from http://en.wikipedia.org/wiki/GNU_C_Library</ref>||http://www.gnu.org/s/libc/||http://packages.debian.org/squeeze/libc6|
|X.org X Window System||7.5+8||7.6<ref>Releases. (2010, Dec. 21). Retrieved on November 5, 2011 from http://www.x.org/wiki/Releases?action=show&redirect=XorgReleases</ref>||http://www.x.org/wiki/||http://packages.debian.org/squeeze/xorg|
|GTK+||2.20.1-2||3.0.12<ref>GTK+ Sources. (No date). Retrieved November 5, 2011 from http://ftp.gnome.org/pub/gnome/sources/gtk+/3.0/</ref>||http://www.gtk.org/||http://packages.debian.org/squeeze/libgtk2.0-0|
|Qt 4||4.6.3-4+squeeze1||4.7.4<ref>Qt 4.7.4 released. (2011, Sept. 1). Retrieved on November 5, 2011 from http://labs.qt.nokia.com/2011/09/01/qt-4-7-4-released/</ref>||http://qt.nokia.com/||http://packages.debian.org/squeeze/libqt4-core|
|Bash||4.1-3||4.2<ref>Bash (Unix shell). (2011, Oct. 25). Retrieved November 5, 2011 from http://en.wikipedia.org/wiki/Bash_%28Unix_shell%29</ref>||http://www.gnu.org/software/bash/||http://packages.debian.org/squeeze/bash|
|Dash (Debian Almquist Shell)||0.5.5.1-7.4||0.5.7<ref>Dash files. (No date). Retrieved on November 5, 2011 from http://gondor.apana.org.au/~herbert/dash/files/</ref>||http://gondor.apana.org.au/~herbert/dash/||http://packages.debian.org/squeeze/dash|
|Coreutils (GNU core utilities)||8.5-1||8.14<ref>GNU Core Utilties. (2011, Oct. 12). Retrieved November 5, 2011 from http://en.wikipedia.org/wiki/GNU_Core_Utilities</ref>||http://www.gnu.org/s/coreutils/||http://packages.debian.org/squeeze/coreutils|
|Busybox||1.17.1-8||1.19.3<ref>Busybox. (No date). Retrieved on November 5, 2011 from http://busybox.net/</ref>||http://busybox.net/||http://packages.debian.org/squeeze/busybox|
|Chromium||9.0.597.45~r70550-1||17.0.948.0<ref>Index of /releases. (No date). Retrieved on November 23, 2011 from http://src.chromium.org/viewvc/chrome/releases/?sortby=date</ref>||http://dev.chromium.org/Home||https://launchpad.net/debian/+source/chromium-browser/9.0.597.45~r70550-1|
|Crunchbang-Dropbox64||1.0.10-1||1.2.48<ref>Dropbox (service). (2011, Nov. 22). Retrieved November 23, 2011 from http://en.wikipedia.org/wiki/Dropbox_%28service%29</ref>||http://www.dropbox.com/||None available|
|Openbox||188.8.131.52-1||3.5.0<ref>Openbox. (2011, Oct. 25). Retrieved on November 6, 2011 from http://en.wikipedia.org/wiki/Openbox</ref>||http://openbox.org/||http://packages.debian.org/squeeze/openbox|
|Xfce4||4.6.2||4.8.0<ref name=xfce>Xfce 4.8 Released. (2011, Jan. 16). Retrieved on November 6, 2011 from http://www.xfce.org/about/news/?post=1295136000</ref>||http://www.xfce.org/||Not a fork|
|Conky||1.8.0-1+squeeze1||1.8.1<ref>Conky. (No date). Retrieved on November 6, 2011 from http://conky.sourceforge.net/</ref>||http://conky.sourceforge.net/||http://packages.debian.org/squeeze/conky|
|Thunar||1.0.2-1+b1||1.2.3<ref>Thunar. (2011, Jan. 16). Retrieved on November 6, 2011 from http://en.wikipedia.org/wiki/Thunar</ref>||http://thunar.xfce.org/||http://packages.debian.org/squeeze/thunar|
Comparison of Packages to their Latest Stable Release
Packages at the the same version as in Debian
|Linux Kernel||While a list of the individual modifications done to version 2.6.32-38 would be too long to list (the diff file alone is almost 15MB), most of the changes listed in the change log inside the diff file are just driver updates.|
|Libc||After reading through the changed log in the diff file, I have found that the Debian fork consists almost entirely of bugfixes and translations, and the developers give their releases amusing names (@!%$&! you, I use Debian, Perl Sucks, Smash Everything with a _Huge Steamroller_!). The sheer quantity of the changes was quite significant, with the diff file itself coming in just under 120,000 lines.|
|X.org||The changes to xorg in 7.5+8 (over 7.5) were fairly small, consisting of small typo and bug fixes, removing obsolete dependencies and adding support for new architectures. This is available from the changelog within the source package.|
|GTK+||There were few changes to GTK+ 2.20.1-2 over 2.20.1, consisting entirely of bug fixes. Most of the fixes were not even made by the Debian team; they were cherry picked from an upstream source. This information is available from the diff file.|
|Qt 4||The changes to Qt 4.6.3-4+squeeze1 over 4.6.3 are fairly minor. As reported in the changelog of the source, the fork is quite small and consists mostly of patches cherry picked from the upstream source and bug fixes, and includes a fairly major fix to decrease the failure rate of creating new processes in Qt.|
|Bash||Very few changes were made to Bash 4.1-3 compared to 4.1. According to the diff file, it is composed entirely of incorporating five upstream patches, changes to the readme, small fixes of .bashrc and a crash fix.|
|Dash||Dash 0.5.5.1-7.4 contains numerous changes over 0.5.5.1. According to the diff file, the changes are mostly bug fixes, translations and removing or adding dependencies.|
|Coreutils||Coreutils 8.5-1 includes very little on top of 8.5. It provides a workaround for a bug in fstat and stops a test from running due to a bug in gcc. This was taken from the diff file.|
|Busybox||Busybox 1.17.1-8 incorporates many changes on top of 1.17.1. According to the changelog in the source there are updates to the configuration re-application of previous patches and many bug fixes and improvements.|
|Chromium||Though the table above states Chromium's "stable" release, all releases of Chromium are considered experimental; stable releases are released as Chrome. Chrome used to be included in CrunchBang and I believe they switched to Chromium since it's open source and therefore easier to customize, which fits in with the goals of the distribution. Chromium 9.0.597.45~r70550-1 had no changes added to it specifically over 9.0.597.45. Instead, its purpose was to incorporate changes made by the Debian maintainers to previous versions of Chromium. This was taken from the change log in the source code.|
|Openbox||Openbox comes installed on CrunchBang since it provides a large part of CrunchBang's ability to be customized. Openbox 184.108.40.206-1 changes very little over 220.127.116.11. According to the changelog in the source the updates related mostly to packaging and installation, and removing files that were no longer necessary.|
|Conky||Conky is included in CrunchBang because it contributes to the ability to customize the look and usage of the system. Oddly enough, the package included in CrunchBang is maintained by Debian, but does not show up in Debian's package list by default. Conky 1.8.0-1+squeeze made numerous improvements over Conky 1.8.0. According to the change log in the source the changes included crash and bug fixes, and support for a whole bunch of new configuration options and standard variables inside Conky scripts. Interestingly, this version of Conky bases itself off of an Ubuntu version, which itself bases itself off of the official Conky release.|
|Thunar||Thunar was included in CrunchBang since it is a highly configurable file manager that was designed for the Xfce Desktop Environment, but also works well with other desktop managers, such as Openbox<ref>How To Set Thunar As The Default #!Crunchbang Filemanager. (2009, Nov. 11). Retrieved November 6, 2011 from http://crunchbanglinux.org/wiki/howto/set_thunar_as_default_filemanager</ref>. Thunar is listed by Debian's package manager, but not installed, while it comes installed by default on CrunchBang. According to the changelog in the diff file Thunar 1.0.2-1 contains very little in the way of changes over 1.0.2. Essentially, this version just removed a patch applied in a previous fork of Thunar since it was originally taken from an upstream source and 1.0.2 already incorporates the change. It also added a dependency.|
The following are some packages included in CrunchBang that are not based off of Debian sources.
CrunchBang uses LSBInit, the same dependency-based, concurrent boot sequence as Debian<ref>LSBInitScripts. (2011, Jul. 4). Retrieved November 6, 2011 from http://wiki.debian.org/LSBInitScripts</ref>. It uses order numbers from the names of the symbolic links to the script, and prerequisites defined in startup scripts to choose what order scripts are to run in.
In the startup boot level, some of the processes run are:
- x11-common, which depends on the local filesystem being mounted, and has an order number of 15.
- fuse (a program for allowing non-privileged users to create their own file system), which depends on all file systems being mounted, and has an order number of 20 so it runs after x11-common.
- lm-sensors (a program for monitoring hardware status such as temperatures, voltages and fan speeds), which depends on all file systems being mounted, and has an order number of 20 so it runs after x11-common and may run before, after or at the same time as fuse.
Programs that run in multi-user state runlevels (2, 3, 4 and 5) will run after startup boot level processes have started.
Some programs that are started in multi-user state runlevels are:
- apache2 (web server), which depends on all file systems being mounted, on the system logger being operational, on networking running, and on a daemon running which provides hostname resolution. This has an order number of 2.
- mysql (the mysql database server daemon), which depends on all file systems being mounted and on the system logger being operational. This has an order number of 3 and so will run after apache2
- cron (background process scheduling and processing daemon), which depends on all file systems being mounted, on the system logger being operational and on the system time having been. This has an order number of 3 so it may be initialized before, after or at the same time as mysql, and will run after apache2.
- Openbox is created upon user login by the gdm (Gnome Display Manager) service, which itself is only started after x11-common has started. Gdm is initialized in run levels 2-5 and has an order number of 6 and so will run after apache2, mysql and cron. Openbox was found to be run by gdm by looking at the process tree.
- Thunar's daemon is run by Openbox's autostart script, which is run when Openbox starts up. As a result, Thunar will always run after Openbox. This was found by looking in Openbox's autostart script (/etc/skel/.config/openbox/autostart.sh)
- Conky is also run by Openbox's autostart script. The autostart script itself runs sequentially, and Conky comes later in the autostart script than the Thunar daemon so it will always run after Thunar.
Unless otherwise specified, this information was found by looking at the file names and content of the scripts in the rcX.d directories.