Skip to content

Bika LIMS Installation

rockfruit edited this page Nov 17, 2014 · 61 revisions

Table of Contents

  1. Introduction
  2. Linux Installation Steps
  3. Linux Installer Script
  4. Upgrading Bika LIMS
  5. Windows Installation Steps
  6. Enable Error Reporting
  7. Complete Buildout Configuration

Introduction

If you have any issues you should read the following pages carefully:


Linux Installation Steps

The most commonly used OS for running Plone and Bika LIMS is Linux, although this process should be fairly similar for all systems on which Plone is supported.

1. Install the following system packages

You can paste the following command directly into a terminal:

sudo apt-get install build-essential python-dev git-core libffi-dev libpcre3-dev gcc autoconf libtool pkg-config zlib1g-dev apt-get install libssl-dev libexpat1-dev libxslt1.1 gnuplot libpcre3 libcairo2 libpango1.0-0 libgdk-pixbuf2.0-0

The version numbers of dependencies are known to be valid in Ubuntu 12.04, 14.04, and Debian Wheezy. If you use a different distribution or version, you may need to find the versions of these packages which are provided with your system.

2. Download and Install Plone

Download the latest stable release of the Plone Unified Installer from http://plone.org/products/plone/releases and unpack the file. The following installation command will be sufficient for most purposes:

./install.sh --target=/usr/local/Plone --build-python --static-lxml zeo

3. Add Bika LIMS to your buildout.cfg

In your new Plone folder, you will see a folder named zeocluster. Change directory into this folder, and edit buildout.cfg. Find the section beginning with eggs=, and add bika.lims to the existing entries.

eggs =
    Plone
    Pillow
    bika.lims

Save the file, and then run bin/buildout again. Buildout will download and install all remaining dependencies.

Verify successful build from the output of the installer script, which should include a list of found versions like this:

*************** PICKED VERSIONS ****************
[versions]
Babel = 1.3
...
plone.jsonapi.core = 0.4
*************** /PICKED VERSIONS ***************

The "PICKED VERSIONS" block above indicates a successful buildout. If errors appear while buildout is installing dependencies, you can safely ignore them if this message is displayed.

If the downloads are interrupted, simply run bin/buildout again. The process will be resumed.

If the buildout finished successfully, an 'adminPassword.txt' will be created automatically inside the Plone instance folder. It contains the super-user credentials you'll need to login with.

4. Test run

To start Plone in debug mode, run this command:

bin/plonectl fg

Note any error messages, and take corrective action if required. If no errors are encountered, you can press Control+C to exit.

5. Add a new Plone site

Open a browser and go to http://localhost:8080/. Select "Add Plone Site", ensure that the Bika LIMS option is checked, then submit the form.

6. Start working with Bika LIMS

bin/plonectl start

Open a browser and go to your Bika LIMS instance: http://localhost:8080/Plone


Upgrading Bika LIMS

If a new release of the LIMS is made available, the following procedure will upgrade your existing installation to use the new packages.

Please read Releases life-cycle documentation before upgrading your Bika LIMS instance.

1. Backup

Make a full backup of your instance before continuing:

bin/snapshotbackup

2. Buildout

Run buildout with the "-n" option, to retreive the latest version of Bika LIMS and it's dependencies.

bin/buildout -n

3. Restart Plone

bin/plonectl restart

3. Migrate

Start Plone and login to your site as admin. Go to site-setup, and click Add-ons. Find Bika LIMS in the list of activated addons, and click the "bika.lims" upgrade button.


Windows Installation Steps

1. Download and Install Plone

Download the latest version of the Plone 4.3 Unified Installer from http://plone.org/products/plone/releases. Execute the installer and follow through the steps.

For this guide we will assume the default location of C:\Plone43

2. Add Bika LIMS to your buildout.cfg

Open C:\Plone43\buildout.cfg in a text editor

Add bika.lims to the eggs section

eggs =
    Plone
    Pillow
    Products.PloneHotfix20130618
    bika.lims

3. Run buildout

Save and close the file, start cmd as Administrator (Click start, type "cmd", and press CTRL+SHIFT+ENTER), and then run bin/buildout. Buildout will download and install all remaining dependencies.

cd C:\Plone43
bin\buildout

Verify successful build from the output of the installer script, which should include a list of found versions like this:

*************** PICKED VERSIONS ****************
[versions]
bika.lims = 3.0
...
pyphen = 0.9.1
*************** /PICKED VERSIONS ***************

The "PICKED VERSIONS" block above indicates a successful buildout. If errors appear while buildout is installing dependencies, you can safely ignore them if this message is displayed.

If the download is interrupted, simply run bin/buildout again. The process will be resumed.

If you see the following error: Error: Couldn't install: cffi 0.8.2 Refer to: Troubleshooting: A) Dependencies

If you see the following error: Error 5: Access is denied Refer to: Troubleshooting: B) Privileges

4. Setting up Plone Services

