Difference between revisions of "Managing Perl Libraries"

From WormBaseWiki
Jump to navigationJump to search
 
(18 intermediate revisions by 3 users not shown)
Line 6: Line 6:
  
 
   /path/to/application/extlib
 
   /path/to/application/extlib
 
Installing modules in a local path is made significantly easier through the use of local::lib and Apache2/mod_perl2 "PerlSwitches" directive.
 
 
local::lib dispenses with the need to maintain multiple CPAN configurations or manual tweaks to your environment variables in order to recognize already installed modules.
 
  
 
= Installing a local CPAN repository =
 
= Installing a local CPAN repository =
Line 15: Line 11:
 
''I maintain a local mirror of CPAN. This makes installing our web application significantly faster.''
 
''I maintain a local mirror of CPAN. This makes installing our web application significantly faster.''
  
Fetch [http://www.trout.me.uk/perl/mirror.sh.txt Matt Trout's minicpan mirroring script]. You can find our version at '''hg:wormbase-admin>mirror/minicpan.sh'''
+
$ sudo perl -MCPAN -e shell
<pre>
+
$ cpan> install CPAN::Mini
#!/bin/sh
 
# Dumbass minicpan replacement - Matt S Trout 2005/6. Perl license.
 
  
# Pick one from http://cpan.org/SITES.html#RSYNC
+
Create a ~/.minicpanrc file:
REMOTEHOST='ftp.belnet.be'
 
REMOTEPREFIX='packages/cpan'
 
  
# Unless you're me, you probably want to change this too
+
<pre>
LOCAL='/home/matthewt/mirrors/minicpan'
+
# CPAN::Mini configuration file
 +
# to set up our local WormBase CPAN
  
cd $LOCAL
+
local: /usr/local/wormbase/minicpan
mkdir -p work authors/id modules
+
remote: http://mirror.rit.edu/CPAN/
 +
exact_mirror: 1
 +
</pre>
  
rsync $REMOTEHOST::"$REMOTEPREFIX/modules/03modlist.data.gz $REMOTEPREFIX/modules/02packages.details.txt.gz" modules/
+
Set up your CPAN to use the local mirror:
zcat modules/02packages.details.txt.gz | egrep '\.(tar\.gz|tgz|zip)$' | egrep -v '/((perl-|parrot-|ponie-)[0-9]|perl5\.004)' | awk '{print $3}' | sort -u >work/targets.dists
+
<pre>
cat work/targets.dists | cut -d'/' -f1-3 | sort -u | perl -pe 's!$!/CHECKSUMS!;' >work/targets.checksums
+
$ cpan
cat work/targets.dists | perl -pe 's!/[^/]+$!\n!;' >work/targets.dirs
+
cpan> o conf urllist file:///usr/local/wormbase/minicpan/
 +
cpan> o conf commit
 +
</pre>
  
cd $LOCAL/authors/id
+
Don't forget cpanplus:
cat $LOCAL/work/targets.dirs | xargs -n100 mkdir -p
+
<pre>
cat $LOCAL/work/targets.checksums | xargs -n100 touch
+
$ cpanp
cat $LOCAL/work/targets.dists | xargs -n100 touch
+
$ CPAN Terminal> s reconfigure
 
+
$ select the System configuration, then the mirror option, custom, and as above. Save and quit.
cd $LOCAL
 
rsync -vr --size-only --existing $REMOTEHOST::"$REMOTEPREFIX/authors/" authors/
 
find authors/id -name '*.*' | perl -pe 's!^authors/id/!!;' | sort -u >work/tree.all
 
sort -u work/targets.* | comm -13 - work/tree.all | perl -pe 's!^!authors/id/!;' | xargs rm -v
 
 
</pre>
 
</pre>
  
= Installation Script =
+
Set up the minicpan to run once a day:
 +
* 3 * * * minicpan
  
The steps described in this document are almost entirely scripted:
+
= Required Perl modules =
  
  wormbase-admin:maintenance/install_perl_modules.sh
+
''See the [https://bitbucket.org/tharris/wormbase/src/d91a1c3571d4/Makefile.PL Makefile.PL] for a complete list of required Perl modules.''
  
  Usage:
+
= Installation Paths =
  $ ./install_perl_modules.sh /path/to/private/libraries/extlib
 
  
  Usage (for installing Catalyst and its dependencies):
+
By convention, 3rd party Perl modules are maintained in an "extlib" directory within each version of the site. This enables us to keep unique sets of libraries for each website.
  $ ./install_perl_modules.sh /path/to/private/libraries/extlib CATALYST
 
  
Read on for additional (important) details that include appropriate settings for interactive steps in the script.
+
website/production/extlib - ''The current production version of the website''
 +
website/tharris/extlib - ''My private development space''
  
= Private library locations =
+
To set up your environment, copy the wormbase.env.template file to ''wormbase.env''.  Change the $APP variable to match your directory (ie ''tharris'). Then:
 +
 +
$ source wormbase.env
  
By convention, 3rd party Perl modules are maintained in an "extlib" directory within each project directory:
+
== local::lib ==
  
  website-classic/extlib - ''The "Classic" WormBase website
+
The ''wormbase.env'' file uses local::lib to easily set up a local library path. local::lib is already installed into the system Perl path:
  website/extlib - 'The rearchitecture
 
  website-2.01/extlib - Version 2.01 of the rearchitecture
 
  
And so on...
+
  sudo perl -MCPAN -e install 'local::lib'
  
 +
local::lib dispenses with the need to maintain multiple CPAN configurations or manual tweaks to your environment variables in order to recognize already installed modules.
  
 +
'''To set a local installation environment, you would:'''
  
= Required Perl modules =
+
$ cd /usr/local/wormbase/website/tharris/extlib
 +
$ perl -Mlocal::lib=./
 +
export MODULEBUILDRC="/usr/local/wormbase/website/tharris/extlib/.modulebuildrc"
 +
export PERL_MM_OPT="INSTALL_BASE=/usr/local/wormbase/website/tharris/extlib"
 +
export PERL5LIB="/usr/local/wormbase/website/tharris/extlib/lib/perl5:/usr/local/wormbase/website/tharris/extlib/lib/perl5/x86_64-linux-gnu-thread-multi:$PERL5LIB"
 +
export PATH="/usr/local/wormbase/website/tharris/extlib/bin:$PATH"
  
== WormBase "Classic" ==
+
$ eval $(perl -Mlocal::lib=--self-contained,./)
  
Install the following Perl modules via CPAN. Note that you DO NOT AND SHOULD NOT be sudo.
+
'''To install a module'''
  
  cd /usr/local/wormbase/extlib/classic
+
  $ perl -MCPAN -Mlocal::lib=--self-contained -e 'CPAN::install(MODULE)'
perl -Mlocal::lib=./
 
eval $(perl -Mlocal::lib=--self-contained,./)
 
perl -MCPAN -e 'CPAN::install(MODULE)'
 
  
// Some basics...
+
'''Installing a module without using local::lib'''
YAML
 
LWP
 
ExtUtils::MakeMaker
 
Bundle::CPAN
 
 
// The rest...
 
Bio::Graphics
 
BioPerl 
 
    // When prompted, choose to download all optional modules. This will also install Ace:
 
Ace
 
    // During configuration, choose option (3), then set the remaining variables as follows:
 
    Site-specific configuration files:  /usr/local/wormbase/website-classic/conf
 
    CGI path: /usr/local/wormbase/website-classic/cgi-bin
 
    HTML path: /usr/local/wormbase/website-classic/html
 
  
    // For Catalyst-based apps:
+
You may on occasion need to install something without using local::lib. For EUMM modules, use
    Site-specific configuration files:  /usr/local/wormbase/website/conf
 
    CGI path: /usr/local/wormbase/website/root/cgi
 
    HTML path/usr/local/wormbase/website/root/static
 
  
Cache::Cache
+
   perl -I/usr/local/wormbase/[PROJECT]/extlib Makefile.PL INSTALL_BASE=/usr/local/wormbase/[PROECT]/extlib
Cache::FileCache
 
CGI
 
CGI::Session 
 
CGI::Cache
 
CGI::Toggle
 
Class::Base
 
Data::Stag
 
Date::Calc
 
Date::Manip
 
DB_File
 
DBI
 
DBD::mysql   (mysql devel package must be installed first)
 
    // To build by hand:
 
    perl Makefile.PL INSTALL_BASE=/usr/local/wormbase/extlib/classic --testuser=USER --testpassword=PASS
 
    make ; make test ; make install
 
Digest::MD5
 
Flickr::API
 
Flickr::API::Simple
 
    // This is a private library
 
    cd /usr/local/wormbase/build
 
    perl ./Build.PL --install_base /usr/local/wormbase/extlib/classic
 
    ./Build install
 
GD
 
GD::SVG
 
GD::Graph
 
GD::Graph::pie
 
HTML::TokeParser
 
IO::Scalar
 
IO::String
 
Image::GD::Thumbnail
 
Log::Log4perl
 
MIME::Lite
 
mod_perl2  // Requires that apache2 already be installed; apxs is at /usr/local/apache2/bin/apxs
 
Net::FTP
 
Proc::Simple
 
Search::Indexer
 
SOAP::Lite
 
Statistics::OLS
 
Storable
 
SVG
 
SVG::Graph
 
Term::ReadKey
 
Test::Pod
 
Text::Shellwords
 
Time::Format
 
WeakRef
 
XML::SAX
 
XML::Parser
 
XML::DOM
 
XML::Writer
 
XML::Twig
 
XML::Simple
 
  
== WormBase > 2.0 ==
+
And for Module::Build
  
WormBase2.0 and above uses the Catalyst web framework.  In addition to the modules described above we also need to install Catalyst.
+
  perl -I/usr/local/wormbase/[PROJECT]/extlib Makefile.PL --install_base /usr/local/wormbase/[PROJECT]/extlib
  
These first two bundles will install the majority of the Catalyst web framework:
+
Alternatively, you can manually edit ~/.cpan/CPAN/MyConfig.pm
  
Task::Catalyst
+
= Installing WebApp Dependencies =
Catalyst::Devel
 
  
  We also need:
+
Build all requirements is as easy as:
  
  Catalyst::Model::DBI
+
  $ cd /usr/local/wormbase/website/$APP
  Catalyst::Model::Adaptor
+
  $ source wormbase.env
  Catalyst::Plugin::ConfigLoader
+
  $ perl Makefile.PL
  Catalyst::Plugin::Session
+
  $ make installdeps
Catalyst::Plugin::Session::State
 
Catalyst::Plugin::Session::State::Cookie
 
Catalyst::Plugin::Session::Store::FastMMap
 
Catalyst::Action::RenderView
 
Catalyst::Action::Rest
 
Catalyst::Log::Log4perl
 
Test::YAML::Valid
 
  
= local::lib =
+
Note: the wormbase.env should ensure local::lib use /usr/local/wormbase/extlib/ as installation path for packages.
  
== Installation ==
+
= Tips and Tricks =
  
local::lib is installed into the system Perl path:
+
== ACePerl ==
  
  sudo perl -MCPAN -e install 'local::lib'
+
Adjust the values below as necessary for your
  
== Setting a library path ==
+
[tharris@wb-dev: AcePerl-1.92-BlHove]> sudo perl Makefile.PL
  
$ cd /usr/local/wormbase/extlib/classic
+
What do you want to build?
$ perl -Mlocal::lib=./
 
export MODULEBUILDRC="/usr/local/wormbase/extlib/classic/.modulebuildrc"
 
export PERL_MM_OPT="INSTALL_BASE=/usr/local/wormbase/extlib/classic"
 
export PERL5LIB="/usr/local/wormbase/extlib/classic/lib/perl5:/usr/local/wormbase/extlib/classic/lib/perl5/x86_64-linux-gnu-thread-multi:$PERL5LIB"
 
export PATH="/usr/local/wormbase/extlib/classic/bin:$PATH"
 
  
Take note: we will use some of these variables for, say, setting up apache.
+
  1) Interface to Ace socket server and local databases (pure Perl)
 +
  2) The above plus XS optimizations (requires C compiler)
 +
  3) The above plus RPC server interface (requires C compiler)
  
  $ eval $(perl -Mlocal::lib=--self-contained,./)
