<!DOCTYPE HTML PUBLIC><meta name="viewport" content="width=device-width, initial-scale=1, minimum-scale=0.8"><meta http-equiv="Content-Security-Policy" content="upgrade-insecure-requests"><body><div id="content" style="max-width:1200px;overflow:auto"><pre>                     Q40/Linux Journal
                        Issue #2

www.geocities.com/SiliconValley/Pines/5865/q40lin.html
Editor: Timothy Swenson (swensont@lanset.com)


Editor's Forumn

I got some positive feedback from the first issue of the Q40/Linux
Journal.  I noticed a number of people at the QL 2000 show carrying it
around.  In all I'm glad I did it and hope to continue doing issues.

Q40/Linux is not the only thing in my life.  I'm working on other QL
projects (Turbo Manual, learning TurboPTR, etc.).  I've also got some
non-computer hobbies eating my time.   I'm making sure that I spend
some time working on Linux.  I'm actually hoping to start supporting
Linux professionally.

So, here is the 2nd issue of the Q40/Linux Journal.  Hope you enjoy
it.


Tip of the Month

I don't know I'm the only one who did not know this, but the
CTRL-ALT-DEL key combination will send INIT a SIGTERM and will cleanly
shutdown Linux.  I got into a situation where I could not get a shell,
and so my only solution was to reset the Q40.  Since the disks were
not unmounted properly, I spent about 5-10 minutes in fsck the next
time Linux booted.  Finding the CTRL-ALT-DEL solution was much nicer.

If you are in X-windows and it seems to lock up, a CTRL-ALT-BACKSPACE
will kill X-windows and return you to the console prompt.


Backing up to Floppy

Having spent some time being a Unix system administrator, I know how
important backing up data can be.  Typical Unix systems backup whole
file systems to tape.  On the Q40, we have the software to do it, but
we don't have access to tape drives.  For some, having a CD-R is a
good way to backup data.  For most of us, floppies is about the only
way to back data up.

Backing up to floppies can take time, but the standard Linux tools
does not allow for easily spreading a backup across multiple disks. 
Looking around www.linux.org, I found an application that can do this.
Span is a utility that takes the output from a program like tar, and
spreads it across a number of diskettes.  Span knows when one disk is
full and prompts you for the next disk.

Span can be found a the following location:

   users.gtn.net/fraserm/span.html
   users.gtn.net/fraserm/span-0.2.4.tar.gz

I downloaded the tar file, transfered it to the Q40, ungzipped it, and
untared it.

   % gzip -d span-0.2.4.tar.gz
   % tar -xvf span-0.2.4.tar

This put the files in the directory span-0.2.4.

Span comes as source code and requires that it be compiled.  Without
making any changes to the source code or Make file, I did the
following:

   % make 
   % su
   % make install

The 'make install' put the executable in /usr/local/bin and puts the
man page where it 'man' can find it.

Using span is fairly easy.  The easiest way to get it to work is the
following command line:

   tar -cfz - /dir | span /dev/fd0

What this does is this:  It creates a tar file for the directory /dir
and pipes it to span and has span use the device /dev/fd0 ( the first
floppy drive).  Span prompts you for the first disk and starts putting
the data on it.  When the disk is full, span will again prompt you to
put in the next disk.  The -z option of GNU tar compresses the tar
ouput with GZIP.  This will store more data on the disks.

The disks I used were formated as MSDOS, but span seems to use it as a
raw device and it may not care if the disk is formatted at all.  The
disks I used were no longer viewable my MS-DOS.

To restore the files, do the following:

   despan /dev/fd0 | tar -xfz -

This works in just the opposite as putting the data on disk.  Despan
will prompt you for the first disk and then start pulling the data off
the disk and feed it to tar.  

I had problems running span as a user, so I resorted to running it as
root.  I think the problem I had is using the -l "label" option of
span.  It kept spitting out an error about the disk not being
previously written by span.  I'd avoid using the -l option.

I did find one major problem with span.  It reacts in a bad way to a
SIGTERM signal (kill).  It starts outputing that it recieved a kill
signal and is aborting.  This message is repeated over and over again,
locking up the console for other uses.  a SIGKILL (kill -9) should
work, as SIGKILL is non-trapable by a program.

