Tiny Core Linux
TinyCore is a x86 Linux distribution that's extremely small and runs primarily from memory. The project also has a few spinoffs that runs on x86_64 (amd64), ARM, and ARM64 architectures. Its main appeal is its small size, modularity, and simplicity.
The project website is at http://tinycorelinux.net.
PXE Boot
To PXE boot TinyCore, create a boot menu that loads the kernel and core.gz image:
LABEL Core
MENU LABEL Core
kernel /images/core/vmlinuz
INITRD /images/core/core.gz
The standard image will not have any extensions and will drop you into a shell.
NFS
To get a GUI, you will need to load Xvesa
, wbar
, flwm_topside
and their dependencies. The easiest way to get these extensions is to grab it from the TinyCore CD.
To get TinyCore to mount a NFS share containing the required extensions, pass nfsmount
to the kernel:
LABEL Core
MENU LABEL Core
kernel /images/core/vmlinuz
INITRD /images/core/core.gz nfsmount=10.1.1.1:/tftpboot/images/tinycore tce=nfs/cde
Where /tftpboot/images/tinycore
contains a directory containing a onboot.lst
file plus all the packages that are needed. In my case, I wanted to PXE boot into Tiny Core Linux with cde, so I copied the 'cde' directory from the Tiny Core Linux iso and dumped it into the NFS export:
$ ls /tftpboot/images/tinycore
cde
$ ls /tftpboot/images/tinycore/cde
copy2fs.lst onboot.lst optional xbase.lst
When TinyCore boots, the NFS share will be mounted as /mnt/nfs
and the packages will be loaded by tce based on the onboot.lst
file in the nfs/cde
directory.
HTTP List
Alternatively, if you don't have a NFS server, you can specify a httplist
that specifies the web server and the path to a file that contains a list of URIs (on that server) that TinyCore should download and load.
LABEL Core
MENU LABEL Core
kernel /images/core/vmlinuz
INITRD /images/core/core.gz httplist=pages.cpsc.ucalgary.ca:80/~leo/boot/pxe/linux/data/tinycore/list.txt
The list file contains:
/~leo/boot/pxe/linux/data/tinycore/8.x/libICE.tcz
/~leo/boot/pxe/linux/data/tinycore/8.x/imlib2.tcz
/~leo/boot/pxe/linux/data/tinycore/8.x/libSM.tcz
...
The only drawback to this feature is that the packages are downloaded from the server hosting that list. This means that you won't be able to make TinyCore download packages from an existing mirror.
.htaccess
file in the 8.x directory that forwards package requests to a mirror.
RewriteEngine on
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule (.*) http://mirror.cpsc.ucalgary.ca/mirror/tinycorelinux/8.x/x86/tcz/$1 [P,L]
Customization
I have made the following changes to /etc/init.d/tc-config
--- ../tc-config 2017-08-20 17:57:00.145946463 -0600
+++ etc/init.d/tc-config 2017-08-20 18:03:52.666609947 -0600
@@ -61,6 +61,7 @@ for i in `cat /proc/cmdline`; do
rsyslog=* ) RSYSLOG=${i#*=}; SYSLOG=1 ;;
blacklist* ) BLACKLIST="$BLACKLIST ${i#*=}" ;;
iso* ) ISOFILE=${i#*=} ;;
+ postexec*) POSTEXEC=${i#*=} ;;
esac
;;
*)
@@ -613,6 +614,19 @@ else
[ -z "$NORTC" ] || /etc/init.d/settime.sh &
fi
+# Post-boot exec command or http script
+if [ -n "$POSTEXEC" ]; then
+ case "$POSTEXEC" in
+ http*)
+ [ -z "$DHCP_RAN" ] && wait4Server $HOST $NOPING
+ wget -O - "$POSTEXEC" | sh
+ ;;
+ *)
+ echo "$POSTEXEC" | sh
+ ;;
+ esac
+fi
+
[ -n "$CRON" ] && /etc/init.d/services/crond start
/sbin/loadcpufreq 2>/dev/null &
With this modification, you can pass postexec
as a kernel argument which then gets executed after all the extensions have loaded, but before the user-side programs start. Eg:
kernel http://${base_url}/linux/data/tinycore/8.x/vmlinuz httplist=pages.cpsc.ucalgary.ca:80/~leo/boot/pxe/linux/data/tinycore/list.txt showapps postexec=http://pages.cpsc.ucalgary.ca/~leo/boot/pxe/linux/data/tinycore/post_install.sh
Usage
Persistence
When TinyCore boots, after all extensions are loaded, customized files are then loaded from /mnt/sdx1/tce/mydata.tgz
. Afterwards, any changes made to a running system will be lost unless it is saved using the filetool.sh
script. This tool will restore and save any files listed in /opt/.filetool.lst
Miscellaneous
Installing to Hard Drive
The installer can be used to install TinyCore on a hard drive. Get the tc-install
package and run it.
Mirrors
The mirror can be selected by editing /opt/tcemirror
.
To use CPSC's mirror, edit /opt/tcemirror
and replace it with:
http://mirror.cpsc.ucalgary.ca/mirror/tinycorelinux/
Modifying mydata.tgz
If you are running TinyCore on a NFS share, you might not be able to modify the system and then save the changes like you normally would with filetool.sh -b
because /mnt/nfs
may be read only.
To modify mydata.tgz
outside of the TinyCore environment:
# umask 022 # In case you have a weird umask, default to 022.
# mkdir tce # this dir should be 755 (anything less will kill your tce image)
# cd tce
# tar --numeric-owner -xzpf ../mydata.tgz # Keep permissions and ownership!
## make your changes
# tar --numeric-owner -czpf ../mydata.tgz * # Re-create the tarball with permissions
Overwrite the old mydata.tgz
on the NFS share and then test the changes on TinyCore by running:
# filetoool.sh -r
Any changes you've made should be visible immediately.
Altering core.gz
- Initrd Image
Follow the steps below if you wish to have the system include a set of packages out of the box without needing to load it as extensions.
Extract
Extract the core.gz
file.
$ mkdir -p /tmp/tinycore/extract
$ mv core.gz /tmp/tinycore # where core.gz is the initrd file
$ cd /tmp/tinycore/extract
# zcat ../core.gz | cpio -i # cpio requires root in order to mknod
The extract directory should now contain the contents of the initrd file system.
Adding Additional Packages
Download the .tcz files you want installed from the repository. Store them somewhere (say /tmp/tinycore/packages
). Each package is a squashfs filesystem which can be extracted using the unsquashfs
utility.
$ cd /tmp/tinycore/extract
$ for i in `ls ../packages/*.tcz` ; do unsquashfs -f -d . $i ; done
If you wish to run something on startup, put it in /opt/bootsync.sh
or /opt/bootlocal.sh
. /opt/bootsync.sh
gets called by /etc/init.d/tc-config
. Just note that networking might not be up immediately since the dhcp client runs asynchronously. I got around this by running while true ; do wget -O - http://somewhere.com && break ; done
just to verify networking is up.
Remastering
With the changes made to the root file system, you will want to package the directory back up to create the initrd image. To do this, do:
$ cd /tmp/tinycore/extract
$ find | cpio -o -H newc > ../core
$ cd ..
$ gzip core
$ advdef -z4 core.gz # this step is optional, but may save you ~2% of space.
Loading Drives
To load some graphics drivers on boot, add to /opt/bootsync.sh
:
#!/bin/sh
# put other system startup commands here, the boot process will wait until they complete.
# Use bootlocal.sh for system startup commands that can run in the background
# and therefore not slow down the boot process.
/usr/bin/sethostname box
Display=`lspci | grep -i vga`
if echo "$Display" | grep -qi nvidia ; then
sudo -u tc tce-load -i nvidia-340.96-4.2.9-tinycore
cp /etc/X11/xorg.conf-nvidia /etc/X11/xorg.conf
fi
if echo "$Display" | grep -qi intel ; then
sudo -u tc tce-load -i xf86-video-intel
fi
if echo "$Display" | grep -qi amd ; then
sudo -u tc tce-load -i xf86-video-ati
fi
if echo "$Display" | grep -qi vmware ; then
sudo -u tc tce-load -i xf86-video-vmware
fi
FLWM title bar
The Fast Light Window Manager (FLWM) window manager comes in two flavors: The default where the title bars are stacked on the left side of the window, and the 'topside' where the title bars are placed at the top as they are more traditionally placed.
By default, Tiny Core Linux uses the version with the title bars placed vertically. If you want to change this, load the flwm_topside.tcz package with tce. If you are using a NFS or HTTP file list, simply download the flwm_topside package and replace the flwm entry with flwm_topside in the file list.