+
Enter your choice: [1] 3
  
== Installing a module ==
+
Do you want to install Ace::Browser?  [n] y
  
$ perl -MCPAN -Mlocal::lib=--self-contained -e 'CPAN::install(MODULE)'
+
You have installed Ace::Browser before, using old settings for defaults.
 +
Directory for the site-specific configuration files (~username ok): [/usr/local/wormbase/website/tharris/conf/ace]
 +
Directory for the acebrowser CGI scripts (~username ok): [/usr/local/wormbase/website/tharris/root/cgi-bin/ace]
 +
Directory for the acebrowser HTML files and images (~username ok): [/usr/local/wormbase/website/tharris/root/static/ace]
  
== Installing a module without using local::lib ==
 
  
You may on occasion need to install something without using local::lib.  For EUMM modules, use
 
 
  perl -I/usr/local/wormbase/[PROJECT]/extlib Makefile.PL INSTALL_BASE=/usr/local/wormbase/[PROECT]/extlib
 
 
And for Module::Build
 
 
  perl -I/usr/local/wormbase/[PROJECT]/extlib Makefile.PL --install_base /usr/local/wormbase/[PROJECT]/extlib
 
 
Alternatively, you can manually edit ~/.cpan/CPAN/MyConfig.pm
 
 
= Tips and Tricks =
 
  
 