Navigate to the Plone root directory

cd C:\Plone43

Plone and Windows do not always play well together. Install, Start and bring your newly created instance to the Foreground (this should stop the default Plone 4.3 Service)

bin\instance.exe install
bin\instance.exe start
bin\instance.exe fg

If you see the following error: OSError: cannot load library libcairo.so.2 Refer to: Troubleshooting: A) Dependencies

When you see INFO Zope Ready to handle requests the server is ready.

Open a browser and go to http://localhost:8080/. Select "Add Plone Site", ensure that the Bika LIMS option is checked, then submit the form.

Congratulations!! you have a successful build of Bika LIMS on Windows.

5. Notes

If you are having trouble starting bin\instance.exe fg as follows:

The program seems already to be running. If you believe not,
check for dangling .pid and .lock files in var/.

You can try the following steps:

-Find the running process id by opening the .pid file within your instance's var/ directory.
-Open the Windows Task Manager and stop the running process with the above identifier.
-Delete all .pid and .lock files in your instance's var/ directory.
-Start your instance.

__OR__

-Run services.msc
-Search for Plone 4.3
-Try Starting or Stopping it along with your instance

6. Troubleshooting

A) Dependencies You need to install some dependencies manually Download and install bika_dependencies(Plone 4.3.1).exe from https://github.com/zylinx/bika.dependencies This fixes the fact that Plone's buildout cannot compile the libraries required by weasyprint. It installs the pre-compiled binaries into System32 and Plone's installation folder instead.

B) Privileges Open Explorer >> Navigate to C:\ >> Right-Click on the Plone43 directory >> select Properties Select the Security Tab >> Click Edit >> Check Full Control Allow for necessary User / Group Click Apply


Enable error reporting

If you have problems that are hard to diagnose or reproduce, or if you just want to help us find and fix errors faster, please consider adding the following lines to your buildout's eggs= section. It's the easiest way to contribute!

eggs =
    ...
    raven

Then, in all [client] or [instance] sections, insert this:

event-log-custom =
    %import raven.contrib.zope
    <logfile>
      path ${buildout:directory}/var/client1/event.log
      level INFO
      max-size 5 MB
      old-files 5
    </logfile>
    <sentry>
      dsn http://90723864025d4520b084acee225ddb8a:f9f7dd0163a74fbeac4e24a5123b3d39@sentry.bikalabs.com/2
      level ERROR
    </sentry>

Finally, add raven 4.0.4 into [versions] section

[versions]
    ...
    raven = 4.0.4

Run bin/buildout, and restart Plone.

Complete Buildout Configuration

Following the instructions above, you should have a buildout that looks something like the one you see below. This was taken from a Linux system running Plone 4.3.3:

[buildout]
extends =
    base.cfg
    versions.cfg
find-links +=
    http://dist.plone.org/release/4.3.3-pending

effective-user = bika
buildout-user = bika
need-sudo = no

site-hostname = your.site.com

varnish-port = 8080
client1-port = 8085
client2-port = 8086
zeoserver-port = 8089

eggs =
    Plone
    Pillow
    bika.lims

develop =
    src/bika.lims

zcml =
var-dir=${buildout:directory}/var
backups-dir=${buildout:var-dir}
user=admin:adminsecret
deprecation-warnings = off
verbose-security = off

parts =
    zeoserver
    client1
    client2
    backup
    zopepy
    unifiedinstaller
    varnish
    varnish-build

[zeoserver]
<= zeoserver_base
recipe = plone.recipe.zeoserver
zeo-address = 127.0.0.1:${buildout:zeoserver-port}

[client1]
<= client_base
recipe = plone.recipe.zope2instance
zeo-address = ${zeoserver:zeo-address}
http-address = ${buildout:client1-port}

[client2]
<= client_base
recipe = plone.recipe.zope2instance
zeo-address = ${zeoserver:zeo-address}
http-address = ${buildout:client2-port}

[varnish-build]
recipe = zc.recipe.cmmi
url = ${varnish:download-url}

[varnish]
recipe = plone.recipe.varnish
daemon = ${buildout:directory}/parts/varnish-build/sbin/varnishd
bind = 127.0.0.1:${buildout:varnish-port}
balancer = round-robin
backends =
    ${buildout:effective-user}:127.0.0.1:${buildout:client1-port}
    ${buildout:effective-user}:127.0.0.1:${buildout:client2-port}
cache-size = 256M
mode = foreground
user = ${buildout:buildout-user}
first-byte-timeout = 300s
between-bytes-timeout = 300s

[versions]
setuptools = 0.7.2
zc.buildout = 2.2.1
ZopeSkel = 2.21.2
Cheetah = 2.2.1
Products.DocFinderTab = 1.0.5
buildout.sanitycheck = 1.0b1
collective.recipe.backup = 2.17
plone.recipe.unifiedinstaller = 4.3.1
zopeskel.dexterity = 1.5.4.1
zopeskel.diazotheme = 1.1