pmpython(1) — Linux manual page
PMPYTHON(1) General Commands Manual PMPYTHON(1)
NAME
pmpython - run a python script using a preferred python variant
SYNOPSIS
pmpython [python-args-and-script]
DESCRIPTION
pmpython provides a way to run python scripts using a
customisable python interpreter, rather than embedding the name
of a particular version of python into each script.
This can be useful as it allows version-independent python code
to be run anywhere. All python modules shipped with PCP support
versions 2.6 and later (in the python2 series), and 3.3 and later
(in the python3 release series).
Due to python monitoring and collecting scripts being relatively
simple in PCP (not requiring new modules, language features,
etc), it has been possible to ensure they work for all of the
above python versions.
However, the name of the python interpreter is not always the
same, thus, it is common for PCP python scripts to use a
“shebang” line that launches the python interpreter indirectly as
follows:
#!/usr/bin/env pmpython
env(1) is used to find the correct path for the pmpython
executable from the user's $PATH.
By default the name of the python interpreter is found from the
the value of $PCP_PYTHON_PROG from the environment (if set) else
from /etc/pcp.conf. The latter is the more typical case where
this value is based on some heuristics about the platform at the
time the PCP packages were build and favour the use of python3 in
all recent releases of PCP (for those platforms that support it).
This allows an appropriate name to be used for the python
interpreter instead of a hard-coded python version name, while
still allowing the user to override the python interpreter as
follows:
$ PCP_PYTHON_PROG=python3 pmpython --version
Python 3.4.2
$ PCP_PYTHON_PROG=python2 pmpython --version
Python 2.7.9
This is convenient for shipping identical scripts on multiple
platforms, and for testing different python versions with the one
script (e.g. in the case where multiple versions of python are
installed, PCP_PYTHON_PROG can be set in the local environment to
override the global setting).
pmpython is a replacement for an earlier tool with similar
function, namely pcp-python(1).
PCP ENVIRONMENT
Environment variables with the prefix PCP_ are used to
parameterize the file and directory names used by PCP. On each
installation, the file /etc/pcp.conf contains the local values
for these variables. The $PCP_CONF variable may be used to
specify an alternative configuration file, as described in
pcp.conf(5).
SEE ALSO
env(1), pcp(1), pcp-python(1) and PCPIntro(1).
COLOPHON
This page is part of the PCP (Performance Co-Pilot) project.
Information about the project can be found at
⟨http://www.pcp.io/⟩. If you have a bug report for this manual
page, send it to pcp@groups.io. This page was obtained from the
project's upstream Git repository
⟨https://github.com/performancecopilot/pcp.git⟩ on 2024-06-14.
(At that time, the date of the most recent commit that was found
in the repository was 2024-06-14.) If you discover any rendering
problems in this HTML version of the page, or you believe there
is a better or more up-to-date source for the page, or you have
corrections or improvements to the information in this COLOPHON
(which is not part of the original manual page), send a mail to
man-pages@man7.org
Performance Co-Pilot PCP PMPYTHON(1)
Pages that refer to this page: pcp-python(1), pmdalio(1), pmdaopenvswitch(1), pmdarabbitmq(1)