Wednesday, January 21. 2004
One thing I noticed today when using RCS is that it isn't terribly user
friendly -- you need to checkout a file to make edits. Often, I make edits,
and then want to commit my changes.
So I wrote a wrapper script called revise. It makes a temporary copy
of the file you've been editing, checks it out of RCS with locking, makes it
writeable, moves the temporary copy to the permanent name, checks it in and
unlocks it (which prompts for a log message), and then makes the file
writeable for the user and group again. The script is outlined here:
#!/bin/bash
FILE=$1
cp $FILE $FILE.new
co -l $FILE
chmod u+w $FILE
mv $FILE.new $FILE
ci -u $FILE
chmod ug+w $FILE
Being the ROX-Filer centric person I am, I also wrote a quick perl script
called rox-revise that I can then put in my SendTo menu. It parses
the file's path, changes to that directory, and then calls the revise
script on the filename, from within a terminal. This script follows:
#!/usr/bin/perl -w
use strict;
use vars qw/$path $file $TERMCMD $REVISE $ZENITY/;
# Configurable variables
$TERMCMD = "myTerm"; # What terminal command to use; must be xterm compliant
$REVISE = "revise"; # What command to use to revise (i.e. rcs ci) the file
$ZENITY = "zenity"; # The zenity or dialog or xdialog command to use
# Grab the filename from the command line
$path = shift;
$file = $path;
# If no file given, raise a dialog and quit
if (!$path || ($path eq '')) {
system(
$ZENITY,
'--title=Error',
'--warning',
"--text=No path given to $0; rox-revise quit!"
);
exit 0;
}
# Get the path to the file and switch to that directory
if ($path =~ m#/#) {
$path =~ s#^(.*)/.*?$#$1#;
if ($path !~ m#^/#) { $path = "./$path"; }
chdir $path or die "$path not found!n";
} else {
# Or else assume we're in the current directory
$path = './';
}
# Get the filename
$file =~ s#^.*/(.*?)$#$1#;
# Execute the revise statement
my $failure = system($TERMCMD, '-e', $REVISE, $file);
if ($failure) {
# on failure, raise a dialog
system(
$ZENITY,
'--title=Error',
'--warning',
"--text=Unable to revise $file"
);
}
1;
Now I just need to check out Subversion, and I can have some
robust versioning!
In trying to implement some of the hacks in Linux Server Hacks, I
had to go to the ssh manpage, where I discovered a number of cool tricks.
- In order to get key-based authentication (i.e., passwordless) working,
the $HOME/.ssh directory must be mode 0700, and all files
in it must be mode 0600. Once that's setup properly, key-based
authentication works perfectly.
- You can have a file called config in your $HOME/.ssh
directory that specifies user-specific settings for using SSH, as well as a
number of host-specific settings:
I mentioned a script called ssh-to
earlier. This is a neat little hack from the server hacks book as well.
Basically, you have the following script in your path somewhere:
#!/bin/bash
ssh -C `basename $0` $*
Then, elsewhere in your path, you do a bunch of ln -s /path/to/ssh-to
/path/to/$HOSTNAME, where $HOSTNAME is the name of a host to
which you ssh regularly; this is where specifying a host nickname in your
$HOME/.ssh/config file can come in
handy. Then, to ssh to any such server, you simply type $HOSTNAME
at the command line, and you're there!
Gleaned from Linux Server Hacks
- Create an RCS directory
- Execute a 'ci -i filename'
- Execute a 'co -l filename' and edit as you wish.
- Execute a 'ci -u filename' to check in changes.
The initial time you checkout the copy, it will be locked, and this can cause
problems if someone else wishes to edit it; you should probably edit it once and
put in the version placeholder in comments somewhere at the top or bottom:
$VERSION$
and then check it back in with the -u flag to unlock it.
Tuesday, January 20. 2004
I stopped at Borders in downtown Burlington on New Year's Eve day, and found
a book called Linux Server Hacks. I loved it immediately, but I
wasn't quite willing to shell out $25 for such a slim volume, even if it did
have many tidbits I could immediately use.
When I told my co-worker, Rob, about it, it turned out he already had the
book, and brought it in to work for me to borrow the next day.
My nose has barely been out of it since. I've done such things as:
-
Create personal firewalls for my home and office machines. I've always
used scripts for this, but the hacks for iptables showed the basics of
how they work, and I've now got nice robust firewalls that are very
simple scripts. To make them even more user-friendly, I borrowed some
syntax from the various /etc/init.d scripts so that I can start, stop,
and reload the firewall at will.
-
I don't use perl at the command line much, even though I've long known
the '-e' switch; it just seems to cumbersome. However, combine it with
the '-p' and/or '-i' switch, and you can use perl as a filter on globbed
files!
-
I know much more about SSH now, and am using ssh-agent
effectively at work now to bounce around servers and transfer groups of
files between servers (often by piping tar commands with ssh).
-
A script called 'movein.sh' turned my life around when it came to
working on the servers. I now have a .skel directory on my work machine
that contains links to oft-used configuration files and directories, as
well as to my ~/bin directory; this allows me to then type 'movein.sh
server' and have all these files uploaded to the server. I can now use
vim, screen, and other programs on any system we have in exactly the
manner I expect to.
-
I've started thinking about versioning more, and have plans to put into
place a subversion repository to store server configs, database schema,
and development projects so we won't make as many mistakes in the future
-- at least not ones we can't rollback from.
-
I rewrote a shell script in perl that was originally intended for IP
takeover, and have been utilizing it to determine if and/or when a
server we've reinstalled goes down.
-
A bunch of Apache and MySQL tips are included, including mod_rewrite
hacks, how to make your directory indexes show full file names, and
more; as well as how to monitor your mysql processes and, if necessary,
kill them. I'm also very interested in how to use MySQL as an
authentication backend for an FTP daemon -- it could give us very
fine-grained control of our webserver for editors.
And that's just the tip of the iceberg. All in all, I highly recommend the
book -- though most likely as a book to check out from the library for a few
weeks, digest, put into practice, and return. The hacks are so damn useful,
I've found that after using one, I don't need to refer to that one ever
again. But that's the point.
Tonight was Papa night, which meant that I got to look after Maeve while Jen
worked late doing a group at work. Last week, Maeve and I established that
Papa Night would always include going to the bookstore, which means Barnes
& Noble in South Burlington.
Last week, Maeve was perfectly content to look at books by herself, and
didn't want me interfering, so I decided this week to grab a book for myself
to peruse while she was busy. It didn't work as I intended -- Maeve saw that
I wasn't paying full attention to her, and then demanded my attention -- but
I was able to look through some of the new items in the second edition of
The Perl Cookbook.
Among them were:
|
|