Thanks to LIS student Kris Meen, we now have the Amazon lookup working with the Openbiblio ILS. The problem had been that it installed ok but that every search turned up zero results.
We had obtained an access key by registereding with Amazon web services. The problem was that Amazon provided a key ID as well as a secret access key.
We had originally followed the instructions for the patch and edited the amazon conf.php file and added the secret access key. The solution is to use the access key ID not the secret key.
Wednesday, November 25, 2009
Tuesday, November 3, 2009
Open Biblio Again
Back to the little library system. We tried to get the Library of Congress lookup patch working without success. I think we made all the changes but it seems to be looking for a .php file in the catalog folder. Will troubleshoot later.
Today we want to try web biblio, a fork of the open biblio project. We downloaded the .zip from the open biblio downloads page link and unzipped the webbiblio3 folder to xampplite/htdocs.
We then went to http://localhost/webbiblio3/install/ to bring up the installation instructions. First task is to create the mySQL database. We open a DOS command shell and run mysql -hlocalhost -uroot to connect to the database server running on the USB stick and issue the following commands:
create database webbiblio;
use webbiblio;
mysql> grant all privileges on WebBiblio.* to webbib@localhost identified by 'zx8180';
Interesting, you don't have to edit the database_constants.php file as the instructions contain a web form that does it for you. I'll leave it as the default of root with no password as this is a USB stick - otherwise we would change it to the webbib user we just created.
After clicking SUBMIT the message database created successfully is displayed. We click on the link and the home page is displayed. We click the Admin tab and login with username admin and password admin.
We want to take a look at this system as a solution to the digital files problem. We have terabytes of digital files, mainly ebooks, video and audio. With this system we could grab cataloging data by doing a LOC or Amazon lookup on the ISBN and then upload the matching ebook file or audio/video file. There is a 128mb limit on file uploads but that can be changed.
We note an error 'upload folder is not writable'. Looking at webbiblio3 folder - where do the uploads go? No information on the web site. Looks like you got to search the source code to figure it out. Documentation is nice....
Today we want to try web biblio, a fork of the open biblio project. We downloaded the .zip from the open biblio downloads page link and unzipped the webbiblio3 folder to xampplite/htdocs.
We then went to http://localhost/webbiblio3/install/ to bring up the installation instructions. First task is to create the mySQL database. We open a DOS command shell and run mysql -hlocalhost -uroot to connect to the database server running on the USB stick and issue the following commands:
create database webbiblio;
use webbiblio;
mysql> grant all privileges on WebBiblio.* to webbib@localhost identified by 'zx8180';
Interesting, you don't have to edit the database_constants.php file as the instructions contain a web form that does it for you. I'll leave it as the default of root with no password as this is a USB stick - otherwise we would change it to the webbib user we just created.
After clicking SUBMIT the message database created successfully is displayed. We click on the link and the home page is displayed. We click the Admin tab and login with username admin and password admin.
We want to take a look at this system as a solution to the digital files problem. We have terabytes of digital files, mainly ebooks, video and audio. With this system we could grab cataloging data by doing a LOC or Amazon lookup on the ISBN and then upload the matching ebook file or audio/video file. There is a 128mb limit on file uploads but that can be changed.
We note an error 'upload folder is not writable'. Looking at webbiblio3 folder - where do the uploads go? No information on the web site. Looks like you got to search the source code to figure it out. Documentation is nice....
Monday, September 28, 2009
Greenstone on the Mac and Linux
Since the new version of Greenstone now includes the remote GLI client, we are keen to test out a server install and to use the client to connect to a portable server, either linux or osx based.
First we download the .dmg from http://www.greenstone.org and extract and run the 2.82 installer. This installs to /Users/gnickers/Greenstone and we select the core, imagemagick and ghostscript. We also enable the Admin pages checkbox with the usual password.
Click Install and away it goes, completing in 42 seconds. In the Greenstone folder we find a bunch of directories:
apache-httpd - the web server
gli - the librarian interface for building collections
bin - executables
collect - collections
image - CSS files and images
The greenstone server interface (GSI) is an application to start/stop the local library server. On Linux and OSX it uses the apache web server that comes with Greenstone.
I see the gs2-server.sh file is there and on linux this requires a trip to the terminal and the ./gs2-server.sh command but it's been years since i did much in the cli in osx. We try it out in terminal and it works. However, port 80 is in use or can't be assigned. (apache already running?) so it assigned port 8282 and pops up a dialog box. We click Enter Library and the server control panel starts up in the web browser. However Safari returns 'can't connect to server'.
Curious to see if localhost is running we try port 80 but nothing. So what's using port 80? We don't have skype installed...
Ubuntu Install
So we try the linux version. The installer program runs just the same. We open a shell and cd Greenstone and type:
./gs2-server.sh
and get the same message about 'port 80 in use or can't be assigned'. We click Enter Library but get the same 'Failed to Connect to locahost:8282
Time for some research....
First we download the .dmg from http://www.greenstone.org and extract and run the 2.82 installer. This installs to /Users/gnickers/Greenstone and we select the core, imagemagick and ghostscript. We also enable the Admin pages checkbox with the usual password.
Click Install and away it goes, completing in 42 seconds. In the Greenstone folder we find a bunch of directories:
apache-httpd - the web server
gli - the librarian interface for building collections
bin - executables
collect - collections
image - CSS files and images
The greenstone server interface (GSI) is an application to start/stop the local library server. On Linux and OSX it uses the apache web server that comes with Greenstone.
I see the gs2-server.sh file is there and on linux this requires a trip to the terminal and the ./gs2-server.sh command but it's been years since i did much in the cli in osx. We try it out in terminal and it works. However, port 80 is in use or can't be assigned. (apache already running?) so it assigned port 8282 and pops up a dialog box. We click Enter Library and the server control panel starts up in the web browser. However Safari returns 'can't connect to server'.
Curious to see if localhost is running we try port 80 but nothing. So what's using port 80? We don't have skype installed...
Ubuntu Install
So we try the linux version. The installer program runs just the same. We open a shell and cd Greenstone and type:
./gs2-server.sh
and get the same message about 'port 80 in use or can't be assigned'. We click Enter Library but get the same 'Failed to Connect to locahost:8282
Time for some research....
Wednesday, September 23, 2009
HeidiSQL tool for mySQL
We have been using XAMPP on USB sticks for teaching for some time now. One of the problems has been the limited tools to manage the mySQL database server:
- phpmyadmin web interface
- mysql command line text-mode client
While the command line client is fast and has a lot of advantages it is somewhat an alien way of working for students. The web interface is more familiar but is slow and very old web like.
Of course you can use some of the great third-party tools for mySQL if they are installed but the general use labs only have the mySQL query browser. My favorite 2rd party tool is Navicat for OSX, I first purchased it years ago for a database project, it did everything well. But it is commercial (although they now have a free Lite version) so out of the student's reach. What we really wanted was a nice GUI tool that would run as a portable application.
Well, amazing enough such a creature exists and it is called HeidiSQL. Goto http://www.heidisql.com/ and have a look. There is a portable version that takes only 4.6 mb of space on a USB Stick.
Run the .exe installer and point it to the PortableApps folder on your USB stick. You don't have to install it there but if you do then it automatically gets added to the Portable Apps menu. Note that you don't actually have to have Portable Apps installed to run any portable application, you can just run the .exe file. However, having a nice menu system is a bonus that helps keep things organized.
When you run the program it brings up a connection manager for your session. Just fill in localhost for the IP, root for the User and click Connect! If you do not specify a database it will show you all the databases on the mySQL server, if you specify a database it only shows you that one.
For a light client it has lots of features, import/export of data and sql files, data search/edit etc, user account admin, SQL queries, database admin and it can even create views. What's not to like?
I think we have found a winner for class use. For more information goto:
http://code.google.com/p/heidisql/ which provide the following list of features:
- phpmyadmin web interface
- mysql command line text-mode client
While the command line client is fast and has a lot of advantages it is somewhat an alien way of working for students. The web interface is more familiar but is slow and very old web like.
Of course you can use some of the great third-party tools for mySQL if they are installed but the general use labs only have the mySQL query browser. My favorite 2rd party tool is Navicat for OSX, I first purchased it years ago for a database project, it did everything well. But it is commercial (although they now have a free Lite version) so out of the student's reach. What we really wanted was a nice GUI tool that would run as a portable application.
Well, amazing enough such a creature exists and it is called HeidiSQL. Goto http://www.heidisql.com/ and have a look. There is a portable version that takes only 4.6 mb of space on a USB Stick.
Run the .exe installer and point it to the PortableApps folder on your USB stick. You don't have to install it there but if you do then it automatically gets added to the Portable Apps menu. Note that you don't actually have to have Portable Apps installed to run any portable application, you can just run the .exe file. However, having a nice menu system is a bonus that helps keep things organized.
When you run the program it brings up a connection manager for your session. Just fill in localhost for the IP, root for the User and click Connect! If you do not specify a database it will show you all the databases on the mySQL server, if you specify a database it only shows you that one.
For a light client it has lots of features, import/export of data and sql files, data search/edit etc, user account admin, SQL queries, database admin and it can even create views. What's not to like?
I think we have found a winner for class use. For more information goto:
http://code.google.com/p/heidisql/ which provide the following list of features:
With HeidiSQL you will be able to
- generate nice SQL-exports
- synchronize tables between two databases
- manage user-privileges
- import text-files
- export table-data as CSV, HTML, XML and SQL
- browse and edit table-data using a comfortable grid
- create and edit stored procedures
- batch-insert ascii or binary files into tables
- write queries with customizable syntax-highlighting and code-completion
- monitor and kill client-processes
- connect to servers via commandline
- and much more
MARC Records into Greenstone
This was a test of getting MARC record imported in Greenstone digital library software and automatically filling in the Dublin Core metadata elements
The first step was to get the MARC records into a file. There are three ways to do this:
- save some records from a library OPAC
- find a file of marc records on the Internet
- use a Z39.50 client
We tested the first two methods. The library OPAC was straightforward, you do a search and tag or select the records you want and then view them. There are several options such as ProCite and MARC format, so we selected MARC and the local disk option and saved them to a file.
The downloaded file was called export.txt so we renamed it export.marc for importing into Greenstone.
Importing
1. We ran the GLI for greenstone and created a new collection
2. Click the Gather tab, expand the Local Filespace
3. Drag export.marc into the Collection window and ADD the MARCplugin
4. Right-click on export.marc in the Collection window and select Explode Metadata Database
5. Select Dublin Core from the metadata_set pulldown and click Explode
6. Click the Design tab
7. Select Marcplugin and click Remove Plugin
You can now build and preview the collection but the display will be all wrong. Remove the default search and browsing indexes. Now you have to create indexes based on the Dublin Core metadata set, for example an Author index:
1. Click Design, Browsing Classifiers
2. Select AZcompactlist from the Select Classifier pulldown menu
3. Click Add Classifier
4. Select dc.Creator from the metadata pulldown menu
5. Place a tickmark in the allvalues checkbox
6. Place a tickmark in the buttonmane checkbox and type in Authors as a menu label
Let's also add a Subject index:
1. Select AZcompactlist from the Select Classifier pulldown
2. Click Add Classifier
3. Select dc.Subject from the metadata pulldown
4. Tick the allvalues checkbox
5. Click OK
Build and preview to see the new indexes, but the display will still be a bit off. The next step is to change the formatting instructions for the web pages:
1. Click Format, Format Features
2. Delete the first and last lines in the HTML Format String box
Once the above two lines are deleted you can refresh the web pages - html or css changes do not require a rebuild. However, if you click on the icon to view the document no text is displayed and the document heading is wrong.
1. Click on Format, Format Features
2. Select DocumentHeading in the Choose Feature pulldown
3. Delete the text in the HTML Format String box
This gets red of the incorrect document header. Now to fix the 'no text' document:
1. Click Format, Format Features
2. Select DocumentText in the Choose Feature pulldown
3. Replace [text] with the following HTML code:
You can add a little inline CSS to pretty up the presentation but you get the idea. The final step is to remove the buttons as there is nothing to detach and highlighting makes no sense in a short bibliographic record:
1. Click Format, Format Features
2. Select Document Buttons
3. Delete the text in the HTML Format String box
You can now preview the collection. Obviously there is a lot more that could be done such as having the index nodes indicate how many records they contain using the [numleafdocs] variable and we could make a much nicer display by tweaking the external style sheet....
Appendix
I downloaded the Terry Reese's excellent MARCedit program to do a little experiment on the marc records files i have saved from the library OPAC. I wanted to test out converting MARC to Dublin Core. Here's what i did:
1. Renamed the export.marc file to export.mrc (marcdedit does not recognize .marc extension)
2. Ran MARCedit and selected MARCbreaker
3. Select MARC -> Dublin Core
4. Choose export.mrc as the input file
4. Choose an export file of weldon_dc.txt and clicked Execute
It created a plain text XML file that uses rdf:description and replaces all the MARC tags with Dublin Core tags. Here is a snippet of the file of records:
Accelerated SQL Server 2008 [electronic resource] /
Walters, Robert E.
Coles, Michael.
Farmer, Donald.
Ferracchiati, Fabio.
Rae, Robert.
SpringerLink (Online service)
text
Berkeley, CA : Robert Walters,
2008.
eng
Data structures (Computer science)
Springer eBooks.
http://dx.doi.org/10.1007/978-1-4302-0606-4
The problem is that i cannot get this file to explode in Greenstone, it imports as one file of one record using LOMplug. I'll have to do some research on this tomorrow...
The first step was to get the MARC records into a file. There are three ways to do this:
- save some records from a library OPAC
- find a file of marc records on the Internet
- use a Z39.50 client
We tested the first two methods. The library OPAC was straightforward, you do a search and tag or select the records you want and then view them. There are several options such as ProCite and MARC format, so we selected MARC and the local disk option and saved them to a file.
The downloaded file was called export.txt so we renamed it export.marc for importing into Greenstone.
Importing
1. We ran the GLI for greenstone and created a new collection
2. Click the Gather tab, expand the Local Filespace
3. Drag export.marc into the Collection window and ADD the MARCplugin
4. Right-click on export.marc in the Collection window and select Explode Metadata Database
5. Select Dublin Core from the metadata_set pulldown and click Explode
6. Click the Design tab
7. Select Marcplugin and click Remove Plugin
You can now build and preview the collection but the display will be all wrong. Remove the default search and browsing indexes. Now you have to create indexes based on the Dublin Core metadata set, for example an Author index:
1. Click Design, Browsing Classifiers
2. Select AZcompactlist from the Select Classifier pulldown menu
3. Click Add Classifier
4. Select dc.Creator from the metadata pulldown menu
5. Place a tickmark in the allvalues checkbox
6. Place a tickmark in the buttonmane checkbox and type in Authors as a menu label
Let's also add a Subject index:
1. Select AZcompactlist from the Select Classifier pulldown
2. Click Add Classifier
3. Select dc.Subject from the metadata pulldown
4. Tick the allvalues checkbox
5. Click OK
Build and preview to see the new indexes, but the display will still be a bit off. The next step is to change the formatting instructions for the web pages:
1. Click Format, Format Features
2. Delete the first and last lines in the HTML Format String box
Once the above two lines are deleted you can refresh the web pages - html or css changes do not require a rebuild. However, if you click on the icon to view the document no text is displayed and the document heading is wrong.
1. Click on Format, Format Features
2. Select DocumentHeading in the Choose Feature pulldown
3. Delete the text in the HTML Format String box
This gets red of the incorrect document header. Now to fix the 'no text' document:
1. Click Format, Format Features
2. Select DocumentText in the Choose Feature pulldown
3. Replace [text] with the following HTML code:
You can add a little inline CSS to pretty up the presentation but you get the idea. The final step is to remove the buttons as there is nothing to detach and highlighting makes no sense in a short bibliographic record:
1. Click Format, Format Features
2. Select Document Buttons
3. Delete the text in the HTML Format String box
You can now preview the collection. Obviously there is a lot more that could be done such as having the index nodes indicate how many records they contain using the [numleafdocs] variable and we could make a much nicer display by tweaking the external style sheet....
Appendix
I downloaded the Terry Reese's excellent MARCedit program to do a little experiment on the marc records files i have saved from the library OPAC. I wanted to test out converting MARC to Dublin Core. Here's what i did:
1. Renamed the export.marc file to export.mrc (marcdedit does not recognize .marc extension)
2. Ran MARCedit and selected MARCbreaker
3. Select MARC -> Dublin Core
4. Choose export.mrc as the input file
4. Choose an export file of weldon_dc.txt and clicked Execute
It created a plain text XML file that uses rdf:description and replaces all the MARC tags with Dublin Core tags. Here is a snippet of the file of records:
The problem is that i cannot get this file to explode in Greenstone, it imports as one file of one record using LOMplug. I'll have to do some research on this tomorrow...
Sunday, August 30, 2009
XAMPP on a CD
Xampp on a CD
The goal today is to produce a self-running cd-rom containing the XAMPP stack along with joomla so that students can burn their projects running on a USB stick to a CD-ROM.
Requirements:
[autorun] open=autorun.bat icon=joomla.png Label=server
I created a small icon of 32x32 pixels. When ampstart is running the icon is in the windows system tray. Double-click on the icon to shut down the web server and unlock the cd tray.
The autorun.bat file consists of:
@echo off rem script to make auto-run xampp joomla lis 9710 cd rem creates a mysql data dir on c because mysql needs a writable folder mkdir c:\mysql\data xcopy xampp\mysql\data\ c:\mysql\data /E start AMPstart.exe
the ampstart.ini file consists of:
[database] overwrite=1 folder=c:\mysql\data [website] website=htdocs\joomla startup=index.php port= [cd] eject=1
The eject option ejects the cd when the web server is shut down. Will it work? Our previous attempts at running from a cd failed and this is when we started researching ampstart. There are some other options we might add later to the .ini file if this works.
[WEBSITE]
website=\path\to\web\app
You can also auto open firefox if it is not the default web browser with:
[WEBSITE]
ExtBrowser=\path\to\browser\executable\file
If you want to make the site seem more realistic in a demo (such as a real looking url instead of localhost) use:
[WEBSITE]
ServerName=somedomain
website=\path\to\web\app
To auto shut down the web server when the web apps ends use:
[WEBSITE]
ShutdownOnClose=1
And to set the duration for the ampstart splash screen use:
[LOGO]
duration=n_second
;default 0 (depending on loading time of web server)
Ok so here we go - burn the cd from the usb stick. Here is the folder structure. It suddenly occurs to me that we have been closing the disc so that it is read-only. What is we made the disc a multi-session? Could mysql then write to its data directory on the cd?
Might be worth trying if this test fails.
Ok and it fails because it could not copy the mysql data folder to the c: drive. Why? Let's step thru the command one by one in the windows shell. The mkdir command works as their is a c:\mysql\data folder. The xcopy fails with an invalid path error. Time to haul out the ms-dos manual...ahhh i'm using the /E switch but it requires the /S switch:
/S - Copies all files in the current directory and in any subdirectory within it.
/E - Copies subdirectories, even if they are empty. If you use this option, you must use the /S option also.
But that doesn't account for the 'path' error. If i change directories to xampp\mysql\data and end up with a pwd of \xampp\mysql\data then the xcopy command works perfectly. But when executed from the root of the usb stick it fails. Ok, this suggests a workaround - just cd into the data folder and then run the xcopy command, a hack but quicker than trying to recall how ms-dos works. So out new autorun.bat looks like:
@echo off
rem script to make auto-run xampp joomla cd
rem creates a mysql data dir on c because mysql needs it
mkdir c:\mysql\data
cd \xampp\mysql\data
xcopy *.* c:\mysql\data /E /S /C
cd \
start AMPstart.exe
Ok - time to burn another CD. This one fails too - mysql error 'could not make a copy' but it did make a copy. The webserver app then just tries to run and fails. Since ampstart is running maybe the error is from the ampstart.ini file. Let's change that to:
[database]
overwrite=0
folder=c:\mysql\data
[website]
website=htdocs\joomla
startup=index.php
port=
[cd]
eject=1
Ok burn another CD...which fails with 'cannot load mysql'. I went looking for the ampstart site but the domain name seems to have lapsed. But the search turned up Lampix, a bootable cd based on knoppix. See: http://lamppix.tinowagner.com/ But it hasn't been updated since 2007 and getting your files from the USB stick to the CD is more work than we want to do. There must be a solution somewhere...
Of course they could just hand in their projects on USB sticks but until they are less than $5 a gig this is not a realistic option...
The goal today is to produce a self-running cd-rom containing the XAMPP stack along with joomla so that students can burn their projects running on a USB stick to a CD-ROM.
Requirements:
- USB stick running xampp with joomla installed
- AMPstart software (replaces the xampp control panel)
- autorun.inf file
- autorun.bat file
- ampstart.ini file
- cd-rom burning software
[autorun] open=autorun.bat icon=joomla.png Label=server
I created a small icon of 32x32 pixels. When ampstart is running the icon is in the windows system tray. Double-click on the icon to shut down the web server and unlock the cd tray.
The autorun.bat file consists of:
@echo off rem script to make auto-run xampp joomla lis 9710 cd rem creates a mysql data dir on c because mysql needs a writable folder mkdir c:\mysql\data xcopy xampp\mysql\data\ c:\mysql\data /E start AMPstart.exe
the ampstart.ini file consists of:
[database] overwrite=1 folder=c:\mysql\data [website] website=htdocs\joomla startup=index.php port= [cd] eject=1
The eject option ejects the cd when the web server is shut down. Will it work? Our previous attempts at running from a cd failed and this is when we started researching ampstart. There are some other options we might add later to the .ini file if this works.
[WEBSITE]
website=\path\to\web\app
You can also auto open firefox if it is not the default web browser with:
[WEBSITE]
ExtBrowser=\path\to\browser\executable\file
If you want to make the site seem more realistic in a demo (such as a real looking url instead of localhost) use:
[WEBSITE]
ServerName=somedomain
website=\path\to\web\app
To auto shut down the web server when the web apps ends use:
[WEBSITE]
ShutdownOnClose=1
And to set the duration for the ampstart splash screen use:
[LOGO]
duration=n_second
;default 0 (depending on loading time of web server)
Ok so here we go - burn the cd from the usb stick. Here is the folder structure. It suddenly occurs to me that we have been closing the disc so that it is read-only. What is we made the disc a multi-session? Could mysql then write to its data directory on the cd?
Might be worth trying if this test fails.
Ok and it fails because it could not copy the mysql data folder to the c: drive. Why? Let's step thru the command one by one in the windows shell. The mkdir command works as their is a c:\mysql\data folder. The xcopy fails with an invalid path error. Time to haul out the ms-dos manual...ahhh i'm using the /E switch but it requires the /S switch:
/S - Copies all files in the current directory and in any subdirectory within it.
/E - Copies subdirectories, even if they are empty. If you use this option, you must use the /S option also.
But that doesn't account for the 'path' error. If i change directories to xampp\mysql\data and end up with a pwd of \xampp\mysql\data then the xcopy command works perfectly. But when executed from the root of the usb stick it fails. Ok, this suggests a workaround - just cd into the data folder and then run the xcopy command, a hack but quicker than trying to recall how ms-dos works. So out new autorun.bat looks like:
@echo off
rem script to make auto-run xampp joomla cd
rem creates a mysql data dir on c because mysql needs it
mkdir c:\mysql\data
cd \xampp\mysql\data
xcopy *.* c:\mysql\data /E /S /C
cd \
start AMPstart.exe
Ok - time to burn another CD. This one fails too - mysql error 'could not make a copy' but it did make a copy. The webserver app then just tries to run and fails. Since ampstart is running maybe the error is from the ampstart.ini file. Let's change that to:
[database]
overwrite=0
folder=c:\mysql\data
[website]
website=htdocs\joomla
startup=index.php
port=
[cd]
eject=1
Ok burn another CD...which fails with 'cannot load mysql'. I went looking for the ampstart site but the domain name seems to have lapsed. But the search turned up Lampix, a bootable cd based on knoppix. See: http://lamppix.tinowagner.com/ But it hasn't been updated since 2007 and getting your files from the USB stick to the CD is more work than we want to do. There must be a solution somewhere...
Of course they could just hand in their projects on USB sticks but until they are less than $5 a gig this is not a realistic option...
Monday, August 24, 2009
Dell Mini 9 Ubuntu Update
I've been using the dell mini 9 for a month or so now and it's time to upgrade it to ubuntu 9. The rationale is:
So time to update to 9. The question is how - we have the 9 cd and a usb dvd so we could go that route or we could do the notebook remix route and use the USB key method which is appealing.
First we get a torrent and download ubuntu-9.04-netbooks-remix-i386.img which is an image to be burned to a usb stick. Next, off to the package manager to install usb-imagewriter version 0.1.3 from the repository. We put in a 2 gig spare stick and run the program using:
Applications, Accessories, Image Writer
It returns an error 'no target devices found'. So it did not find a USB stick. We note the mounted stick does not have the orange usb symbol on it so we unmount it and plug it into another usb port. We check and this is listed as /dev/sdb
Re-running image writer works. It asks us for an image. We select the netbook-remix img file and start writing it to the usb stick.
Ok now that it is done put it in the dell mini and boot it on up. We first select the try option to see how it will look and if samba networking is fixed. Up it comes we click on networking and //megatron and //mothra show up immediately. We can't mount mothra shares so we try megatron. No joy here. Networking works as we can get to the internet but not to my local network. On the plus side this is running pretty fast off the usb stick.
Also not sure i like the desktop - it is designed like all the netbook OS with a bunch of icons cluttering up your space. This is supposed to be better? We do have an inspiron 910 img we could try as well as the stock ubuntu 9 cd. Let's try the CD first.
Ok we plug in a usb and boot to the liveCD mode and try to browse the network shares. The machines show up but unable to mount their shares to see them. Internet works but not the local network. So we might as well keep the machine as is and if time permits do some samba troubleshooting. This has always been a weakness of Linux, imho - osx works perfectly well with windows shares and it is a multi-vendor world. I don't like windows but we have to co-exist with it so it should just work.
- the dell ubuntu install is version 8 so it is old
- it uses the dell repositories so not many updates
- samba was broken on install, which is unforgivable as we have to coexist with windows
So time to update to 9. The question is how - we have the 9 cd and a usb dvd so we could go that route or we could do the notebook remix route and use the USB key method which is appealing.
First we get a torrent and download ubuntu-9.04-netbooks-remix-i386.img which is an image to be burned to a usb stick. Next, off to the package manager to install usb-imagewriter version 0.1.3 from the repository. We put in a 2 gig spare stick and run the program using:
Applications, Accessories, Image Writer
It returns an error 'no target devices found'. So it did not find a USB stick. We note the mounted stick does not have the orange usb symbol on it so we unmount it and plug it into another usb port. We check and this is listed as /dev/sdb
Re-running image writer works. It asks us for an image. We select the netbook-remix img file and start writing it to the usb stick.
Ok now that it is done put it in the dell mini and boot it on up. We first select the try option to see how it will look and if samba networking is fixed. Up it comes we click on networking and //megatron and //mothra show up immediately. We can't mount mothra shares so we try megatron. No joy here. Networking works as we can get to the internet but not to my local network. On the plus side this is running pretty fast off the usb stick.
Also not sure i like the desktop - it is designed like all the netbook OS with a bunch of icons cluttering up your space. This is supposed to be better? We do have an inspiron 910 img we could try as well as the stock ubuntu 9 cd. Let's try the CD first.
Ok we plug in a usb and boot to the liveCD mode and try to browse the network shares. The machines show up but unable to mount their shares to see them. Internet works but not the local network. So we might as well keep the machine as is and if time permits do some samba troubleshooting. This has always been a weakness of Linux, imho - osx works perfectly well with windows shares and it is a multi-vendor world. I don't like windows but we have to co-exist with it so it should just work.
Sunday, August 2, 2009
VNC on the USB
Remote Access via the USB Stick
Last week while cleaning out the storage device i ran across an old vnc program. I had used this in class some years ago to connect to the Linux server i was running in my office. It got me thinking about adding VNC capabilities to the USB stick.
There is no listed VNC downloadable application at http://portableapps.com/apps but you can add non-installable programs to the environment. For example, I setup winamp for an internet radio on a usb stick demo some terms ago.
So off we go to http://www.tightvnc.com/ to grab the latest version of the viewer which is tightvnc-1.3.10_x86_viewer.zip from which we extract vncviewer.exe
Next we create a file folder called vnc in the /PortableApps folder on the USB stick and copy vncviewer.exe to that folder. From the Portable Apps menu we select Options, Refresh App Icons and the menu item TightVNC Win32 Viewer is added. You can do this for most applications that do not install but you have to create a folder for them else portable apps will not create a menu item.
VNC Server
The next step is to set up the VNC server. Since our portable server is a mac mini running osx server it already has a VNC server, we just have to turn it on. So over to the mac and select System Preferences, Sharing. We place a checkmark in the Screen Sharing box and set a password for the VNC viewer. This is for version 10.5, which has made some changes from the setup used in 10.4 but instructions for 10.4 can be found at http://www.dssw.co.uk/blog/2007/05/14/a-vnc-server-is-included-in-mac-os-x-104/.
Connecting
Backto the USB stick we run VNC viewer and enter the IP address of the osx server.
It makes the connection and the password box is shown. If we had not specified a password in the VNC server setup for osx then any vnc client could connect to and administer the osx server! We enter the password and the mac osx server desktop is displayed. Everything works but of course the screen refreshes are a bit slow as is usual with vnc. The idea behind this is to create a portable server that can be taken to class and used to demonstrate various technologies. The reasons behind this approach are:
- corporate IT is against users running servers from their offices
- if they install a server it is so locked down that students do not learn necessary skills
- most IT depts are windows-centric in a world where windows is rapidly becoming irrelvant
Why mac?
So why is the server running mac osx? Well, their are a number of reasons that make this the best choice for a portable server. Here are the criteria i developed:
- portability: the server must be portable which means light and small
- open source: the server must run common standard open source technologies such as perl, php, apache, ruby, mail, mysql etc.
- GUI: the server must have a gui interface for easy of use in a classroom. Doing lots of typing is a sure way to lose the interest of the students in a class....
So what are the options? The first choice would be a laptop and there are some nice laptops (i own 4) but all have compromises or limitations. My best laptop runs Ubuntu 9 and can be a portable server, in fact it runs a number of useful things as virtualbox vm's (windows, ubuntu server 9 with joomla, mac) but it is too heavy for lugging about. The 11" laptop is not quite light and portable but the battery last for less than 2 hours which makes it rather non-portable for class use. I am toying with the idea of making it into a full ubuntu server. The problem with ubuntu server is that there is no gui. I tried a long time ago (ver 6, 7?) to install the server and then install the desktop but it was a failure. May try again.
One neat possibility is the netbook which is a 2 gig DT atom 1.66 with 64 gig ssd with a battery life of 3.5 hours. This is running the dell netbook version of ubuntu (8). I'm thinking of moving this to the ubuntu netbook version of 9 to fix some issues (samba) that are needed. Right now it has Xampp running but it is a pain to maintain/administer due to it being installed in /opt instead of the user's home directory. This means you have to sudo everything when you want to do stuff - an unecessary annoyance, IMHO. It would be easier if it ran under the user account.
We could use the mac laptop but the consumer laptops cannot run osx server and also use desktop apps like iLife. The solution would be to put osx server on a portable drive and choose to boot from that. I may look at the macbook pro this fall.
Anyway the mac mini is small, runs standard os software with a nice gui on top and does all we want. What's not to like?
time for some lunch
Last week while cleaning out the storage device i ran across an old vnc program. I had used this in class some years ago to connect to the Linux server i was running in my office. It got me thinking about adding VNC capabilities to the USB stick.
There is no listed VNC downloadable application at http://portableapps.com/apps but you can add non-installable programs to the environment. For example, I setup winamp for an internet radio on a usb stick demo some terms ago.
So off we go to http://www.tightvnc.com/ to grab the latest version of the viewer which is tightvnc-1.3.10_x86_viewer.zip from which we extract vncviewer.exe
Next we create a file folder called vnc in the /PortableApps folder on the USB stick and copy vncviewer.exe to that folder. From the Portable Apps menu we select Options, Refresh App Icons and the menu item TightVNC Win32 Viewer is added. You can do this for most applications that do not install but you have to create a folder for them else portable apps will not create a menu item.
VNC Server
The next step is to set up the VNC server. Since our portable server is a mac mini running osx server it already has a VNC server, we just have to turn it on. So over to the mac and select System Preferences, Sharing. We place a checkmark in the Screen Sharing box and set a password for the VNC viewer. This is for version 10.5, which has made some changes from the setup used in 10.4 but instructions for 10.4 can be found at http://www.dssw.co.uk/blog/2007/05/14/a-vnc-server-is-included-in-mac-os-x-104/.
Connecting
Backto the USB stick we run VNC viewer and enter the IP address of the osx server.
It makes the connection and the password box is shown. If we had not specified a password in the VNC server setup for osx then any vnc client could connect to and administer the osx server! We enter the password and the mac osx server desktop is displayed. Everything works but of course the screen refreshes are a bit slow as is usual with vnc. The idea behind this is to create a portable server that can be taken to class and used to demonstrate various technologies. The reasons behind this approach are:
- corporate IT is against users running servers from their offices
- if they install a server it is so locked down that students do not learn necessary skills
- most IT depts are windows-centric in a world where windows is rapidly becoming irrelvant
Why mac?
So why is the server running mac osx? Well, their are a number of reasons that make this the best choice for a portable server. Here are the criteria i developed:
- portability: the server must be portable which means light and small
- open source: the server must run common standard open source technologies such as perl, php, apache, ruby, mail, mysql etc.
- GUI: the server must have a gui interface for easy of use in a classroom. Doing lots of typing is a sure way to lose the interest of the students in a class....
So what are the options? The first choice would be a laptop and there are some nice laptops (i own 4) but all have compromises or limitations. My best laptop runs Ubuntu 9 and can be a portable server, in fact it runs a number of useful things as virtualbox vm's (windows, ubuntu server 9 with joomla, mac) but it is too heavy for lugging about. The 11" laptop is not quite light and portable but the battery last for less than 2 hours which makes it rather non-portable for class use. I am toying with the idea of making it into a full ubuntu server. The problem with ubuntu server is that there is no gui. I tried a long time ago (ver 6, 7?) to install the server and then install the desktop but it was a failure. May try again.
One neat possibility is the netbook which is a 2 gig DT atom 1.66 with 64 gig ssd with a battery life of 3.5 hours. This is running the dell netbook version of ubuntu (8). I'm thinking of moving this to the ubuntu netbook version of 9 to fix some issues (samba) that are needed. Right now it has Xampp running but it is a pain to maintain/administer due to it being installed in /opt instead of the user's home directory. This means you have to sudo everything when you want to do stuff - an unecessary annoyance, IMHO. It would be easier if it ran under the user account.
We could use the mac laptop but the consumer laptops cannot run osx server and also use desktop apps like iLife. The solution would be to put osx server on a portable drive and choose to boot from that. I may look at the macbook pro this fall.
Anyway the mac mini is small, runs standard os software with a nice gui on top and does all we want. What's not to like?
time for some lunch
Friday, July 24, 2009
USB Drive Speeds
Since we have been using USB sticks for lamp applications over the past few terms it has become clear that not all USB sticks are the same. They may all be 2.0 but the speeds are obviously different. I have been recommending students purchase sticks that are advertised as Windows Vista 'readyboost' capable on the assumption they have to meet a certification program for speed.
With Vista going the way of windows me we need another way of finding good usb sticks so we need to test the speed to answer the question of how different are they?
So off we go to http://mikelab.kiev.ua/index_en.php?page=PROGRAMS/programs_en and download check flash, a utility that performs read/write tests on a USB stick. This program has the advantage of not needing to be installed so you can keep it on your stick to test another stick anywhere. It runs in dos-mode (which may be a disadvantage to some)
So we download it and open a terminal in windows and type chkflsh and then select a currently mounted USB stick. There is a bit of a bug, you must select one of the NT based system choices and then select the Temporary File choice in the radio button menu before you can click START.
If you just leave it on Temporary File then START is greyed out. Of course you nornmally want the temporary file option as the other 2 options wipe the stick clean - destroying existing data.
USB Stick Speed Tests
Our first step is on a cheapo 1 gig GTX stick formatted as FAT32. READ speed is constant at 16.2 mb/s but the write speed is awful hitting a max of 5 mb/sec and frequently dropping down to 4 mb/sec.
Next up is a 1 gig Kingston DataTraveller formatted as FAT. The READ speed is 13.9 mb/s with a truly awful write speed of 1.2 mb/s probably due to the use of the slower FAT file system.
And the same model Kingston Data Traveller 1 gig formatted as FAT32. The READ speed is 13 mb/s with a write speed of 2.7 mb/s. The read speed is the same but the writes are twice as fast.
Next a Kingston Data Traveller 2 gig formatted as FAT. The READ speed is 13 mb/s with a write speed of 5 mb/s. This is much faster writing than the 1 gig model. I should backup and convert to FAT32.
Next a Kingston Data Traveller 2 gig formatted as FAT32. This is a more recent version that my white data traveller model. The READ speed is 16 mb/s with a write speed of 10 mb/s.
And a Patriot 2 Gig formatted as FAT32. The READ speed is an amazing 24 mb/s with a write speed of 3.2 mb/s. This is my daily XAMPP stick, might be time to change...
Finally, we have a Kingston Data Traveller 8 gig formatted as FAT32. The READ speed is 17 mb/s with a write speed of 7 mb/s.
This was my daily XAMPP stick until my foot sent it flying and broke the plastic case. Can't believe the ITS people bought computers in 2009 with the usb ports on the botttom of the case. Now the stick is held together with duct tape and it still works but it's retired from regular service.
We would like to compare with our portable 80gig SATA hard disk formatted as FAT32 and running off the usb port but chkflash 1.09 cannot handle this. So we downloaded HD_speed, another dos-based non-installable utility. The USB portable hd READ avg was 24.4 mb/s but we could not test the WRITE data rate without destroying the existing data.
We assume it is faster but it can't fit on a keychain, more of a shirt pocket item as it is about the size of an ipod touch, although a bit heavier. You will note the preponderance of Kingston USB Sticks. I've used them for years and found them quite reliable. Never had one die on me unlike sandisk and others.
Conclusions
Latest test is on a maxell - one of the new thin sticks that looks like a piece of plastic with some gold 'finger' connectors. These sticks should be immune to the bending and eventually breaking that happens with the square USB connector on many sticks. We ran Check Flash 1.09 on it using the 'temporary file' setting and got a result of 15.5 mb/s for reads and 4.8 mb/s for writes so it is slower than my faster sticks.
With Vista going the way of windows me we need another way of finding good usb sticks so we need to test the speed to answer the question of how different are they?
So off we go to http://mikelab.kiev.ua/index_en.php?page=PROGRAMS/programs_en and download check flash, a utility that performs read/write tests on a USB stick. This program has the advantage of not needing to be installed so you can keep it on your stick to test another stick anywhere. It runs in dos-mode (which may be a disadvantage to some)
So we download it and open a terminal in windows and type chkflsh and then select a currently mounted USB stick. There is a bit of a bug, you must select one of the NT based system choices and then select the Temporary File choice in the radio button menu before you can click START.
If you just leave it on Temporary File then START is greyed out. Of course you nornmally want the temporary file option as the other 2 options wipe the stick clean - destroying existing data.
USB Stick Speed Tests
Our first step is on a cheapo 1 gig GTX stick formatted as FAT32. READ speed is constant at 16.2 mb/s but the write speed is awful hitting a max of 5 mb/sec and frequently dropping down to 4 mb/sec.
Next up is a 1 gig Kingston DataTraveller formatted as FAT. The READ speed is 13.9 mb/s with a truly awful write speed of 1.2 mb/s probably due to the use of the slower FAT file system.
And the same model Kingston Data Traveller 1 gig formatted as FAT32. The READ speed is 13 mb/s with a write speed of 2.7 mb/s. The read speed is the same but the writes are twice as fast.
Next a Kingston Data Traveller 2 gig formatted as FAT. The READ speed is 13 mb/s with a write speed of 5 mb/s. This is much faster writing than the 1 gig model. I should backup and convert to FAT32.
Next a Kingston Data Traveller 2 gig formatted as FAT32. This is a more recent version that my white data traveller model. The READ speed is 16 mb/s with a write speed of 10 mb/s.
And a Patriot 2 Gig formatted as FAT32. The READ speed is an amazing 24 mb/s with a write speed of 3.2 mb/s. This is my daily XAMPP stick, might be time to change...
Finally, we have a Kingston Data Traveller 8 gig formatted as FAT32. The READ speed is 17 mb/s with a write speed of 7 mb/s.
This was my daily XAMPP stick until my foot sent it flying and broke the plastic case. Can't believe the ITS people bought computers in 2009 with the usb ports on the botttom of the case. Now the stick is held together with duct tape and it still works but it's retired from regular service.
We would like to compare with our portable 80gig SATA hard disk formatted as FAT32 and running off the usb port but chkflash 1.09 cannot handle this. So we downloaded HD_speed, another dos-based non-installable utility. The USB portable hd READ avg was 24.4 mb/s but we could not test the WRITE data rate without destroying the existing data.
We assume it is faster but it can't fit on a keychain, more of a shirt pocket item as it is about the size of an ipod touch, although a bit heavier. You will note the preponderance of Kingston USB Sticks. I've used them for years and found them quite reliable. Never had one die on me unlike sandisk and others.
Conclusions
- Check the file format on your stick, if FAT back up the data and reformat as FAT32
- Buy a new stick, it is probably faster than your old workhorse
- Higher capacity sticks are probably faster than lower capacity ones
Latest test is on a maxell - one of the new thin sticks that looks like a piece of plastic with some gold 'finger' connectors. These sticks should be immune to the bending and eventually breaking that happens with the square USB connector on many sticks. We ran Check Flash 1.09 on it using the 'temporary file' setting and got a result of 15.5 mb/s for reads and 4.8 mb/s for writes so it is slower than my faster sticks.
Wednesday, July 22, 2009
OpenBiblio ILS
Now that openbiblio is installed time to do some admin.
Access the site by launching a web browser and going to http://localhost/openbiblio/index.php, Enter "admin" for both the userid and password whenever you are prompted to signon.
You can change the admin password from the "Admin" tab -> staff list, where you can also add more library staff members. So we add Anita Bonghit and Max Power.
This is where you can set things up. Where is the opac the public sees?Ok
Goto http://localhost/openbiblio/opac/ and the opac appears. It is pretty bare bones:
We do a quick search for 'a' and the record display is shown. Again pretty basic.
11 results found sorted by title(sort by author).
Result Pages: 1 2 next»
Result Pages: 1 2 next»
Time to look at some enhancement such as LoC lokup patch, a series of scripts that use Z39.50 to grab and load MARC records. These addons are listed in the page at http://obiblio.sourceforge.net/index.php/Main/AddOns
We try the Amazon lookup first and download amazon.zip. The amazon folder inside contains 3 php scripts and install instructions. Ok this requires something from Amazon which we don't have right now so later....
Note: You must have an Amazon access key to use this module.
You may obtain an access key from Amazon by registering for web services at: https://aws-portal.amazon.com/gp/aws/developer/registration/index.html.
To find your access key, go to the web services section on Amazon. Search for 'Amazon Web Services' on the Amazon main page to find the link to it, and click it. Near the top right of the main content (below the header, mouse over 'Your Web Services Account' and click 'View Access Key Identifiers'.
Copy and paste your access key into amazon.conf.php
On the the next addon, the library of congress SRU module. We download locsru.zip and inside are a bunch of php scripts and some install instructions. First we edit navbars/cataloguing.php and add:
/**
* Added for Library of Congress SRU module
*/
if($nav == 'locsru')
{
echo '» ' . $navLoc->getText('LOCsearch') . "
\n";
}
else
{
echo '' . $navLoc->getText('LOCsearch') . "
\n";
}
?>
Then we edit locale/en/navbars.php and add a bunch of text and then finally:
Copy the following files to /catalog
locsru.php
locsru.php.ini
locsru_form.php
locsru_multiple.php
locsru_process.php
locsru_search.php
This extension should allow users to retrieve information from the Library of Congree using SRU, which returns an XML form. This module does not require YAZ functionality and should work on all platforms. The menu entry is added and this is what you get:
The instructions lable is not linked so it is hard to know what to do until you know what to do. So more research is needed. I decide to test out the MARC record import.
The Upload MARC Record function on the menu yields this:
The TEST load true is useful as it will load the data and show you the MARC records. Best to test the import before putting them into the catalog. Once working set the radio button to FALSE and change Show in OPAC to YES.
Of course you need to find a .MARC file containing library records in USMARC format. I got 500 test records from http://www.humanitiesebook.org/librarians.html which has three .zip files of 2000,500 and a sample for download. It also links to a useful tool called MarcEdit.
A free MARC editing tool known as “MarcEdit” can be downloaded from: http://oregonstate.edu/~reeset/marcedit/html/downloads.html.
I was thinking that for the pride special collection on campus something like openbiblio might be the answer, particularly if they catalog the items into MarcEdit and then use the marceditor function to produce MARC records that could be uploaded into openbiblio or another library system.
I uploaded acls6b.marc into openbiblio and the 500 records were imported into the OPAC in seconds.
joomla integration
The joomla extension is not is usual .zip format it is a gzippped tarball and it is old, from 2006. When we try and itstall it notes this needs the legacy plugin. So the first thing to do is go to the Plugin Manager and enable the System-Legacy plugin.
Next off to the Extensions manager and select the downloaded file and click Upload and Install. We get the following error, based on the previous attempt:
JInstaller::install: There is already a folder called 'E:\xampp\htdocs\joomla\administrator\components\com_obiblioopac4j\tmpl\showobibconfig.html'.
- openbiblio addins
Except we don't see the directory.
---- Update Sept 2009 ------
Installed the Amazon look up but any search returns no results - not sure why yet.
However, the library of congress lookup is great and works really fast - look up any book and then copy the MARC record into the catalog - you can edit the basic record or the marc record.
Excellent! This could serve as a personal library - just enter the ISBN of your books and you got the record - enter your friends as borrowers etc...
If you click on circulation and click SEARCH without entering a name or library card number it displays all the records. There are 3 patrons:
3 results found.
Clicking New Member allows you to add a patron. All of the input forms except the classification are text boxes. What is the format of the Card number? Let's try the help screen. 'this section still under construction'.
Go to the Collections page (Admin tab) and set Daily Late Fee for all collections to zero. BTW there are 494 adult non-fiction books in my collection.
ToDo:
- remove all the existing records
- start cataloguing my books using the ISBN and LOC
- figure out how the call numbers work - really it should let mysql autonumber
I don't think any of the books from the MARC records i loaded have call numbers! So when a record is loaded it needs to be assigned a call number.
How to Add a Bar Code
Search for and display a record
Click Add New Copy
Place a tick in the AutoGenerate checkbox
Click Submit
A bar code such as 004831 is issued for the record and it's status is changed to Checked In. A call number is not added although you can edit the record to add one.
You could also add books (called bibliography?) by doing your own original cataloging.
The reports tab can retrieve a list of all books with call numbers (just enter 00) - you can export reports as HTML or CSV.
Actually, i'm starting to like openbiblio - for a program not yet in version 1.0 that has not been actively developed for years it has some nice features. Since the code is php and the database is mysql and the presentation is css it could be modified by a knowledgeable person. Shame that some library or organization doesn't sponsor some development of the program. As a learning or lite system for person or small libraries. This would be a perfect program to get the pride library collection on campus up on the Internet.
Bugs
Add new member classificaiton is mis-spelled in the Admin tab
The system supports barcodes - we should get one of those wasp bar code scanners - there is also a program that uses a webcam to scan barcodes - wonder if that would work...
Access the site by launching a web browser and going to http://localhost/openbiblio/index.php, Enter "admin" for both the userid and password whenever you are prompted to signon.
You can change the admin password from the "Admin" tab -> staff list, where you can also add more library staff members. So we add Anita Bonghit and Max Power.
This is where you can set things up. Where is the opac the public sees?Ok
Goto http://localhost/openbiblio/opac/ and the opac appears. It is pretty bare bones:
Online Public Access Catalog (OPAC)
Welcome to our library's online public access catalog. Search our catalog to view bibliography information on holdings we have in our library.We do a quick search for 'a' and the record display is shown. Again pretty basic.
11 results found sorted by title(sort by author).
Result Pages: 1 2 next»
Search Results: | ||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
1. |
| |||||||||||||||||||||
Copy Barcode: 104 | Status: checked in | |||||||||||||||||||||
2. |
| |||||||||||||||||||||
Copy Barcode: 103 | Status: checked in | |||||||||||||||||||||
3. |
| |||||||||||||||||||||
Copy Barcode: 102 | Status: checked in | |||||||||||||||||||||
4. |
| |||||||||||||||||||||
Copy Barcode: 201 | Status: checked in | |||||||||||||||||||||
5. | Copy Barcode: 202 | Status: checked in | ||||||||||||||||||||
6. | Copy Barcode: 203 | Status: checked in | ||||||||||||||||||||
7. |
| |||||||||||||||||||||
Copy Barcode: 210 | Status: checked in | |||||||||||||||||||||
8. | Copy Barcode: 211 | Status: checked in | ||||||||||||||||||||
9. | Copy Barcode: 212 | Status: checked in | ||||||||||||||||||||
10. | Copy Barcode: 213 | Status: checked in |
Result Pages: 1 2 next»
Time to look at some enhancement such as LoC lokup patch, a series of scripts that use Z39.50 to grab and load MARC records. These addons are listed in the page at http://obiblio.sourceforge.net/index.php/Main/AddOns
We try the Amazon lookup first and download amazon.zip. The amazon folder inside contains 3 php scripts and install instructions. Ok this requires something from Amazon which we don't have right now so later....
Note: You must have an Amazon access key to use this module.
You may obtain an access key from Amazon by registering for web services at: https://aws-portal.amazon.com/gp/aws/developer/registration/index.html.
To find your access key, go to the web services section on Amazon. Search for 'Amazon Web Services' on the Amazon main page to find the link to it, and click it. Near the top right of the main content (below the header, mouse over 'Your Web Services Account' and click 'View Access Key Identifiers'.
Copy and paste your access key into amazon.conf.php
On the the next addon, the library of congress SRU module. We download locsru.zip and inside are a bunch of php scripts and some install instructions. First we edit navbars/cataloguing.php and add:
/**
* Added for Library of Congress SRU module
*/
if($nav == 'locsru')
{
echo '» ' . $navLoc->getText('LOCsearch') . "
\n";
}
else
{
echo '' . $navLoc->getText('LOCsearch') . "
\n";
}
?>
Then we edit locale/en/navbars.php and add a bunch of text and then finally:
Copy the following files to /catalog
locsru.php
locsru.php.ini
locsru_form.php
locsru_multiple.php
locsru_process.php
locsru_search.php
This extension should allow users to retrieve information from the Library of Congree using SRU, which returns an XML form. This module does not require YAZ functionality and should work on all platforms. The menu entry is added and this is what you get:
The instructions lable is not linked so it is hard to know what to do until you know what to do. So more research is needed. I decide to test out the MARC record import.
The Upload MARC Record function on the menu yields this:
The TEST load true is useful as it will load the data and show you the MARC records. Best to test the import before putting them into the catalog. Once working set the radio button to FALSE and change Show in OPAC to YES.
Of course you need to find a .MARC file containing library records in USMARC format. I got 500 test records from http://www.humanitiesebook.org/librarians.html which has three .zip files of 2000,500 and a sample for download. It also links to a useful tool called MarcEdit.
A free MARC editing tool known as “MarcEdit” can be downloaded from: http://oregonstate.edu/~reeset/marcedit/html/downloads.html.
I was thinking that for the pride special collection on campus something like openbiblio might be the answer, particularly if they catalog the items into MarcEdit and then use the marceditor function to produce MARC records that could be uploaded into openbiblio or another library system.
I uploaded acls6b.marc into openbiblio and the 500 records were imported into the OPAC in seconds.
joomla integration
The joomla extension is not is usual .zip format it is a gzippped tarball and it is old, from 2006. When we try and itstall it notes this needs the legacy plugin. So the first thing to do is go to the Plugin Manager and enable the System-Legacy plugin.
Next off to the Extensions manager and select the downloaded file and click Upload and Install. We get the following error, based on the previous attempt:
JInstaller::install: There is already a folder called 'E:\xampp\htdocs\joomla\administrator\components\com_obiblioopac4j\tmpl\showobibconfig.html'.
- openbiblio addins
Except we don't see the directory.
---- Update Sept 2009 ------
Installed the Amazon look up but any search returns no results - not sure why yet.
However, the library of congress lookup is great and works really fast - look up any book and then copy the MARC record into the catalog - you can edit the basic record or the marc record.
Excellent! This could serve as a personal library - just enter the ISBN of your books and you got the record - enter your friends as borrowers etc...
If you click on circulation and click SEARCH without entering a name or library card number it displays all the records. There are 3 patrons:
3 results found.
Search Results: | |
---|---|
1. | Baggins, Bilbo Hole 1, 1st Street The Shire, IA 12345 Card Number: 102 Classification: adult |
2. | Baggins, Frodo Hole 2, 1st Street The Shire, IA 12345 Card Number: 103 Classification: adult |
3. | Cat, Huckle 101 1st Street BusyTown,IA 12345 Card Number: 101 Classification: juvenile |
Clicking New Member allows you to add a patron. All of the input forms except the classification are text boxes. What is the format of the Card number? Let's try the help screen. 'this section still under construction'.
Go to the Collections page (Admin tab) and set Daily Late Fee for all collections to zero. BTW there are 494 adult non-fiction books in my collection.
ToDo:
- remove all the existing records
- start cataloguing my books using the ISBN and LOC
- figure out how the call numbers work - really it should let mysql autonumber
I don't think any of the books from the MARC records i loaded have call numbers! So when a record is loaded it needs to be assigned a call number.
How to Add a Bar Code
Search for and display a record
Click Add New Copy
Place a tick in the AutoGenerate checkbox
Click Submit
A bar code such as 004831 is issued for the record and it's status is changed to Checked In. A call number is not added although you can edit the record to add one.
You could also add books (called bibliography?) by doing your own original cataloging.
The reports tab can retrieve a list of all books with call numbers (just enter 00) - you can export reports as HTML or CSV.
Actually, i'm starting to like openbiblio - for a program not yet in version 1.0 that has not been actively developed for years it has some nice features. Since the code is php and the database is mysql and the presentation is css it could be modified by a knowledgeable person. Shame that some library or organization doesn't sponsor some development of the program. As a learning or lite system for person or small libraries. This would be a perfect program to get the pride library collection on campus up on the Internet.
Bugs
Add new member classificaiton is mis-spelled in the Admin tab
The system supports barcodes - we should get one of those wasp bar code scanners - there is also a program that uses a webcam to scan barcodes - wonder if that would work...
Tuesday, July 21, 2009
Integrated Library Systems and LAMP
Time to take a look at some small ILS for the LAMP platform. We start with phyMylibrary which is a located at http://sourceforge.net/projects/phpmylibrary/ and is designed for small or personal collections. According to the project page:
The program consist of cataloging, circulation, and the webpac module. The programs also has an import export feature. The program strictly follow the USMARC standard for adding materials.
The latest version is 2.2.1-3 which we download on a windows machine to start. The idea will be to later move it to the portable apps and to the linux environment.
We xtract the phpMylibrary folder and view the README file which has lots of change notes. There is also an installation folder which has an index.php but not instructions, maybe you just copy it to your web root and run the php program. But it will need a mysql database and mysql user, no? Anyway we proceed. This is a windows box running wampserver so we copy the phpMylibrary to c:\wamp\www and open a browser to http:\\localhost\phpmylibrary\installation
The only minor issue is that magic quotes is set to off in the php.ini file but we proceed anyway. Ah, the mysql database configuration page wants the hostname, the mysql user/password and the database name. One assumes these have to be set up BEFORE running this install script but with no documentation in a README or any information on this page you have to guess what to do. The page also has a NEXT but no BACK buttons so it may not be possible to return to this page if you proceed.
Todo Tomorrow
Create the phpmylibrary database along a phpmylibrary user and re-do the install
ok we are now on the dell min 9 with ubuntu and i copied the openbiblio folder to the sd card rather than the ssd drive. The htdocs folder is in /opt/lampp so we need to tell apache to use /media/kingston/openbiblio as a virtual directory. The idea is to create a library system on a removable disk and to be able to swap in pre-setup applications on sd cards. This makes the netbook a very portable demo machine.
The first thing to do is to tell apache we want to use virtual directories. With linux xampp the httpd.conf file is in /opt/lampp/etc which is different from the mac and win versions and since it is not owned by gnickers we cannot edit from the gui.
Open terminal and cd to /opt/lampp/etc and then do sudo pico httpd.conf but drats no pico installed. Turns out pico is not included in the distro so we run the package manager and find nano, a gpl pico clone.
sudo nano httpd.conf
works. The line we want to uncomment is:
tomorrow
We are now on a windows USB stick running portableapps. The openbiblio docs say that php.ini must enable sessions. The version of portable apps/xampp we are running uses /apache/bin to store php.ini but this is changed to the php directory in the more recent versions.
So we edit php.ini and set up a few things:
- turn magic quotes on
- turn display errors off
- file uploads are on and set to upload_tmp_dir = "\xampp\tmp" (make sure tmp exists!)
- session.save_path = "\xampp\tmp"
This was setup before when we were testing out php programming and although session files were saved:
PMA_token |s:32:"bae7b084a2d2f1fdceb62dbd04a96119";PMA_Config|O:10:"PMA_Config":10:{s:14:"default_source";s:30:"./libraries/config.default.php";s:8:"settings";a:170:
{s:14:"PmaAbsoluteUri";s:28:"http://localhost/phpmyadmin/";s:28:"PmaNoRelation_DisableWarning";b:0;s:21:"SuhosinDisableWarning"
we had problems implementing session variables in php. This may have been due to our lack of understanding of php and sessions, so we press on and SAVE the changes.
Set up the Database
Next comes the mysql part. Since we are on a windows machine the fast way is to open a terminal window to our home folder and run the mysql command line client.
Microsoft Windows XP [Version 5.1.2600]
U:\>dir *.exe
Volume in drive U is K-Faculty
Directory of U:\
07/06/2007 02:24 PM 2,039,808 mysql.exe
07/06/2007 02:24 PM 2,035,712 mysqldump.exe
07/06/2007 02:24 PM 1,982,464 mysqlimport.exe
08/01/2003 06:27 PM 274,432 vnc.exe
4 File(s) 6,332,416 bytes
0 Dir(s) 14,276,997,120 bytes free
U:\>
Now all we do is type mysql -hlocalhost -uroot and we are logged into the mysql server running on the usb stick. (note the default xampp is no password for root, which is a security risk)
We first create a log file of our session:
mysql> \T openbiblio.txt
Logging to file 'openbiblio.txt'
mysql>
Next we create the empty database and test to see if the command was successful:
mysql> create database OpenBiblio;
Query OK, 1 row affected (0.28 sec)
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| blogs |
| books |
| catalog |
| cdcol |
| course_data |
| course_date |
| digital_library |
| joomla |
| mysql |
| openbiblio |
| perl |
| philosophy |
| phpmyadmin |
| test |
| webauth |
+--------------------+
16 rows in set (0.56 sec)
Next, you have to set up the openbiblio user for the php install program to use:
mysql> grant all privileges on OpenBiblio.* to
obiblio_user@localhost identified by 'obiblio_password';
Query OK, 0 rows affected (0.00 sec)
Obviously, we should have changed the example in the documentation to something but this is just a demo. We stop the session logging with \t and exit mysql.
We have already copied the openbiblio folder to the htdocs folder on the usb stick so the next step is to edit the database_constants.php file in the openbiblio directory to set the username and password to whatever you set up in mysql.
define("OBIB_HOST", "localhost");
define("OBIB_DATABASE", "OpenBiblio");
define("OBIB_USERNAME", "openbiblio_user");
define("OBIB_PWD", "openbiblio_password");
Now to run the install program. Open a web browser and goto http://localhost/openbiblio/install/index.php which opens up the mysql database and starts the install. We get an error:
The connection to the database failed with the following error.
This could be caused by a couple of things. First we make sure the mysql tables have been updated by logging back into the database server and flushing the priviledges to refresh the table.
U:\>mysql -hlocalhost -uroot
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 7
Server version: 5.1.30-community MySQL Community Server (GPL)
Type 'help;' or '\h' for help. Type '\c' to clear the buffer.
mysql> flush privileges;
Query OK, 0 rows affected (0.05 sec)
Let's try the install program again to see if that was the cause. No joy. The second possibility is we set up the privileges incorrectly. Let's try making it from any host.
mysql> grant all privileges on OpenBiblio.* to obiblio@"%" identified by 'obiblio';
Query OK, 0 rows affected (0.00 sec)
Then we change the database_constants.php file to match and try to install again. No Joy. Let's confirm the user name/password is working on mysql.
U:\>mysql -hlocalhost -uobiblio -p
Enter password: *******
ERROR 1045 (28000): Access denied for user 'obiblio'@'localhost' (using password: YES)
Ah - the problem is we can't connect. We can fix the host connect problem later but for a quick hack let's just try root which can connect to localhost. We edit the database_constants.php file to change user to root with no password and refesh the install.php page. It works, so the problem for the obiblio user is it denied access to localhost.
We select English as the language and place a tick mark in the Install Sample Data. In a flash it is done and we get:
Database connection is good.
Building OpenBiblio tables, please wait...
OpenBiblio tables have been created successfully!
start using OpenBiblio
We click on the link and viola, we now have an integrated library system in our pocket!
ToDo List
- customize for a library like the Springfield Public Library
- import more MARC records to make it realistic
- integrate with Joomla!
The program consist of cataloging, circulation, and the webpac module. The programs also has an import export feature. The program strictly follow the USMARC standard for adding materials.
The latest version is 2.2.1-3 which we download on a windows machine to start. The idea will be to later move it to the portable apps and to the linux environment.
We xtract the phpMylibrary folder and view the README file which has lots of change notes. There is also an installation folder which has an index.php but not instructions, maybe you just copy it to your web root and run the php program. But it will need a mysql database and mysql user, no? Anyway we proceed. This is a windows box running wampserver so we copy the phpMylibrary to c:\wamp\www and open a browser to http:\\localhost\phpmylibrary\installation
The only minor issue is that magic quotes is set to off in the php.ini file but we proceed anyway. Ah, the mysql database configuration page wants the hostname, the mysql user/password and the database name. One assumes these have to be set up BEFORE running this install script but with no documentation in a README or any information on this page you have to guess what to do. The page also has a NEXT but no BACK buttons so it may not be possible to return to this page if you proceed.
Todo Tomorrow
Create the phpmylibrary database along a phpmylibrary user and re-do the install
ok we are now on the dell min 9 with ubuntu and i copied the openbiblio folder to the sd card rather than the ssd drive. The htdocs folder is in /opt/lampp so we need to tell apache to use /media/kingston/openbiblio as a virtual directory. The idea is to create a library system on a removable disk and to be able to swap in pre-setup applications on sd cards. This makes the netbook a very portable demo machine.
The first thing to do is to tell apache we want to use virtual directories. With linux xampp the httpd.conf file is in /opt/lampp/etc which is different from the mac and win versions and since it is not owned by gnickers we cannot edit from the gui.
Open terminal and cd to /opt/lampp/etc and then do sudo pico httpd.conf but drats no pico installed. Turns out pico is not included in the distro so we run the package manager and find nano, a gpl pico clone.
sudo nano httpd.conf
works. The line we want to uncomment is:
#Include conf/extra/httpd-vhosts.conf
which is way down the file. Everything else is entered in the file httpd-vhosts.conf
, which will be located in the extra
folder.tomorrow
We are now on a windows USB stick running portableapps. The openbiblio docs say that php.ini must enable sessions. The version of portable apps/xampp we are running uses /apache/bin to store php.ini but this is changed to the php directory in the more recent versions.
So we edit php.ini and set up a few things:
- turn magic quotes on
- turn display errors off
- file uploads are on and set to upload_tmp_dir = "\xampp\tmp" (make sure tmp exists!)
- session.save_path = "\xampp\tmp"
This was setup before when we were testing out php programming and although session files were saved:
PMA_token |s:32:"bae7b084a2d2f1fdceb62dbd04a96119";PMA_Config|O:10:"PMA_Config":10:{s:14:"default_source";s:30:"./libraries/config.default.php";s:8:"settings";a:170:
{s:14:"PmaAbsoluteUri";s:28:"http://localhost/phpmyadmin/";s:28:"PmaNoRelation_DisableWarning";b:0;s:21:"SuhosinDisableWarning"
we had problems implementing session variables in php. This may have been due to our lack of understanding of php and sessions, so we press on and SAVE the changes.
Set up the Database
Next comes the mysql part. Since we are on a windows machine the fast way is to open a terminal window to our home folder and run the mysql command line client.
Microsoft Windows XP [Version 5.1.2600]
U:\>dir *.exe
Volume in drive U is K-Faculty
Directory of U:\
07/06/2007 02:24 PM 2,039,808 mysql.exe
07/06/2007 02:24 PM 2,035,712 mysqldump.exe
07/06/2007 02:24 PM 1,982,464 mysqlimport.exe
08/01/2003 06:27 PM 274,432 vnc.exe
4 File(s) 6,332,416 bytes
0 Dir(s) 14,276,997,120 bytes free
U:\>
Now all we do is type mysql -hlocalhost -uroot and we are logged into the mysql server running on the usb stick. (note the default xampp is no password for root, which is a security risk)
We first create a log file of our session:
mysql> \T openbiblio.txt
Logging to file 'openbiblio.txt'
mysql>
Next we create the empty database and test to see if the command was successful:
mysql> create database OpenBiblio;
Query OK, 1 row affected (0.28 sec)
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| blogs |
| books |
| catalog |
| cdcol |
| course_data |
| course_date |
| digital_library |
| joomla |
| mysql |
| openbiblio |
| perl |
| philosophy |
| phpmyadmin |
| test |
| webauth |
+--------------------+
16 rows in set (0.56 sec)
Next, you have to set up the openbiblio user for the php install program to use:
mysql> grant all privileges on OpenBiblio.* to
obiblio_user@localhost identified by 'obiblio_password';
Query OK, 0 rows affected (0.00 sec)
Obviously, we should have changed the example in the documentation to something but this is just a demo. We stop the session logging with \t and exit mysql.
We have already copied the openbiblio folder to the htdocs folder on the usb stick so the next step is to edit the database_constants.php file in the openbiblio directory to set the username and password to whatever you set up in mysql.
define("OBIB_HOST", "localhost");
define("OBIB_DATABASE", "OpenBiblio");
define("OBIB_USERNAME", "openbiblio_user");
define("OBIB_PWD", "openbiblio_password");
Now to run the install program. Open a web browser and goto http://localhost/openbiblio/install/index.php which opens up the mysql database and starts the install. We get an error:
The connection to the database failed with the following error.
Cannot connect to database server.: Access denied for user 'openbiblio_user'@'localhost' (using password: YES) -- FULL SQL: Connecting to database server...Please make sure the following has been done before running this install script.
This could be caused by a couple of things. First we make sure the mysql tables have been updated by logging back into the database server and flushing the priviledges to refresh the table.
U:\>mysql -hlocalhost -uroot
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 7
Server version: 5.1.30-community MySQL Community Server (GPL)
Type 'help;' or '\h' for help. Type '\c' to clear the buffer.
mysql> flush privileges;
Query OK, 0 rows affected (0.05 sec)
Let's try the install program again to see if that was the cause. No joy. The second possibility is we set up the privileges incorrectly. Let's try making it from any host.
mysql> grant all privileges on OpenBiblio.* to obiblio@"%" identified by 'obiblio';
Query OK, 0 rows affected (0.00 sec)
Then we change the database_constants.php file to match and try to install again. No Joy. Let's confirm the user name/password is working on mysql.
U:\>mysql -hlocalhost -uobiblio -p
Enter password: *******
ERROR 1045 (28000): Access denied for user 'obiblio'@'localhost' (using password: YES)
Ah - the problem is we can't connect. We can fix the host connect problem later but for a quick hack let's just try root which can connect to localhost. We edit the database_constants.php file to change user to root with no password and refesh the install.php page. It works, so the problem for the obiblio user is it denied access to localhost.
We select English as the language and place a tick mark in the Install Sample Data. In a flash it is done and we get:
Database connection is good.
Building OpenBiblio tables, please wait...
OpenBiblio tables have been created successfully!
start using OpenBiblio
We click on the link and viola, we now have an integrated library system in our pocket!
Welcome to OpenBiblio
Use the navigation tabs at the top of each page to access the following library administration sections.Tab | Description |
---|---|
Circulation | Use this tab to manage your member records.
|
Cataloging | Use this tab to manage your bibliography records.
|
Admin | Use this tab to manage staff and administrative records.
|
Reports | Use this tab to run reports on your library data.
|
- customize for a library like the Springfield Public Library
- import more MARC records to make it realistic
- integrate with Joomla!
Tuesday, July 7, 2009
xampp on ubuntu
xampp on the dell mini 9
specs: Atom 1.6ghz ht cpu, 2 gig ddr2 ram, 64 gig runcore SSD.
Decided to see if the netbook could be used as a travelling development machine so we need to install lamp. So off to apache friends at http://www.apachefriends.org/en/xampp-linux.html to download the linux version which comes in a tarball. Not my fav method but so be it.
We save the download to our home directory.
Open a terminal window and do:
sudo tar xvfz xampp-linux-1.7.1.tar.gz -C /opt
which extracts all the files. Now to run the lamp stack
sudo /opt/lampp/lampp start
which displays
Starting XAMPP for Linux 1.7.1...
XAMPP: Starting Apache with SSL (and PHP5)...
XAMPP: Starting MySQL...
XAMPP: Starting ProFTPD...
XAMPP for Linux started.
we then run firefox and goto http://localhost and the lamp page is displayed. success
Next we do places,home and browse the filesystem to opt/lampp/htdocs and create a bookmark which adds a htdocs folder to the places list. we should also check out apache/bin/php.ini and make some changes and we should install a good php aware text editor and then install joomla
Joomla on the Dell Mini 9
Now that LAMPP is installed (thanks apache friends) it is time to install joomla. We follow the same instructions as per xampp on windows. The phpmyadmin has a few minor differences but we created the joomla database and joomla user ok. This is fairly straightforward under linux but the next part is different. You can't just create a directory in the system area and extract a bunch of files to it - you are just a regular user. Windows XP allows that and look what happens.
So we open a terminal and cd /opt/lampp/htdocs and then do sudo mkdir joomla to set up the folder for the joomla. We goto off the joomlacode.org and under the 1.5 section we click on Other Joomla Packages. Under Joomla1.5.12 we find Joomla_1.5.12-Stable-Full_Package.tar.gz which is what we want. You have to know this is a zipped tarball for linux while the .zip package is for windows. We save it to own home folder.
In the terminal we copy the download to the joomla folder with sudo cp Joomla_1.5.12-Stable-Full_Package.tar.gz /opt/lampp/htdocs/joomla which is no mean feat on the Dell mini 9 keyboard! Actually, once i had done this i realized i should just have extracted the files to there instead of copying the archive. Oh well. Change to there with cd /opt/lampp/htdocs/joomla and extract the files with sudo tar xvzf Joomla_1.5.12-Stable-Full_Package.tar.gz
Why it was stupid to copy instead of extracting is now i have to rm the joomla file - 3 times i had to type that file name...arghh
Anyway now we can run the install with the web browser pointed to http://localhost/joomla which gives the browser based setup. Answer a few questions - ok, the joomla install cannot write changes to the php configuration file. This is configuration.php in the joomla folder that contains the settings - it recommends copying the configuration settings and editing the file manually after the install is finished.
The other problem is that php.ini has Display Errors set to ON as well as Register Globals set to ON. We will have to edit php.ini to fix these after the install.
One change from windows installs is that i've set up FTP so that the joomla ftp user can ftp files to the system. Note to self - check and see if joomla has to be manually added to the list of ftp users, similar to the list of samba users. The Verify FTP button returned an error, noting the ftp server was 'not compatible'. Probably because one is not running, i'll install wu-ftp later. The root path is /joomla. We decide to press on and install the sample data and setup the admin user. Install is ok.
Ok, the final page lists the code for configuration.php so we copy and paste it into the text editor and then in the terminal we do cp configuration.php /opt/lampp/htdocs/joomla
Now that it is copied over time to fix the other problems, first to remove the installation directory. Since this is a system folder in linux you just can delete it in the file manager, so we cd /opt/htdocs/joomla and type sudo rm -rf installation/ and away it goes.
The php.ini file is not in the opt/lampp/bin folder, it's not fatal so we ignore it for now and run joomla with http://localhost/joomla and login as the admin user. We check the global configuration and the paths are /opt/lampp/htdocs/joomla/tmp etc.
Update Aug 31
I run xampp with sudo /opt/lampp/lampp start and up it comes but going to http://localhost returns 'object not found'. The xampp stack is running, we confirm this by checking the open ports with network tools:
21 - open
80 - open
443 - open
3306 - open
but we cannot get to the mysql database server either, the client returns an error message of 'can't connect through socket 'var/run/mysqld/mysqld.sock(2)'. This seems odd, one would think it would be something like 'opt/lampp/var/mysql/mysql.sock'?
I opened a web browser on another machine and connected to the webserver on the dell mini9 but no pages are returned. You get:
Object Not Found!
192.168.1.109
Sun 30 Aug 2009 02:24:56 PM EDT
Apache/2.2.11 (Unix) DAV/2 mod_ssl/2.2.11 OpenSSL/0.9.8k PHP/5.2.9 mod_apreq2-20051231/2.6.0 mod_perl/2.0.4 Perl/v5.10.0
This shows xampp is running but it is not working anymore. Why? This makes my idea of using it as a portable in-class server less likely. The USB xampp is more reliable and we can use wamp/mamp laptops as well. Found lots of theories as to why but testing them out to come up with a solution will take more time than i have to invest. Disappointing....
specs: Atom 1.6ghz ht cpu, 2 gig ddr2 ram, 64 gig runcore SSD.
Decided to see if the netbook could be used as a travelling development machine so we need to install lamp. So off to apache friends at http://www.apachefriends.org/en/xampp-linux.html to download the linux version which comes in a tarball. Not my fav method but so be it.
We save the download to our home directory.
Open a terminal window and do:
sudo tar xvfz xampp-linux-1.7.1.tar.gz -C /opt
which extracts all the files. Now to run the lamp stack
sudo /opt/lampp/lampp start
which displays
Starting XAMPP for Linux 1.7.1...
XAMPP: Starting Apache with SSL (and PHP5)...
XAMPP: Starting MySQL...
XAMPP: Starting ProFTPD...
XAMPP for Linux started.
we then run firefox and goto http://localhost and the lamp page is displayed. success
Next we do places,home and browse the filesystem to opt/lampp/htdocs and create a bookmark which adds a htdocs folder to the places list. we should also check out apache/bin/php.ini and make some changes and we should install a good php aware text editor and then install joomla
Joomla on the Dell Mini 9
Now that LAMPP is installed (thanks apache friends) it is time to install joomla. We follow the same instructions as per xampp on windows. The phpmyadmin has a few minor differences but we created the joomla database and joomla user ok. This is fairly straightforward under linux but the next part is different. You can't just create a directory in the system area and extract a bunch of files to it - you are just a regular user. Windows XP allows that and look what happens.
So we open a terminal and cd /opt/lampp/htdocs and then do sudo mkdir joomla to set up the folder for the joomla. We goto off the joomlacode.org and under the 1.5 section we click on Other Joomla Packages. Under Joomla1.5.12 we find Joomla_1.5.12-Stable-Full_Package.tar.gz which is what we want. You have to know this is a zipped tarball for linux while the .zip package is for windows. We save it to own home folder.
In the terminal we copy the download to the joomla folder with sudo cp Joomla_1.5.12-Stable-Full_Package.tar.gz /opt/lampp/htdocs/joomla which is no mean feat on the Dell mini 9 keyboard! Actually, once i had done this i realized i should just have extracted the files to there instead of copying the archive. Oh well. Change to there with cd /opt/lampp/htdocs/joomla and extract the files with sudo tar xvzf Joomla_1.5.12-Stable-Full_Package.tar.gz
Why it was stupid to copy instead of extracting is now i have to rm the joomla file - 3 times i had to type that file name...arghh
Anyway now we can run the install with the web browser pointed to http://localhost/joomla which gives the browser based setup. Answer a few questions - ok, the joomla install cannot write changes to the php configuration file. This is configuration.php in the joomla folder that contains the settings - it recommends copying the configuration settings and editing the file manually after the install is finished.
The other problem is that php.ini has Display Errors set to ON as well as Register Globals set to ON. We will have to edit php.ini to fix these after the install.
One change from windows installs is that i've set up FTP so that the joomla ftp user can ftp files to the system. Note to self - check and see if joomla has to be manually added to the list of ftp users, similar to the list of samba users. The Verify FTP button returned an error, noting the ftp server was 'not compatible'. Probably because one is not running, i'll install wu-ftp later. The root path is /joomla. We decide to press on and install the sample data and setup the admin user. Install is ok.
Ok, the final page lists the code for configuration.php so we copy and paste it into the text editor and then in the terminal we do cp configuration.php /opt/lampp/htdocs/joomla
Now that it is copied over time to fix the other problems, first to remove the installation directory. Since this is a system folder in linux you just can delete it in the file manager, so we cd /opt/htdocs/joomla and type sudo rm -rf installation/ and away it goes.
The php.ini file is not in the opt/lampp/bin folder, it's not fatal so we ignore it for now and run joomla with http://localhost/joomla and login as the admin user. We check the global configuration and the paths are /opt/lampp/htdocs/joomla/tmp etc.
Update Aug 31
I run xampp with sudo /opt/lampp/lampp start and up it comes but going to http://localhost returns 'object not found'. The xampp stack is running, we confirm this by checking the open ports with network tools:
21 - open
80 - open
443 - open
3306 - open
but we cannot get to the mysql database server either, the client returns an error message of 'can't connect through socket 'var/run/mysqld/mysqld.sock(2)'. This seems odd, one would think it would be something like 'opt/lampp/var/mysql/mysql.sock'?
I opened a web browser on another machine and connected to the webserver on the dell mini9 but no pages are returned. You get:
Object Not Found!
192.168.1.109
Sun 30 Aug 2009 02:24:56 PM EDT
Apache/2.2.11 (Unix) DAV/2 mod_ssl/2.2.11 OpenSSL/0.9.8k PHP/5.2.9 mod_apreq2-20051231/2.6.0 mod_perl/2.0.4 Perl/v5.10.0
This shows xampp is running but it is not working anymore. Why? This makes my idea of using it as a portable in-class server less likely. The USB xampp is more reliable and we can use wamp/mamp laptops as well. Found lots of theories as to why but testing them out to come up with a solution will take more time than i have to invest. Disappointing....
Wednesday, July 1, 2009
Dell Mini 9 and Ubuntu
Dell Ubuntu
We restored the dell netbook using the ubuntu 8.04 restore image. It had come with windows xp but with no ubunutu disc in the box.
This is a customized version of 8.04 for dell. The plus is that everything works, the downside is that I don't like some of the package choices and settings, however that should be easy to change.
First we restore the default ubuntu desktop to get rid of the big launcher bar. Next we remove the apps we don't want - ie periodic table etc and tuxmath and games. Next we download the updates
SHOW STOPPER - the system monitor only reports 883mb of ram in a 2 gig machine. What gives? A post by ffreitas:
To check yours just open in a text editor/viewer the file /boot/config-2.6.24-19lpia , and search for the text "CONFIG_NOHIGHMEM" (without the double quotes). You will see something like this:
That is an incredible oversight. Ok - appears that if you enable a repository you can get a fixed kernel. Done - now we see the full 2 gig. Removed the k-crud and now we have a fast system with 22 gig free. Time to get a good sd card...
We restored the dell netbook using the ubuntu 8.04 restore image. It had come with windows xp but with no ubunutu disc in the box.
This is a customized version of 8.04 for dell. The plus is that everything works, the downside is that I don't like some of the package choices and settings, however that should be easy to change.
First we restore the default ubuntu desktop to get rid of the big launcher bar. Next we remove the apps we don't want - ie periodic table etc and tuxmath and games. Next we download the updates
SHOW STOPPER - the system monitor only reports 883mb of ram in a 2 gig machine. What gives? A post by ffreitas:
CONFIG_NOHIGHMEM=y
# CONFIG_HIGHMEM4G is not set
# CONFIG_HIGHMEM64G is not set
That is an incredible oversight. Ok - appears that if you enable a repository you can get a fixed kernel. Done - now we see the full 2 gig. Removed the k-crud and now we have a fast system with 22 gig free. Time to get a good sd card...
Monday, June 22, 2009
Dell Mini 9
Search for the Netbook...continued
We sold the Asus eee as the 7" screen had just too many issues. We liked the light weight and the wireless was very good but the screen resolution was just too low.
After a little research we settled on the Dell Inspiron mini 9 with an 8.9" screen at 1024 x 600 resolution, an Atom 1.6 ghz cpu, 1 gig ram and an 8 gig ssd. The machine is also highly upgradable with all the 'works' accessible by removing two screens on the bottom cover. Excellent! Of course, this is such a good machine that Dell stopped making it and replaced it with the much less usefull 10 - a larger screen with a http://www.canadaram.com to oder a 2 gig stick which is the max for this machine.
While we are there we need to get a bigger and faster SSD than the stock 8 gig one. They have the RunCore Pro PATA Mini PCIe 32 gig SSD. We drool over the 64gig model but it is too expensive, it costs more than the mini 9 and would take this project over the $500 mark which disqualifies it as a netbook.
Ok the goods have arrived. We first install the new ram and boot while holding down the 2 key to get to the BIOS. Doesn't anyone use DEL anymore? The BIOS version is A4. We enable the boot time diagnostic screen and disable quickboot mode (will reset later). We also enable bluetooth and USB legacy support (will disable later). We change the boot order to USB 1st, CD/DVD 2nd, removable devices 3rd and then the hard drive.
Next is to prepare the boot media but we can't find the 10.4 disc, we find the 10.5 DVD but the external dvd drives are all firewire, the usb externals are cdrw. We find a dell usb dvd from the D400 but it has a proprietary connector. Idiots. We have 10.3 on cd but that doesn't look good. Stores are closed, we could try the USB stick method but there is only one 8 gig stick here and it has a portable XAMPP Joomla setup i'd like to keep.
ok we went out and bought a usb case and stuck an LG combo drive in it. These are used in apple's machines and so should be compatible with osx. The apple rom drives are packed away and not sure if there are dvd or just cd.
Now to replace the stock SSD with the 32gig runcore. Done
Installation
We download the DellMiniBoot123v8.01.iso.zip 'type11' bootloader and extract the iso image and burn to a cd. Put it in the external dvd and start up the Dell.
At startup we press 0 (zero) to bring up the list of boot devices, although it should look to the dvd anyway as we changed the boot order.
The boot menu appears and the dvd is the top of the list anyway.
We press enter which loads the bootloader into darwin/x86 and displays the boot: prompt
We remove the bootloader cd and put in our retail osx 10.5 dvd.
At the boot: prompt we type press ESC and enter 9f and press enter. The osx install runs but then crashes and on restart we get 'NTLDR is missing' error message.
We restart and press 0 and choose the dvd. Same result so we go back to booting with the bootloader to get back to the boot: prompt
We power on and off the external drive. Press esc and enter 9f with the same result - 'you need to restart your computer'. So we remove the ssd and mount it using a usb cable - it is formatted as a windows NTFS vol - we reformat it as a mac osx partition and go back to the bootloader.
This time we decide to press F8 for startup options and select the mac osx install dvd. same result - crashes when it runs.
Same problem - looks like the LG drive is not compatible. Ok we need to look for an apple rom drive...none here so i created a disk image from the retail osx dvd and now cloning it to a USB stick. The usb devices are 81 and 82 so we boot from the type11 bootdisk and select the mac os x install dvd hd(1,2)
the apple logo appears but it errors with the same message. Doesn't look like osx likes this mini 9. Let's try one more thing. We download osxdvd.zip
First we turn on viewing the hidden files and then we extract the systemconfiguration folder to the library and the system files too. We run the bootloader and try the new usb osx image.
It loads darwin and crashes at the apple. All right enough, we download the dell mini 9 ubuntu restore and burn it to dvd.
It boots up no problem and starts installing ubuntu...we thought about installing the ubuntu netbook remix but it was an img file so we would have to use usb-imagewriter and burn it to a usb stick. A slower option and not customized for the mini 9.
We sold the Asus eee as the 7" screen had just too many issues. We liked the light weight and the wireless was very good but the screen resolution was just too low.
After a little research we settled on the Dell Inspiron mini 9 with an 8.9" screen at 1024 x 600 resolution, an Atom 1.6 ghz cpu, 1 gig ram and an 8 gig ssd. The machine is also highly upgradable with all the 'works' accessible by removing two screens on the bottom cover. Excellent! Of course, this is such a good machine that Dell stopped making it and replaced it with the much less usefull 10 - a larger screen with a http://www.canadaram.com to oder a 2 gig stick which is the max for this machine.
While we are there we need to get a bigger and faster SSD than the stock 8 gig one. They have the RunCore Pro PATA Mini PCIe 32 gig SSD. We drool over the 64gig model but it is too expensive, it costs more than the mini 9 and would take this project over the $500 mark which disqualifies it as a netbook.
Ok the goods have arrived. We first install the new ram and boot while holding down the 2 key to get to the BIOS. Doesn't anyone use DEL anymore? The BIOS version is A4. We enable the boot time diagnostic screen and disable quickboot mode (will reset later). We also enable bluetooth and USB legacy support (will disable later). We change the boot order to USB 1st, CD/DVD 2nd, removable devices 3rd and then the hard drive.
Next is to prepare the boot media but we can't find the 10.4 disc, we find the 10.5 DVD but the external dvd drives are all firewire, the usb externals are cdrw. We find a dell usb dvd from the D400 but it has a proprietary connector. Idiots. We have 10.3 on cd but that doesn't look good. Stores are closed, we could try the USB stick method but there is only one 8 gig stick here and it has a portable XAMPP Joomla setup i'd like to keep.
ok we went out and bought a usb case and stuck an LG combo drive in it. These are used in apple's machines and so should be compatible with osx. The apple rom drives are packed away and not sure if there are dvd or just cd.
Now to replace the stock SSD with the 32gig runcore. Done
Installation
We download the DellMiniBoot123v8.01.iso.zip 'type11' bootloader and extract the iso image and burn to a cd. Put it in the external dvd and start up the Dell.
At startup we press 0 (zero) to bring up the list of boot devices, although it should look to the dvd anyway as we changed the boot order.
The boot menu appears and the dvd is the top of the list anyway.
We press enter which loads the bootloader into darwin/x86 and displays the boot: prompt
We remove the bootloader cd and put in our retail osx 10.5 dvd.
At the boot: prompt we type press ESC and enter 9f and press enter. The osx install runs but then crashes and on restart we get 'NTLDR is missing' error message.
We restart and press 0 and choose the dvd. Same result so we go back to booting with the bootloader to get back to the boot: prompt
We power on and off the external drive. Press esc and enter 9f with the same result - 'you need to restart your computer'. So we remove the ssd and mount it using a usb cable - it is formatted as a windows NTFS vol - we reformat it as a mac osx partition and go back to the bootloader.
This time we decide to press F8 for startup options and select the mac osx install dvd. same result - crashes when it runs.
Same problem - looks like the LG drive is not compatible. Ok we need to look for an apple rom drive...none here so i created a disk image from the retail osx dvd and now cloning it to a USB stick. The usb devices are 81 and 82 so we boot from the type11 bootdisk and select the mac os x install dvd hd(1,2)
the apple logo appears but it errors with the same message. Doesn't look like osx likes this mini 9. Let's try one more thing. We download osxdvd.zip
First we turn on viewing the hidden files and then we extract the systemconfiguration folder to the library and the system files too. We run the bootloader and try the new usb osx image.
It loads darwin and crashes at the apple. All right enough, we download the dell mini 9 ubuntu restore and burn it to dvd.
It boots up no problem and starts installing ubuntu...we thought about installing the ubuntu netbook remix but it was an img file so we would have to use usb-imagewriter and burn it to a usb stick. A slower option and not customized for the mini 9.
Subscribe to:
Posts (Atom)