When backing up your data, I'd recommend numbering the diskettes so
that you can have them in the proper order when restoring the data.

   
Installing MySQL
   By Claus Graf (cgraf@q40.de)

According to the MySQL reference manual, "MySQL is a very fast,
multi-threaded, multi-user and robust SQL (Structured Query Language)
database server. For Unix and OS/2 platforms, MySQL is basically free;
for Microsoft platforms you must get a MySQL license after a trial
time of 30 days. The MySQL home page (http://www.mysql.com/) provides
the latest information about MySQL." As the Q40 is Microsoft free, you
can happily use MySQL.

Since there is no RPM with a m68k binary of MySQL you need to get the
Source RPM.  I am using the one out of SuSE Linux 6.4 PowerPC Edition.
The source RPM package, is independant of the hardware architecture
and any Linux distribution that contains the MySQL sources should be
suitable.

After mounting the CDROM and locating the MySQL source package you can
install it by typing

   % rpm -i /cdrom/full-names/src/mysql-3.22.32-55.src.rpm

Your version number of MySQL might be different, of course. After
that, some new files appear in /usr/src/redhat/SOURCES:

   DBI-1.13.tar.gz
   Data-ShowTable-3.3.tar.gz
   Data-ShowTable-3.3.dif
   Msql-Mysql-modules-1.2210.tar.gz
   mysql-3.22.32.dif
   mysql-3.22.32.tar.gz

At first only the files mysql-3.22.32.tar.gz and mysql-3.22.32.dif are
necessary.  sql-Mysql-modules are Perl modules for MySQL that need the
BI/BD interface. Data-ShowTable is also a Perl module for formatted
output of results of database queries.  Now copy mysql-3.22.32.tar.gz
to the place where you want to compile the sources and uncompress and
unpack the source data:

   % gzip -d mysql-3.22.32.tar.gz
   % tar xvf mysql-3.22.32.tar
   % cd mysql-3.22.32
   % cp /usr/src/redhat/SOURCES/mysql-3.22.32.dif .

The last command puts the diff file into the source directory. With
the patch command you can apply small changes to the data in order to
fix bugs etc:

   % patch -p1 < mysql-3.22.32.dif

I had to skip two patch operations, the rest did work well. I don't
know the reason for that.  You can find more on how to apply patches
in the file INSTALL-SOURCE, chapter "Applying patches".

Now you're ready for compilation. This is done by the usual configure
and make runs. It's described in detail in the file
INSTALL-SOURCE-GENERIC. Here are the steps to do in short form:

   % ./configure
   % make
   % make check
   % make install
   % make clean
   % ldconfig
   % scripts/mysql_install_db

The whole procedure takes a lot of time (hours). I'm waiting for a Q60
:-).

Now you're ready to run. Before you can do anything with the database
system, you have to start the MySQL server:

   % safe_mysqld &

Administration is done with the "mysqladmin" program. For example,
check out if the server really is running by

   % mysqladmin version

and then shutdown the server with

   % mysqladmin shutdown

For the sake of security you should also set a password, this is again
done (after restarting the server) with mysqladmin:

   % mysqladmin -u root password new_password

Here you have to replace "new_password" with the one you want to have.

If you want to explore the existing databases and tables, use the
"mysqlshow" command.  Here are some simple sample commands (if you've
set a password, you need the -p option and you have to type in the
password after submitting the command) :

   % mysqlshow -p
   % mysqlshow -p mysql
   % mysqlshow -p mysql db

If you want to pass SQL commands to the DBMS, there is the "mysql"
command. Here is one example with a select statement. The password can
also be supplied directly, but then everyone who is looking over your
shoulder can read it:

   % mysql -pmy_password -e "select host, db, user from db" mysql

In order to get into that I suggest that you read the chapter
"Post-installation setup and testing" in the file INSTALL-SOURCE. The
main manual in the ./Docs directory is very good and describes
everything in detail, but is is also very long and it takes a while to
find what you're looking for.

If you like to produce a m68k binary RPM of MySQL you may try

    % rpm --rebuild MySQL-VERSION.src.rpm

I haven't done that yet and cannot guarantee that it works.

