--- doc/build/Attic/loncapasqldatabase.html 2001/02/12 17:32:15 1.5 +++ doc/build/Attic/loncapasqldatabase.html 2001/02/14 15:20:55 1.9 @@ -8,7 +8,7 @@ Scott Harrison

-Last updated: 02/12/2001 +Last updated: 02/14/2001

This file describes issues associated with LON-CAPA @@ -17,9 +17,11 @@ and a SQL database.

Latest HOWTO

+

Important notes

+

+It might be worthwhile to look at /usr/local/mysql/manual.html. +It is quite in depth. +

Current status of documentation

I am going to begin documentation by inserting what notes @@ -41,11 +48,22 @@ and checked again!

Current status of implementation

+Need to +

+

Right now, a lot of "feasibility" work has been done. Recipes for manual installation and configuration have been gathered. Network connectivity of lond->lonsql->lond->lonc type tests have been performed. A binary installation -has been compiled in an RPM (LON-CAPA-mysql). +has been compiled in an RPM (LON-CAPA-mysql, with perl components +a part of LON-CAPA-systemperl). The most lacking test in terms of feasibility has been looking at benchmarks to analyze the load at which the SQL database can efficiently allow many users to @@ -131,13 +149,31 @@ THE SOLUTION: processes (lonsql's) handle the MySQL database manipulations.

+

Dependencies

+

+I believe (but am not 100% confident) that the following +RPMs are necessary (in addition to the current ones +in rpm_list.txt) to run MySQL. Basically I discovered these +dependencies while trying to do external RPM based installs. +I assume, and sometimes found, that these dependencies apply +to tarball-based distributions too. (So to play it on the +safe side, I am going to include these RPMs as part of the +core, minimal RPM set.) +

+

Installation

Installation of the LON-CAPA SQL database normally occurs by default when using the LON-CAPA installation CD (see http://install.lon-capa.org). It is installed as the LON-CAPA-mysql RPM. This RPM encodes for the MySQL -engine and related perl interfaces (Perl::DBI, Perl::Msql-Mysql). +engine. Related perl interfaces (Perl::DBI, Perl::Msql-Mysql) +are encoded in the LON-CAPA-systemperl RPM.

The three components of a MySQL installation for the @@ -162,6 +198,201 @@ actual MySQL functionality on the system

Installation from source

+Note: the mysql site recommends that Linux users install by +using the MySQL RPMs (MySQL-client, MySQL, MySQL-shared, etc). +While these RPMs work, I was unsuccessful at integrating +this RPM-installed database with perl modules from www.cpan.org. +Hence, I strongly recommend that, when installing +from "source", MySQL and the perl components be in fact installed +from their tarballs (.tar.gz, .tgz). (Perl components, when installed +from RPMs, also wound up in incorrect locations on the disk.) +Do not coordinate a source install with externally made RPMs! +It is, of course, okay to use LON-CAPA RPMs such as LON-CAPA-systemperl +and LON-CAPA-mysql since we, in fact, made these RPMs correctly :). +

+

+

So, here is exactly how I installed MySQL-3.23. (Note that all files +wind up in /usr/local/mysql-3.23.33-pc-linux-gnu-i686 except for +a link from /usr/local/mysql to /usr/local/mysql-3.23.33-pc-linux-gnu-i686 +and some files involved in system process handling (/etc/rc.d/*/*mysql). +

+

This is how I installed the Msql-Mysql-modules perl modules. +

+[root@fenchurch Msql-Mysql-modules-1.2215]# perl Makefile.PL 
+Which drivers do you want to install?
+
+    1)	MySQL only
+    2)	mSQL only (either of mSQL 1 or mSQL 2)
+    3)  MySQL and mSQL (either of mSQL 1 or mSQL 2)
+
+    4)  mSQL 1 and mSQL 2
+    5)  MySQL, mSQL 1 and mSQL 2
+
+Enter the appropriate number:  [3] 1
+
+
+Do you want to install the MysqlPerl emulation? You might keep your old
+Mysql module (to be distinguished from DBD::mysql!) if you are concerned
+about compatibility to existing applications! [y] n
+[root@fenchurch Msql-Mysql-modules-1.2215]# make
+[root@fenchurch Msql-Mysql-modules-1.2215]# make test
+make[1]: Entering directory `/home/user/Msql-Mysql-modules-1.2215/mysql'
+make[1]: Leaving directory `/home/user/Msql-Mysql-modules-1.2215/mysql'
+make[1]: Entering directory `/home/user/Msql-Mysql-modules-1.2215/mysql'
+PERL_DL_NONLAZY=1 /usr/bin/perl -I../blib/arch -I../blib/lib -I/usr/lib/perl5/5.00503/i386-linux -I/usr/lib/perl5/5.00503 -e 'use Test::Harness qw(&runtests $verbose); $verbose=0; runtests @ARGV;' t/*.t
+t/00base............ok
+t/10dsnlist.........ok
+t/20createdrop......ok
+t/30insertfetch.....ok
+t/40bindparam.......ok
+t/40blobs...........ok
+t/40listfields......ok
+t/40nulls...........ok
+t/40numrows.........ok
+t/50chopblanks......ok
+t/50commit..........ok
+t/60leaks...........skipping test on this platform
+t/ak-dbd............ok
+t/akmisc............ok
+t/dbdadmin..........ok
+t/mysql.............ok
+t/mysql2............ok
+All tests successful, 1 test skipped.
+Files=17,  Tests=732, 40 wallclock secs (15.38 cusr +  1.30 csys = 16.68 CPU)
+[root@fenchurch Msql-Mysql-modules-1.2215]# make install
+
+These files are installed.
+/usr/bin/dbimon
+/usr/lib/perl5/man/man3/Bundle::DBD::mysql.3
+/usr/lib/perl5/man/man3/DBD::mysql.3
+/usr/lib/perl5/man/man3/Mysql.3
+/usr/lib/perl5/site_perl/5.005/i386-linux/Bundle/DBD/mysql.pm
+/usr/lib/perl5/site_perl/5.005/i386-linux/DBD/mysql.pm
+/usr/lib/perl5/site_perl/5.005/i386-linux/Mysql.pm
+/usr/lib/perl5/site_perl/5.005/i386-linux/Mysql/Statement.pm
+/usr/lib/perl5/site_perl/5.005/i386-linux/auto/DBD/mysql/mysql.bs
+/usr/lib/perl5/site_perl/5.005/i386-linux/auto/DBD/mysql/mysql.so
+/usr/man/man1/dbimon.1
+/usr/lib/perl5/site_perl/5.005/i386-linux/auto/Msql-Mysql-modules/.packlist
+
+

+

+This is how I installed the DBI perl modules. +

+[root@fenchurch DBI-1.14]# perl Makefile.PL
+*** Note:
+    The optional PlRPC-modules (RPC::PlServer etc) are not installed.
+    If you want to use the DBD::Proxy driver and DBI::ProxyServer
+    modules, then you'll need to install the RPC::PlServer, RPC::PlClient,
+    Storable and Net::Daemon modules. The CPAN Bundle::DBI may help you.
+    You can install them any time after installing the DBI.
+    You do *not* need these modules for typical DBI usage.
+
+Optional modules are available from any CPAN mirror, in particular
+    http://www.perl.com/CPAN/modules/by-module
+    http://www.perl.org/CPAN/modules/by-module
+    ftp://ftp.funet.fi/pub/languages/perl/CPAN/modules/by-module
+
+Checking if your kit is complete...
+Looks good
+Writing Makefile for DBI
+
+    Remember to actually *read* the README file!
+    Use  'make' to build the software (dmake or nmake on Windows).
+    Then 'make test' to execute self tests.
+    Then 'make install' to install the DBI and then delete this working
+    directory before unpacking and building any DBD::* drivers.
+
+[root@fenchurch DBI-1.14]# make
+[root@fenchurch DBI-1.14]# make test
+PERL_DL_NONLAZY=1 /usr/bin/perl -Iblib/arch -Iblib/lib -I/usr/lib/perl5/5.00503/i386-linux -I/usr/lib/perl5/5.00503 -e 'use Test::Harness qw(&runtests $verbose); $verbose=0; runtests @ARGV;' t/*.t
+t/basics............ok
+t/dbidrv............ok
+t/examp.............ok
+t/meta..............ok
+t/proxy.............skipping test on this platform
+t/shell.............ok
+t/subclass..........ok
+All tests successful, 1 test skipped.
+Files=7,  Tests=179,  7 wallclock secs ( 6.46 cusr +  0.49 csys =  6.95 CPU)
+PERL_DL_NONLAZY=1 /usr/bin/perl -Iblib/arch -Iblib/lib -I/usr/lib/perl5/5.00503/i386-linux -I/usr/lib/perl5/5.00503 test.pl
+test.pl 
+DBI test application $Revision: 1.9 $
+Using /home/user/DBI-1.14/blib
+Switch: DBI 1.14 by Tim Bunce, 1.14
+Available Drivers: ADO, ExampleP, Multiplex, Proxy, mysql
+dbi:ExampleP:: testing 5 sets of 20 connections:
+Connecting... 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 
+Disconnecting...
+Connecting... 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 
+Disconnecting...
+Connecting... 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 
+Disconnecting...
+Connecting... 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 
+Disconnecting...
+Connecting... 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 
+Disconnecting...
+Made 100 connections in  0 wallclock secs ( 0.22 usr +  0.03 sys =  0.25 CPU)
+
+Testing handle creation speed...
+5000 NullP statement handles cycled in 6.6 cpu+sys seconds (762 per sec)
+
+test.pl done
+
+[root@fenchurch DBI-1.14]# make install
+These files are installed.
+/usr/lib/perl5/site_perl/5.005/i386-linux/auto/DBI/.packlist
+/usr/bin/dbiproxy
+/usr/bin/dbish
+/usr/lib/perl5/man/man3/Bundle::DBI.3
+/usr/lib/perl5/man/man3/DBD::ADO.3
+/usr/lib/perl5/man/man3/DBD::Multiplex.3
+/usr/lib/perl5/man/man3/DBD::Proxy.3
+/usr/lib/perl5/man/man3/DBI.3
+/usr/lib/perl5/man/man3/DBI::DBD.3
+/usr/lib/perl5/man/man3/DBI::FAQ.3
+/usr/lib/perl5/man/man3/DBI::Format.3
+/usr/lib/perl5/man/man3/DBI::ProxyServer.3
+/usr/lib/perl5/man/man3/DBI::Shell.3
+/usr/lib/perl5/man/man3/DBI::W32ODBC.3
+/usr/lib/perl5/man/man3/Win32::DBIODBC.3
+/usr/lib/perl5/site_perl/5.005/i386-linux/Bundle/DBI.pm
+/usr/lib/perl5/site_perl/5.005/i386-linux/DBD/ADO.pm
+/usr/lib/perl5/site_perl/5.005/i386-linux/DBD/ExampleP.pm
+/usr/lib/perl5/site_perl/5.005/i386-linux/DBD/Multiplex.pm
+/usr/lib/perl5/site_perl/5.005/i386-linux/DBD/NullP.pm
+/usr/lib/perl5/site_perl/5.005/i386-linux/DBD/Proxy.pm
+/usr/lib/perl5/site_perl/5.005/i386-linux/DBD/Sponge.pm
+/usr/lib/perl5/site_perl/5.005/i386-linux/DBI.pm
+/usr/lib/perl5/site_perl/5.005/i386-linux/DBI/DBD.pm
+/usr/lib/perl5/site_perl/5.005/i386-linux/DBI/FAQ.pm
+/usr/lib/perl5/site_perl/5.005/i386-linux/DBI/Format.pm
+/usr/lib/perl5/site_perl/5.005/i386-linux/DBI/ProxyServer.pm
+/usr/lib/perl5/site_perl/5.005/i386-linux/DBI/Shell.pm
+/usr/lib/perl5/site_perl/5.005/i386-linux/DBI/W32ODBC.pm
+/usr/lib/perl5/site_perl/5.005/i386-linux/Win32/DBIODBC.pm
+/usr/lib/perl5/site_perl/5.005/i386-linux/auto/DBI/DBI.bs
+/usr/lib/perl5/site_perl/5.005/i386-linux/auto/DBI/DBI.so
+/usr/lib/perl5/site_perl/5.005/i386-linux/auto/DBI/DBIXS.h
+/usr/lib/perl5/site_perl/5.005/i386-linux/auto/DBI/Driver.xst
+/usr/lib/perl5/site_perl/5.005/i386-linux/auto/DBI/dbd_xsh.h
+/usr/lib/perl5/site_perl/5.005/i386-linux/auto/DBI/dbi_sql.h
+/usr/lib/perl5/site_perl/5.005/i386-linux/auto/DBI/dbipport.h
+/usr/man/man1/dbiproxy.1
+/usr/man/man1/dbish.1
+
+

+ old notes in green +

The following set of tarballs was found to work together properly on a LON-CAPA RedHat 6.2 system: