The term “load average” is used in many Linux/UNIX utilities. Everybody knows that the numbers the term “load average” refers to, usually three numbers, somehow represent the load on the system’s CPU. In this post I’ll try to make these three numbers clearer and more understandable.
Continue reading Understanding load average – A Practitioner’s Guide
rzip vs. bzip2 – A short comparison
I decided to benchmark rzip against bzip2 for my backup needs. The benchmark was performed on an 89M tar archive of a directory that I regularly back up using my Amazon S3 backup script. The directory contains mostly LaTeX, PDF, and OpenOffice files, so this benchmark may reflect very different results from what you would get if you tested it on other kinds of files.
Continue reading rzip vs. bzip2 – A short comparison
usb 1-4: device descriptor read/64, error -71
When I try to connect my Sansa Clip MP3 player to the Linux box, I see the following error in dmesg:
usb 1-4: device descriptor read/64, error -71
and the device recognition fails. The player’s battery gets recharged, but I can’t mount it and transfer songs.
Continue reading usb 1-4: device descriptor read/64, error -71
Start Trac on Startup – Init.d Script for tracd
As part of a server move, I went on to reinstall Trac. I tried to install it as FastCGI, but I failed to configure the clean URLs properly. I got the clean URLs to work if the user accessed them, but Trac insisted on adding trac.fcgi to the beginning of every link it generated. So I decided to use the Trac standalone server, tracd.
The next problem I faced was how to start Trac automatically upon startup. The solution was to use an init.d script for starting Trac. After some searching, I didn’t find an init.d script for tracd that was satisfactory (most were poorly written). So I went on and wrote my own init.d script for tracd.
Continue reading Start Trac on Startup – Init.d Script for tracd
Clean URLs (Permalinks) for WordPress on Lighttpd
I’ve moved my blog in the last few days to a new, bigger dedicated server (as well as some other sites I own). After doing some benchmarks (I plan to post those soon), I’ve decided to switch to Lighttpd. While the exact migration notes are the topic of another post, I can say that I’m fairly satisfied with the move.
After setting up the server, I started moving the blog. Importing the files and the database was pretty straightforward. But when I thought everything was ready and I transferred the domain to the new server, I’ve found out that none of my inner pages are accessible. The reason, as it turned up pretty quickly, is that WordPress depends on Apache’s mod_rewrite to create the clean URLs (the so-called permalinks). This actually posed two problems:
- WordPress depends on Apache’s
mod_rewrite. - WordPress uses
.htaccessfiles for the clean URLs configuration.
Continue reading Clean URLs (Permalinks) for WordPress on Lighttpd
radio.py-0.5 – An Easy Interface for Listening to Radio under Linux
This new release of radio.py brings more predefined stations and the much wanted recording feature. radio.py is a Python wrapper for mplayer, designed to provide an easy-to-use interface for listening to radio from the command line. And indeed, using radio.py is very easy; just pass the station name.
radio.py Classic FM
To read more about radio.py and the existing features, go to radio.py – a Wrapper Script for Listening to Radio in Linux.
New stations in this release include Ram FM, Classic FM, Radio Caroline, and updates to all the radioIO stations. So overall, this version of radio.py comes with 81 predefined stations. To see the full list of recognized stations, run radio.py --list. If your favorite station is still missing, you can add it via configuration files, as described here. If you send a comment with the names of the stations and their websites, I’ll add them to the next release.
The other important new feature is the ability to record radio streams to mp3 directly from radio.py. This is done using the --record command-line switch. For example, the following
radio.py CNN --record cnn.mp3
will record the radio stream of CNN to a file called cnn.mp3. To stop recording, just press ‘q’. This option can also be used with --sleep and --wake-up to time your recordings. For example, if you want to record a show that starts in 30 minutes and is 60 minutes long, you should do
radio.py BBC1 --record bbc1.mp3 --wake-up 30 --sleep 60
You can download the new version from here. Installation is pretty straightforward: just untar the archive and put radio.py somewhere in your path (e.g. /usr/local/bin/), and the package is installed.
As always, if you want new stations added to the next release, send a comment with the station details (at least the name and website).
UPDATE 14/12/2008: I’ve changed the download link to point to radio.py‘s SourceForge project page.
WordPress Backup Script
This is a small script I’ve written to automate my server-side backups of my blogs. It creates a backup of both the database and the actual WordPress files.
#!/bin/bash
# (C) 2008 Guy Rutenberg - http://www.guyrutenberg.com
# This is a script that creates backups of blogs.
DB_NAME=
DB_USER=
DB_PASS=
DB_HOST=
#no trailing slash
BLOG_DIR=
BACKUP_DIR=
echo -n "dumping database... "
mysqldump --user=${DB_USER} --password=${DB_PASS} --host=${DB_HOST} ${DB_NAME}
| bzip2 -c > ${BACKUP_DIR}/${DB_NAME}-$(date +%Y%m%d).sql.bz2
if [ "$?" -ne "0" ]; then
echo -e "nmysqldump failed!"
exit 1
fi
echo "done"
echo -n "Creating tarball... "
tar -cjf ${BACKUP_DIR}/${BLOG_DIR##*/}-$(date +%Y%m%d).tar.bz2 ${BLOG_DIR}
if [ "$?" -ne "0" ]; then
echo -e "ntarball creation failed!"
exit 1
fi
echo "done"
spass 1.1 – Secure Password Generator
This is a new version of my /dev/random-based secure password generator – spass. The new version doesn’t have any new features; it’s mainly a bug-fix release. The package now uses autotools, which means it has the standard configure script and makefile. I also fixed some typos in the help message. Overall, the new version doesn’t offer anything new compared to the old one, except for easier installation.
Continue reading spass 1.1 – Secure Password Generator
mctext 0.2 – A Markov Chain Text Generator
This is the second release of my Markov Chain text generator – mctext. This text generator takes existing sample text and generates new text using Markov Chains.
The main new thing in this version is that it allows users to specify via the command line how many words should be considered when generating the next one. The bigger the step number, the closer the generated text is to the original one. The value used in mctext-0.1 was 2, and this is also the default in this one. The number of steps can be set using the --steps command line switch.
Continue reading mctext 0.2 – A Markov Chain Text Generator
Pull vs. Push MVC Architecture
I intended to write this post a couple of months ago, when I worked on a pull-based MVC framework for some site. Most web developers are acquainted with the MVC architecture, and almost all the major web frameworks use this concept, including Ruby on Rails, CakePHP, Django, Symfony, and others. So what is MVC, and what’s the difference between pull and push?
Continue reading Pull vs. Push MVC Architecture