''Some modules may require a little TLC.  After running the script you can find source at ~/.cpan/build/module-*''
 
''Some modules may require a little TLC.  After running the script you can find source at ~/.cpan/build/module-*''
Line 237: Line 145:
  
 
You will need to specify a test user and test password for tests to pass.
 
You will need to specify a test user and test password for tests to pass.
 
== ModPerl2 ==
 
 
You will need to be sudo in order to install the dso.
 
  
 
= Updating Modules =
 
= Updating Modules =
Line 270: Line 174:
 
(Or just use the install script).
 
(Or just use the install script).
  
 
+
[[Category:Maintenance (Web Dev)]]
 
[[Category:Developer documentation]]
 
[[Category:Developer documentation]]

Latest revision as of 18:47, 13 April 2015

Overview

Maintaining Perl modules across our server farm can be a time consuming and tedious task because of the heterogeneity of our setup. Further, we often need to maintain unique sets of libraries for different applications with collisions.

To solve these problems, I maintain local copies of libraries for each application. Typically, these are found at

 /path/to/application/extlib

Installing a local CPAN repository

I maintain a local mirror of CPAN. This makes installing our web application significantly faster.

$ sudo perl -MCPAN -e shell
$ cpan> install CPAN::Mini

Create a ~/.minicpanrc file:

