User:Ckeene/ep3 upgrade
Contents
Eprints 3 upgrade
A journal of our upgrade process from eprints2 to eprints3. This will include my own stupid mistakes and errors, many will be laughable and show my true incompetence. I keep them here so others do not do the same!
Current situation
Current Version: EPrints 2.3.12 (Southern Chicken) [Born on 2005-05-24] Running on Ubuntu 6.06 LTS (based on Debian) Visual look and quite a bit of the wording has been changed, and endnote/BibTeX import functionality has been added (via the downloads from the eprints.org site).
The plan
- Apache 2 installed, with mod perl and php
- Other dependencies
- Install eprints3
- Create test archive (ep3v) - v for vanilla
- Install and run migration tool. Document results.
- Look in to problems, use mailing list for support
- Modify wording of user interface (both for depositors and end users) to follow changes made on eprints2 (where they still apply and where changes were not bought across)
- Apply Sussex Templates to eprints3
- Install additional modules to bring in line with extra functionality of our eprints2 setup, see table below
- Repeat migration process of data to test and address issues.
- Follow steps to add additional functionality, such as auto-complete features, which are not out-of-the-box, but core features of eprints3.
- Update documentation and screenshots ready for eprints3
- Demonstrate to others, solicit feedback
- Make changes based on user feedback
- Migrate data one final time, update apache so that eprints.sussex.ac.uk points to eprints3, not eprints2. This will make eprints3 live. woohoo!
Steps to bring eprint3 (out of the box) in-line with our current eprints2
- Import from Endnote
- Import from Bibtex
- LDAP authentication
- Import/update users from text file
- Fields created to hold record id (from Uni pub db) and personnel id (for Sussex authors)
Install Apache 2, mod_perl, etc
- key doc http://wiki.eprints.org/w/Installing_EPrints_3_on_Ubuntu_6.10
- sudo apt-get install apache2 libapache2-mod-perl2
- eprints2 is on port 80. vi /etc/apache2/ports.cfg, changed from 80 to 8082
- /usr/sbin/apache2ctl start
- http://localhost:8082/ http://researchonline.lib.sussex.ac.uk:8082/ http://eprints.sussex.ac.uk:8082/ all work!
- [we already have mysql installed - skip step]
- sudo apt-get install libxml-libxml-perl libunicode-string-perl \
libterm-readkey-perl libmime-lite-perl libdbd-mysql-perl
- most of these were already installed. but at least
libterm-readkey-perl libmime-lite-perl were not.
- /etc/init.d/httpd stop start - eprints2 is still working!
- sudo cpan install Readonly
Eprints 3 install
- Follow http://wiki.eprints.org/w/Installing_EPrints_3_on_Ubuntu_6.10
- We already have an 'eprints' user so I'm going to try and not create one now, the only issue might be that the instructions state the users home should be /opt/eprints3 but I'm going to leave it as /home/eprints/ and see what happens
- sudo adduser www-data eprints
- tar xzvf eprints-3.0.2-beta-3.tar.gz (yup I'm installing a beta!)
- cd eprints-3.0.2-beta-3
- Remind myself of our smtp server: grep smtp /opt/eprints2/perl_lib/EPrints/SystemSettings.pm
- ./configure --with-smtp-server=smtp.sussex.ac.uk
- sudo ./install.pl
Apache setup
- sudo vi /etc/apache2/sites-available/eprints
- add to this new file: Include /opt/eprints3/cfg/apache.conf
- sudo a2ensite eprints
- sudo ln -s /opt/eprints3/bin/epindexer /etc/init.d/epindexer
- but: "ln: creating symbolic link `/etc/init.d/epindexer' to `/opt/eprints3/bin/epindexer': File exists"
- looks like it will overwrite the eprints 2 indexer: ls -l shows... /etc/init.d/epindexer -> /opt/eprints2/bin/epindexer But this is ok, we run the indexer as a job from cron "/opt/eprints2/bin/indexer start --rollcount 6 --once" and don't use this symlink, which is for running it as a service, should be ok to overwrite (I hope)...
- sudo rm /etc/init.d/epindexer
- sudo ln -s /opt/eprints3/bin/epindexer /etc/init.d/epindexer
- sudo update-rc.d epindexer defaults 99 99 : produced an error message that it already existed, so should be fine to skip this.
Configure an archive
- Documentation a little unclear here, the Ubuntu docs tell us to follow the 'main eprints3 documentation', so from the main Eprints3 page I clicked on 'installation' and then followed Getting Started on the right, this seems half updated for eprints3 but also referes to eprints2.
- However I also found on the main Eprints 3 docs page a link to Getting Started with EPrints 3 which I shall follow here. I also found the bottom of Installing EPrints 3 on RedHat Enterprise 4 useful. (I've updated the Ubuntu page to link to these two pages).
- cd /opt/eprints3/
- bin/epadmin create
- (at this point I create a cname in our dns for ep3v.lib.sussex.ac.uk as an alias for eprints.lib.sussex.ac.uk, the v is for vanilla as this will be a eprints3 install with no changes made to it for reference)
- archiveID is ep3v
- continue to enter details as prompted, at db username i accept the default it suggests. Get stuck with db password, reports 'bad input'. I quit out of this, and then played with epadmin config_db. In the end had a database but no user and it just didn't seem happy. Easy option, delete directory and start again!
- epadmin create, again, good until, complains "EPrints can create the database, and grant the correct permissions." when doing the db stuff, this was because I had forgotten to delete the ep3v db (which I should have done when I deleted the directory).
- because the create process terminated prematurely I need to run some commands manually
- run bin/epadmin config_db ep3v
- run bin/create_user ep3v (seems to have a fairly strict password criteria, a 7 digit combination of numbers and letters produced 'bad input')
- bin/generate_static ep3v
- bin/import_subjects ep3v
- bin/generate_apacheconf
- sudo /usr/sbin/apache2ctl stop
- It works!
- http://ep3v.lib.sussex.ac.uk:8082/
22 June 2007
First attempt to migrate data
- create dns/dhcp record for ep3m.lib.sussex.ac.uk (m for migration)
- create new archive:
- /opt/eprints3
- bin/epadmin create
- follow creation process (db bit works fine this time, but requires a decent password!).
 
- started to follow http://wiki.eprints.org/w/Migration
- downloaded and extracted toolkit
- run mkconfig.pl sussex
- cd /opt/eprints3/archives/ep3m
- cp -rp cfg cfg.orig
- copy cfg from toolkit to ep3m
- it works. But do we want this. The nice submission process of ep3 has been turned in to the uglyness that is ep2.
- Though... how can we migrate just our changes, without migrating the ep2 default stuff?
- cd migration/mtoolkit
- ./export3data.pl sussex eprints > eprints.xml
- ./export3data.pl sussex users > users.xml
- ./export3data.pl sussex subjects > subjects.xml
- /opt/eprints3/bin/epadmin erase_data ep3m
- /opt/eprints3/bin/import_subjects --verbose --force --xml ep3m subjects.xml
- /opt/eprints3/bin/import --verbose --migration ep3m user XML users.xml
- a number of warnings appear:
- Can't exec "NOTFOUND": No such file or directory at /opt/eprints3/perl_lib/EPrints/Plugin/Convert/ImageMagick/ThumbnailDocuments.pm line 73.
- I suspect these should be ok
- note http://www.eprints.org/tech.php/7265.html
 
- use ubuntu package manager to install imagemagick
- sudo /usr/sbin/apache2ctl stop
- sudo /usr/sbin/apache2ctl start
- /opt/eprints3/bin/epadmin erase_eprints ep3m
- this did not resolve the issue (though /usr/bin/convert exists).
 