MySQL is a fairly complex application.  There are a number of
commercial  books that cover using MySQL.  To example books are:

   MySQL, Paul DuBois, New Riders
   MySQL & mSQL, O'Reilly & Associates

At www.mysql.com is an online version of a manual that includes a
tutorial.


Adding Themes to WindowMaker

I've decided to make WindowMaker my default window manager.  There
seems to be a fair amount of support in the Linux community for it,
versus the lack of support for fvwm95, the default window manager for
Red Hat 5.2.

A Theme in WindowMaker is a overall look for the window manager.  It
includes a background image, a different look for menus (but still the
same menus), a different font, and so on.  I ran across Themes when I
was looking into the different window managers available on the Q40.

The web site www.themes.org, is a repository for themes for many
different window managers.  The web page wm.themes.org has a listing
of all of the themes for WindowMaker.  The best way to get a feel for
what a Theme is, is to check out this web site and see all of the
examples.

I browsed around the web site and found a couple of themes that I
wanted to try.  I downloaded them, put them on floppy, and sneaker
netted them to the Q40.  

The themes are in a gzip tar file.  The files go into the ~/GNUstep/
Library/WindowMaker directory.  Then do the following

   % gzip -d file.tar.gz
   % tar -xvf file.tar

The files should be untarred to the proper directory.  The next step
is to start up WindowMaker and select a new theme.  Before doing this,
make a backup of the files in ~/GNUstep/Defaults/ directory.  I ran
into one Theme that seemed to have a problem and caused WindowMaker to
core dump on start up.  Since I could not run WindowMaker, I could not
change the Theme back.  I had to move the files in ~/GNUstep/Defaults/
aside and only then could I restart WindowMaker.

Once in WindowMaker, select the menu (right mouse) and then select
   Appearance
      Themes
        select Theme from the list.

The new Theme should take affect in a few seconds (give it time to
read in the new Background image).  That's all there is to it.

</pre></table></textarea><h3> &nbsp&nbsp&nbsp Source: <a href=/svenqhj>geocities.com/svenqhj</a><br></h3></div><table align="center" style="height:320px"><tr><td>
<div onClick="setTimeout(function(){location.reload();},2300);" id="2" style="display: inline;">
<script language="JavaScript" type="text/javascript">
var rp_account   = '9645';
var rp_site      = '17527';
var rp_zonesize  = '55620-15';
var rp_adtype    = 'js';
var rp_smartfile = '[SMART FILE URL]';
</script>
<script type="text/javascript" src="https://ads.rubiconproject.com/ad/9645.js"></script>
</div></td><td>
<div onClick="setTimeout(function(){location.reload();},2300);" id="1"  style="display: inline;">
<script language="JavaScript" type="text/javascript">
var rp_account   = '9645';
var rp_site      = '17527';
var rp_zonesize  = '55620-15';
var rp_adtype    = 'js';
var rp_smartfile = '[SMART FILE URL]';
</script>
<script type="text/javascript" src="https://ads.rubiconproject.com/ad/9645.js"></script>
</div></td><td>
<div onClick="setTimeout(function(){location.reload();},2300);" id="3"  style="display: inline;">
<script language="JavaScript" type="text/javascript">
var rp_account   = '9645';
var rp_site      = '17527';
var rp_zonesize  = '55620-15';
var rp_adtype    = 'js';
var rp_smartfile = '[SMART FILE URL]';
</script>
<script type="text/javascript" src="https://ads.rubiconproject.com/ad/9645.js"></script>
</div></td><td>
<div onClick="setTimeout(function(){location.reload();},2300);" id="4"  style="display: inline;">
<script language="JavaScript" type="text/javascript">
var rp_account   = '9645';
var rp_site      = '17527';
var rp_zonesize  = '55620-15';
var rp_adtype    = 'js';
var rp_smartfile = '[SMART FILE URL]';
</script>
<script type="text/javascript" src="https://ads.rubiconproject.com/ad/9645.js"></script>
</div>
</td></tr></table><br>
<script>
  (function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
  (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
  m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
  })(window,document,'script','https://www.google-analytics.com/analytics.js','ga');

  ga('create', 'UA-26808115-2', 'auto');
  ga('send', 'pageview');

</script>