# CPAN::Mini configuration file
# to set up our local WormBase CPAN

local: /usr/local/wormbase/minicpan
remote: http://mirror.rit.edu/CPAN/
exact_mirror: 1

Set up your CPAN to use the local mirror:

$ cpan
cpan> o conf urllist file:///usr/local/wormbase/minicpan/
cpan> o conf commit

Don't forget cpanplus:

$ cpanp
$ CPAN Terminal> s reconfigure
$ select the System configuration, then the mirror option, custom, and as above. Save and quit.

Set up the minicpan to run once a day:

  • 3 * * * minicpan

Required Perl modules

See the Makefile.PL for a complete list of required Perl modules.

Installation Paths

By convention, 3rd party Perl modules are maintained in an "extlib" directory within each version of the site. This enables us to keep unique sets of libraries for each website.

website/production/extlib - The current production version of the website
website/tharris/extlib - My private development space

To set up your environment, copy the wormbase.env.template file to wormbase.env. Change the $APP variable to match your directory (ie tharris'). Then:

$ source wormbase.env

local::lib

The wormbase.env file uses local::lib to easily set up a local library path. local::lib is already installed into the system Perl path:

 sudo perl -MCPAN -e install 'local::lib'

local::lib dispenses with the need to maintain multiple CPAN configurations or manual tweaks to your environment variables in order to recognize already installed modules.

To set a local installation environment, you would:

$ cd /usr/local/wormbase/website/tharris/extlib
$ perl -Mlocal::lib=./
export MODULEBUILDRC="/usr/local/wormbase/website/tharris/extlib/.modulebuildrc"
export PERL_MM_OPT="INSTALL_BASE=/usr/local/wormbase/website/tharris/extlib"
export PERL5LIB="/usr/local/wormbase/website/tharris/extlib/lib/perl5:/usr/local/wormbase/website/tharris/extlib/lib/perl5/x86_64-linux-gnu-thread-multi:$PERL5LIB"
export PATH="/usr/local/wormbase/website/tharris/extlib/bin:$PATH"
$ eval $(perl -Mlocal::lib=--self-contained,./)

To install a module

$ perl -MCPAN -Mlocal::lib=--self-contained -e 'CPAN::install(MODULE)'

Installing a module without using local::lib

You may on occasion need to install something without using local::lib. For EUMM modules, use

 perl -I/usr/local/wormbase/[PROJECT]/extlib Makefile.PL INSTALL_BASE=/usr/local/wormbase/[PROECT]/extlib

And for Module::Build

 perl -I/usr/local/wormbase/[PROJECT]/extlib Makefile.PL --install_base /usr/local/wormbase/[PROJECT]/extlib 

Alternatively, you can manually edit ~/.cpan/CPAN/MyConfig.pm

Installing WebApp Dependencies

Build all requirements is as easy as:

$ cd /usr/local/wormbase/website/$APP
$ source wormbase.env
$ perl Makefile.PL
$ make installdeps

Note: the wormbase.env should ensure local::lib use /usr/local/wormbase/extlib/ as installation path for packages.

Tips and Tricks

ACePerl

Adjust the values below as necessary for your

[tharris@wb-dev: AcePerl-1.92-BlHove]> sudo perl Makefile.PL

What do you want to build?

 1) Interface to Ace socket server and local databases (pure Perl)
 2) The above plus XS optimizations (requires C compiler)
 3) The above plus RPC server interface (requires C compiler)

