VirtualBox image creation
details
Go up to the main directory page (md)
For those who are interested, this is how the VirtualBox image was
created.
Introduction
This page has a number of different sections, and the sections you
need to install will vary depending on what course you are using this
image for. The top of each section describes which of the sub-sections
need to be installed for what.
Software Versions
This installation document installs the following versions:
Newer versions of the above may have since come out, but at the time
of the last update of this document (August 2019), they the latest
versions installed via apt-get.
Notes
- The guest hard drive reported 27 Gb of space available, prior to
distribution of the image. The disk image itself was, after compaction,
10 Gb. When compressed via zip, it was 4.3 Gb in size.
- You will likely need to use a different unzip program to extract the
image; the ones that come bundled with most operating systems can not
handle archives of that size. We have used 7-zip with success.
- Video and sound (via youtube) worked fine with both Chrome and
Firefox (although it may a bit slow depending on your computer’s
speed)
- The VM may capture the mouse - to uncapture it, you press the “host
key”, (which is the right Control key on Linux and Windows hosts, and
the left Command key on Mac hosts). To have it warn you about what this
is, you can reset all warnings via the VirtualBox help menu, and it will
warn you about this at boot-up
- In the image creation process, you may run into a problem with
VirtualBox where it cannot register a new (or different) disk because it
has the same UUID as a previous disk that you are replacing. If so, then
the command
VBoxManage internalcommands sethduuid disk.vdi
(changing disk.vdi
appropriately) will change the UUID, and
allow you to proceed
Basic installation
All installations need to run through this, as it sets up the default
Ubuntu installation.
Basic installation
- Created a new VirtualBox image
- I named it “Ubuntu 18.04” or similar; this automatically selected
Linux as the OS type; I manually selected “Ubuntu (64 bit)” as the
version
- I set the memory at 4096 Mb (instead of the default of 512 Mb),
ensured that the disk size was “dynamically allocated” and was set to 40
Gb (instead of the default 8 Gb); everything else was set at the
default
- I installed Ubuntu 18.04.3 LTS (64 bit), desktop edition, from the
DVD image downloaded from ubuntu.com
- When prompted, I clicked on ‘download updates’ and ‘install 3rd
party software’ when the options were given
- For hard drive, I used the default option that was already
selected
- The computer name is cassiopeia, the login name is ‘student’, full
name is ‘l33t h4x0r’, and the password is ‘password’
- This account can run root (system) commands via ‘sudo’ - if you
don’t know what this means, you can safely ignore it
- Once it was finished, I rebooted, and logged in
- Via a Konsole, ran
sudo apt-get update
then sudo
apt-get dist-upgrade
- Reboot!
- Ran
apt-get autoremove
(which didn’t have to remove
anything)
- VirtualBox guest additions
- These are the utilities so that VirtualBox will work correctly with
the host computer (proper full screen, etc.)
- The menu option to “Insert Guest Additions CD Image” downloads a
version that will not work with the current Linux kernel version, so the
ISO must be manually downloaded from http://download.virtualbox.org/virtualbox/
- Installing these requires the
gcc make perl
packages to
be installed first
- Once done, run
autorun.sh
from
/media/student/VBOXADDITIONS_4.3.36_105129
(or similar),
and follow the prompts. Alternatively, if that does not work, try
running sudo bash VBoxLinuxAdditions.run
from that same
directory.
- Reboot!
- As per here
to fix an issue with /etc/resolv.conf, edited /etc/systemd/resolved.conf
to put 8.8.8.8 as the DNS line, and then ran the commands from the
second answer:
sudo rm -f /etc/resolv.conf
followed by
sudo ln -s /run/systemd/resolve/resolv.conf
/etc/resolv.conf
, and then rebooted
- Ran
apt-get remove thunderbird
- Disable the KDE wallet system (if using KDE)
Development installation
The “Program and Data Representation configuration” section is for
the Program and Data
Representation course, and it includes all of the compilers and
editors needed. The “Python/Django” section installs the files needed to
run Python 3 and the Django framework.
Program and Data
Representation configuration
- Installed the other packages:
sudo apt-get install clang
emacs25 vim nasm astyle tofrodos source-highlight gdb lldb doxygen
doxygen-doc graphviz ddd git g++ gobjc gnustep gnustep-make
gnustep-common libgnustep-base-dev evince g++-multilib libc6-dev-i386
libc6-dev:i386 flex
- Note that there are two other
apt-get install
lines to
be run, below
- The last 5 packages are for Objective C, based on the instructions
here
(it may be that only a subset of those packages are actually
necessary)
- Ran the following two commands to change the default C/C++ compiler
to clang:
sudo update-alternatives --set cc /usr/bin/clang
sudo update-alternatives --set c++ /usr/bin/clang++
- Downloaded Google Chrome from here,
and installed it via
sudo dpkg -i
google-chrome-stable_current_i386.deb
- If that installation does not work perfectly, run
sudo apt-get
-f install
- Then the .deb file was removed
- GNOME customization
- Removed RhythmBox, Ubuntu Software, and Amazon from the favorites
bar on the left-hand side
- Added Terminal, Emacs, and Chrome to the favorites on the left-hand
side
- Disabled the screen saver lock, as detailed in the first answer here
- Browser customization
- Set the home pages for both Chrome and Firefox to online course repo
site (http://uva-cs.github.io/pdr) and to Collab
- Chrome is set as the default browser
- I loaded up emacs from the command line, and then told it to disable
showing the startup messages (this could also be accomplished by
following the guidelines here).
- Added a few aliases were added (the last 4 lines of .bashrc) to help
prevent people from accidentally removing files (adding -i for rm, mv,
and cp; and aliasing xemacs to emacs). This was done both in
/home/student/.bashrc and /etc/skel/.bashrc.
alias mv='mv -i'
alias rm='rm -i'
alias cp='cp -i'
alias xemacs='emacs'
- Cloned the github repo via
git clone
https://github.com/uva-cs/pdr
; note that a git pull
will still have to be executed each time to update it
- Removed all the empty default directories in ~/student other than
Desktop and Downloads
Introduction to
Cybersecurity configuration
- Cloned the github repo via
git clone
https://github.com/aaronbloomfield/ics
; note that a git
pull
will still have to be executed each time to update it
- Ran
sudo apt-get install default-jdk libssl-dev fcrackzip
libarchive-zip-perl testdisk libboost-dev libboost-doc unzip traceroute
strace nmap apache2 php libapache2-mod-php imagemagick
- default-jdk: for the Java assignments, such as RSA
- libssl-dev: for the hashing HW (C++ MD5 routines)
- fcrackzip: for the zip cracking program
- libarchive-zip-perl: for the CRC program
- testdisk: used in autopsy / sleuthkit (includes photorec)
- libboost-dev libboost-doc: for boost
- (see notes for 2019 for additional packages and installs)
- unzip, if not already installed
- traceroute, for networks
- strace, for the kernel rootkits tutorial
- nmap, apache2, libapache2-mod-php: for networks
- python3, python3-pip, python-virtualenv, python3-virtualenv, for
Python development
- php, libapache2-mod-php: for PHP on apache
- imagemagick: needed for autopsy
- Installed the kernel headers, as per http://derekmolloy.ie/writing-a-linux-kernel-module-part-1-introduction/
- Ran
apt-cache search linux-headers-$(uname -r)
, then
installed that package (if not already installed)
- apache2 configuration
- enabled the userdir apache2 module (i.e., using ~userid/ for each
userid):
sudo a2enmod userdir
- enabled the URL rewriting apache2 module:
sudo a2enmod
rewrite
- enabled PHP in user directories: edit (via sudo)
/etc/apache2/mods-available/php7.4.conf
(the number ‘7.4’
may be different), and change the Off
in the
php_admin_value engine Off
line to On
- restart apache:
sudo service apache2 restart
- the ‘student’ user can already view the apache2 error logs (in
/var/log/apache2), but if they couldn’t, then they would have to have
been added to the ‘adm’ group (i.e.,
usermod -a -G adm
student
, but this requires logging out and logging in for the
group change to take effect)
- made a ‘public_html’ directory both in ~student and /etc/skel; the
former is chown’ed to student:student
- Install autopsy:
Download the latest version of autopsy and the the sleuthkit_java
package from http://sleuthkit.org/
(the download page is on the autoposy tab there, not the sleuthkit
tab)
- A given version of autopsy is “mated” to a specific version of
sleuthkit, and they have to match. As of the writing of thus (June
2021), the current downloadable versions (autopsy 4.18.0 and
sleuthkit-java 4.10.2) match.
The command to install the package is dpkg -i
sleuthkit-java_4.6.6-1_amd64.deb
– when that fails due to
dependency issues, run apt-get -f install
, and it will
install the dependent packages and finish the sleuthkit package
installation
Unzip autopsy to /usr/local – the path will be something like
/usr/local/autopsy-4.18.0/
- This should be unzipped as root:
cd /usr/local; sudo unzip -q
/path/to/autopsy-4.18.0.zip
This needs a specific version of Java (1.8) along with JavaFX;
directions for installing this can be found here;
they are:
wget -q -O - https://download.bell-sw.com/pki/GPG-KEY-bellsoft | sudo apt-key add -
echo "deb [arch=amd64] https://apt.bell-sw.com/ stable main" | sudo tee /etc/apt/sources.list.d/bellsoft.list
sudo apt-get update
sudo apt-get install bellsoft-java8-full
export JAVA_HOME=/usr/lib/jvm/bellsoft-java8-full-amd64
- Put that list line at the end of
~student/.bashrc
If the /usr/local/autopsy-4.18.0/unix_setup.sh file is Windows
text file format, it needs to be converted
- Run
file /usr/local/autopsy-4.18.0/unix_setup.sh
, and
if it says “CRLF line terminators”, it needs to be converted
- Run
sudo fromdos
/usr/local/autopsy-4.18.0/unix_setup.sh
- Note that it doesn’t hurt to run that
fromdos
command
regardless of the format
Configure autopsy: from the autopsy directory
(/usr/local/autopsy-4.18.0/), run sudo
JAVA_HOME=/usr/lib/jvm/bellsoft-java8-full-amd64 bash
./unix_setup.sh
- Use the actual path of the JRE, not necessarily what is listed in
the command above
- It should complete with no errors and print “Autopsy is now
configured. You can execute bin/autopsy to start it”
More autopsy configuration
- Run
sudo chmod 755
/usr/local/autopsy-4.18.0/bin/autopsy
to allow non-root to run
autopsy
Put in an alias in ~/.bashrc: alias
autopsy='/usr/local/autopsy-4.18.0/bin/autopsy --nosplash --jdkhome
/usr/lib/jvm/bellsoft-java8-full-amd64'
- The
--nosplash
is critical, as there is a known bug
where the spash screen hides the confirmation box, and the confirmation
box needs to be checked before one can open up the GUI.
Run autopsy to get it working
- Ensure that the
~/.autopsy
directory is not present,
and that no autopsy processes are running
- The first time, run without the
--nosplash
option:
/usr/local/autopsy-4.18.0/bin/autopsy --nosplash --jdkhome
/usr/lib/jvm/bellsoft-java8-full-amd64
- That will hang on “starting modules” or “loading module
services”
- Kill the process (likely by finding the PID via
ps
),
and then run with the --nosplash
option
- This should load properly with the “Welcome” dialog
Service
Learning Practicum configuration section
These sections are no longer included here, nor used in the images
currently distributed, but can be found in the
latest version of the aaronbloomfield/slp repo. There were two
sections for this: “LAMP configuration (with both PHP and Python 3)” and
“Ruby on Rails configuration”. Note that that repo, and the linked
instructions, were last updated in August of 2017. All the versions
stated therein are outdated, and many (all?) of those instructions may
need tweaking to work properly again.
Programming Contest
configuration section
This section is no longer included here, nor used in the images
currently distributed, but can be found in an
old version of the PDR repo. That version was last updated in the
spring of 2018.
Image completion
The “Image finalization” section should be run on every image.
Image finalization
- Reboot (rebooting also clears out /tmp)
- Run
apt-get autoremove
and apt-get
clean
- Cleared browser history
- Removed the apt-get proxy, if present:
sudo /bin/rm -f
/etc/apt/apt.conf.d/02proxy
- To reduce the size of the hard disk (since I have to host it for
people to download), I ran
sudo cat /dev/zero > zero; sudo
/bin/rm -f zero
. This creates a large file of all 0’s until it
runs out of space, then removes that file.
- Ran
history -c
to remove the history of the commands
entered on the command line
- Logged out then shut down the guest, and ran:
VBoxManage
modifyhd disk.vdi --compact
(using the real image file name
instead of “disk.vdi”). A better way would be to load up into recovery
mode and run zerofill, but the grub menu does not seem to be easily
available to load into recovery mode, so I didn’t pursue it any
further.
Increasing the disk size
The hard drive size was set at 40 Gb, and about 27 Gb is available;
the rest is used by the operating system (and the swap partition). If
you need more space than this, you will have to expand the hard drive.
Be careful – it is easy to accidentally erase the entire hard drive
while doing this!
- The process has two steps: increase the VirtualBox disk image
itself, then increase the partition of the guest OS.
- To increase the VirtualBox disk image, power it down, and then run
the following command. The size listed is the size in Mb, so 40960 Mb is
40 Gb. The command is:
VBoxManage modifyhd <imagefile>
--resize 40960
– but you will want to use a larger value if you
are increasing the size.
- Note that
<imagefile>
is the .vdi disk image, and
should be the absolute path including the name and extension
- The second step is to resize the guest OS partition. The easiest way
to do this is to download a bootable disk image for this purpose. You
can use Gparted,
which is free. Keep in mind that your guest OS is 64-bit, so you will
want the “amd64” version.
- To boot up via the Gparted image, Go to Settings -> Storage. In
the “Storage Tree” box, there will be a “Controller: IDE” entry, with an
“Empty” line below that; click on the “Empty” line, and select the
Gparted disk image (using the blue DVD icon on the right). Click Okay,
then start the image. It should start the Gparted disk.
- When Gparted boots, selected the default boot option. In the
text-based menus, hit Enter to select the defaults.
- From the GUI, resize your partition. Hit “Apply” when done.
- Double click on the red “Exit” icon, and select shutdown.
- Back in Settings -> Storage -> Controller: IDE -> Empty,
remove that disk from the virtual CD/DVD drive (under the blue DVD icon,
select the last option to remove the image) – it should not be there by
default at this point. Click OK.
- Boot into Kubuntu normally.
Changes for the future