Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

Testers can use the following environment settings to properly test their applications against Python 2.7.13:

Configuring LCLS production environment for testing

Method 1

If you would like full control over your user environment settings, use the following instructions.

...

  1. Add the new Python instance to your environment:

    export PYTHON_ROOT=${LCLS_ROOT}/package/python/python2.7.13/linux-x86_64

  2. Add the new Python binaries to the PATH environment variable:

    export PATH=${QT_HOME}/bin:${ORACLE_HOME}/bin:${PYTHON_ROOT}/bin:${PATH}

  3. Add the new Python libraries and their dependencies (EPICS 64-bit, Matlab, etc.) to the LD_LIBRARY_PATH environment variable. This is to ensure that the new 64-bit versions of Python modules built against those dependencies will work:

    export LD_LIBRARY_PATH=${LCLS_ROOT}/matlab/2016b/extern/lib:${EPICS_BASE_RELEASE}/lib/linux-x86_64: ${EPICS_EXTENSIONS}/lib/linux-x86_64:${EPICS_BASE_TOP}/base-cpp-R4 -6-0/lib/linux-x86_64:${PYTHON_ROOT}/lib:${PYTHON_ROOT}/build/Python2.7.13/Lib:${LD_LIBRARY_PATH}

  4. Clear the PYTHONPATH environment variable. This is to ensure that there are no false positives when testing applications, since PYTHONPATH may still have access to older versions of Python modules:

    export PYTHONPATH=
  5. [Optional] If your application(s) import the "cx_Oracle" module, add/change the following in your environment:

    export PATH=${ORACLE_HOME}/bin:${PATH}

    export LD_LIBRARY_PATH=${ORACLE_HOME}/lib:${LD_LIBRARY_PATH}

  6. [Optional] If your application(s) import "PyQt", "PyQwt", or any other Python modules that depend on Qt, add/change the following in your environment:

    export QT_HOME=${LCLS_ROOT}/package/Qt/Qt-4.8.6/linux-x86_64

    export PATH=${QT_HOME}/bin:${PATH}

    export LD_LIBRARY_PATH=${QT_HOME}/lib:${LD_LIBRARY_PATH}

Method 2

If you would like to use the full Python 2.7.13 64-bit environment and all of its dependencies, source the following setup script, which does all of the steps in Method 1, including the optional ones:

source /usr/local/lcls/tools/script/go_python2.7.13.bash

Info
titleNote
The script above may introduce duplicate paths into your environment settings. Be aware of your environment settings before and after testing your Python applications.

 

#!/bin/bash

# Sets the user environment to use Python2.7.13

 

if [

...

-d /afs/slac/g/lcls ];

...

then

...

    export LCLS_ROOT=/afs/slac/g/lcls

else

   

...

export LCLS_ROOT=/usr/local/lcls

fi

 

...

# Set default Java to 64-bit

export JAVA_HOME=${LCLS_ROOT}/package/

...

java/

...

jdk1.

...

8.0_144

 

if [ -z `echo "${PATH}" | grep "${JAVA_HOME}/bin"` ]; then

    export PATH=${JAVA_HOME}/bin:${PATH}

fi

 

if [ -z `echo "${LD_LIBRARY_PATH}" | grep "${JAVA_HOME}/lib"` ]; then

    export LD_LIBRARY_PATH=${JAVA_HOME}/lib:${LD_LIBRARY_PATH}

fi

 

# Set default Qt to 64-bit for PyQwt and PyQt4 compatibility

export QT_HOME=${LCLS_ROOT}/package/Qt/Qt-4.8.6/linux-x86_64

if [ -z `echo "${PATH}" | grep "${QT_HOME}/bin"` ]; then

...

    export PATH=${QT_HOME}/bin:${PATH}

fi

 

if [ -z `echo "${LD_LIBRARY_PATH}" | grep "${QT_HOME}/lib"` ]; then

    export LD_LIBRARY_PATH=${QT_HOME}/lib:${LD_LIBRARY_PATH}

fi

 

# Set default Oracle client to 11.2.0.2.0 64-bit for cx_Oracle compatibility

export ORACLE_HOME=${LCLS_ROOT}/package/

...

oracle/product/11.2.0.2.0_x86_64/client_1

if [ -z `echo "${PATH}" | grep "${ORACLE_HOME}/bin"` ]; then

   

...

export PATH=${

...

ORACLE_HOME}/bin:${PATH}

fi

 

if [ -z `echo "${LD_LIBRARY_PATH}" | grep "${ORACLE_HOME}/

...

lib"` ]; then

    export LD_LIBRARY_PATH=${

...

ORACLE_

...

HOME}/

...

lib:${LD_LIBRARY_PATH}

fi

 

 

# Set default Matlab to 2016b 64-bit for matlab_wrapper compatibility

if [ -z `echo "${LD_LIBRARY_PATH}" | grep "${LCLS_ROOT}/matlab/2016b/extern/lib"` ]; then

   

...

export LD_LIBRARY_PATH=${LCLS_ROOT}/matlab/2016b/extern/lib:${LD_LIBRARY_PATH}

fi

 

# Set default EPICS to 64-bit for pyca and psp compatibility

if [ -z `echo "${LD_LIBRARY_PATH}" | grep "${EPICS_BASE_RELEASE}/lib/linux-x86_64"` ]; then

    export LD_LIBRARY_PATH=${EPICS_BASE_RELEASE}/lib/linux-x86_64:${LD_LIBRARY_PATH}

fi

 

if [ -z `echo "${LD_LIBRARY_PATH}" | grep "${EPICS_EXTENSIONS}/lib/linux-x86_64"` ]; then

    export LD_LIBRARY_PATH=${EPICS_EXTENSIONS}/lib/linux-x86_64:${LD_LIBRARY_PATH}

fi

 

if [ -z `echo "${LD_LIBRARY_PATH}" | grep "${EPICS_BASE_TOP}/base-cpp-R4-6-0/lib/linux-x86_64"` ]; then

    export LD_LIBRARY_PATH=${EPICS_BASE_TOP}/base-cpp-R4-6-0/lib/linux-x86_64:

...

${LD_LIBRARY_PATH}

fi

 

# Set default Python to 2.7.13 64-bit

export PYTHON_ROOT=${LCLS_ROOT}/package/python/python2.7.13/linux-x86_64

if [ -z `echo "${PATH}" | grep "${PYTHON_ROOT}/bin"` ]; then

    export PATH=${PYTHON_ROOT}/bin:${PATH}

fi

 

if [ -z `echo "${LD_LIBRARY_PATH}" | grep "${PYTHON_ROOT}/lib"` ]; then

    export LD_LIBRARY_PATH=${PYTHON_ROOT}/lib:${LD_LIBRARY_PATH}

fi

 

if [ -z `echo "${LD_LIBRARY_PATH}" | grep "${PYTHON_ROOT}/build/Python2.7.13/Lib"` ]; then

    export LD_LIBRARY_PATH=${PYTHON_ROOT}/build/Python2.7.13/Lib:${LD_LIBRARY_PATH}

fi

 

# Clear existing $PYTHONPATH

export PYTHONPATH=

 

Workarounds

After testing, it may be discovered that certain applications may not run with Python 2.7.13 64-bit due to unresolved/conflicting dependencies (e.g., 32-bit Python modules, Matlab2016b, Qt5, etc.) or other reasons. If such dependencies cannot currently be resolved, Python developers may invoke the following environment settings in a wrapper script or similar to launch the application using the older instance of Python instead:

...