Enter your choice: [1] 3

Do you want to install Ace::Browser? [n] y

You have installed Ace::Browser before, using old settings for defaults. Directory for the site-specific configuration files (~username ok): [/usr/local/wormbase/website/tharris/conf/ace] Directory for the acebrowser CGI scripts (~username ok): [/usr/local/wormbase/website/tharris/root/cgi-bin/ace] Directory for the acebrowser HTML files and images (~username ok): [/usr/local/wormbase/website/tharris/root/static/ace]


Some modules may require a little TLC. After running the script you can find source at ~/.cpan/build/module-*

BioPerl

Instead of building BioPerl from CPAN, it might be necessary to build from SVN:

 $ cd /usr/local/wormbase/build
 $ svn co svn+ssh://USERNAME@dev.open-bio.org/home/svn-repositories/bioperl/bioperl-live/trunk bioperl-live
 $ mv bioperl-live bioperl-live-tharris
 $ cd bioperl-live-tharris
 $ perl ./Build.PL install_base /usr/local/wormbase/extlib
 $ ./Build test
 $ ./Build install

DBD::mysql

You will need to specify a test user and test password for tests to pass.

Updating Modules

To show all modules that are out-of-date with those on CPAN:

$ cd /path/to/extlib
$ perl -Mlocal::lib=./
$ eval $(perl -Mlocal::lib=--self-contained,./)
$ perl -MCPAN -e 'CPAN::Shell->r'

To update all of these modules at once:

$ perl -MCPAN -e 'CPAN::Shell->install(CPAN::Shell->r)'

Managing libraries across architectures

Via CPAN bundles

# Create a bundle
$ cd /path/to/extlib
$ perl -Mlocal::lib=./
$ eval $(perl -Mlocal::lib=--self-contained,./)
$ perl -MCPAN -e autobundle   # The bundle is (typically) in extlib
# To reinstall:
$ perl -MCPAN -e 'install Bundle::Snapshot_YYYY_MM_DD_00'

(Or just use the install script).