Skip to content

Linux scan

Installation and basic operation

The Linux scan module is implemented in Python and delivered as a Python Executable Zip Application. The current scanner can be found in the subdirectory Native/octoscan-linux of the OctoSAM delivery archive.

Invocation and collection of generated files

Usually, the scanner is invoked using existing management infrastructure.

On workstations and client systems, it's highly recommended to start the scanner in the user's context (logon scripts, etc.) as that gives you valuable device affinity information.

On servers, the scanner should be started in a user context that has read rights to all specificed filesystem locations for Java scans. Otherwise, scanned information may be incomplete.

FILE=$(./octoscan.pyz -o /tmp)

The program emits the generated filename to stdout. Use the variable ${FILE} to further process the file. You are completely free on how to transfer the generated files to the OctoSAM Import Service import folder.

A list of all options can be obtained using the help option

./octoscan.pyz --help

Running octoscan in a container environment

Use your existing container orchestration tools to start the scanner in each container. Depending on your base image you may have to install Python first.

In your orchestration or management environment, you may already have more information about the settings than the scanner can find out in a platform-independent way.

Octoscan supports several options to reflect this environment information to the OctoSAM inventory:

cluster Option

Specify the name of your cluster. Cluster names must be unique.

container Option

Specify --container if you run it in a container environment.

machine Option

You can specify another machine name than what is returned by hostname within the container. The specified value (FQDN format) overrides the machine name in OctoSAM. Make sure the value is unique.

host Option

You can specify an FQDN for your container host (pod). Specify the same FQDN that you get when you scan the host machine from outside the container cluster. DNS may be different inside and outside the container environment.

tag Option

You can specify a custom value to identify the scan source. The specified value will be available in OctoSAM Inventory.

Common error messages when starting the scanner

Unsupported Python2 Version:
Unsupported Python3 Version:

Your system does not meet the minimum requirement of either Python 2.7 or 3.6 or newer.

-bash: ./octoscan.pyz: Permission denied

You probably forgot to set execution permissions on the file octoscan.pyz

/usr/bin/env 'python': No such file or directory

Your system does not have a python interpreter registered under the name python. Most likely you are on a more recent Linux system that has python3 as the default python environment. You need to start the scanner using the python3 command:

python3 octoscan.pyz

Using an upload server

Octosoft provides a web-based upload server running on Windows/IIS or Linux/nginx for generated .scan files.

Use the curl utility on Linux and Mac to upload the generated file.

Very simple example:

FILE=$(./octoscan.pyz -o /tmp)
if curl -F "upload=@${FILE}" http://youruploadserver.yourdomain:8080/upload
then
    rm ${FILE}
fi

In practice, you need to add error handling and ideally handle the case that the upload server may not be available by caching generated .scal files. Depending on your security setup you may also need to provide additional headers etc.

Linux Java process scan

Octoscan performs an in-depth scan of running Java processes. If run as root the scan will read all java processes. Otherwise, it reads processes running under the same user as the scan only.

Linux Java filesystem scan

Without configuration, octoscan scans common installation filesystem paths for Java versions:

  • /opt
  • /usr/lib
  • /usr/lib64
  • /usr/java

If you have your own conventions for installing software, specify the --java option. Paths that do not exist or are not accessible are silently ignored.

octoscan.pyz --java "/app/java:/u00/myapp/lib"

Exclude paths that you do not want to scan with the --javaexclude option. For example if you have mounted an NFS based software repository filesystem on all machines, you do not want to scan this on all machines where it is available. Scan it from a few systems only to avoid false positive hits.

octoscan.pyz --java  "/var:/myapps" --javaexclude "/var/shared/software"

Scan with a user account that has read rights on every specified filesystem.

Do not scan shared network drives multiple times

You might have a software installation filesystem mounted on every machine. We recommend scanning this network drive only from a few specific machines. Otherwise, you may potentially get a lot of false alarm installations for every machine.

Python Version

octoscan.pyz assumes that it is called using the current system implementation of Python. Currently, this is Python 2.7 or 3.6 or newer on most systems. If called directly it uses the python available using /usr/bin/env python.

You can also call python explicitly:

python3 octoscan.pyz -o /tmp

Why use Python?

We decided that a single dependency on a python-minimal installation is easier to handle than the multiple dependencies that we would have with a typical shell-based scanner. The situation is different on macOS, where we can assume certain command-line programs are installed on every machine.

Due to the diversity of Linux implementations, the Linux scanner is quite more complex than the macOS scanner for example. Python allows us to implement a complex scan without writing temporary files, this improves performance considerably. Python programs are generally easier to maintain and debug than shell scripts.

Open file format

The produced file is a zip archive that contains all information as clear text. You can unzip the archive to see what got scanned.

unzip f74ecf32-38b7-4e24-9a7e-f262d7d5e26b.scal

Scanner source license

The source code of the Linux scanner is licensed under the MIT open source license.

Network prerequisites

For best results, all machines in your network should have synchronized clocks. Otherwise, date and time information in the inventory can be unreliable.

Notes for specific Linux variants

The supported Linux variants are tested with their standard installs. If you use a minimal install, some required modules may not be installed by default.

RHEL 8, Centos 8, Rocky Linux 8, minimal install

The python3 command may not be installed by default. The standard system Python is Python 3.6.

sudo yum update
sudo yum install python3
python3 octoscan.pyz

RHEL 9, Centos 9, Rocky Linux 9, Alma Linux 9, minimal install

The python or python3 commands are installed by default and point to Python 3.9.

chmod +x octoscan.pyz
python3 ./octoscan.pyz

Ubuntu minimal install

Some minimum Ubuntu installs do not include Python by default. In that case, you need to first install python-minimal.

sudo apt-get update
sudo apt-get install python-minimal
python octoscan.pyz

Debian 12 minimal network install (with standard utilities)

The python command is installed and points to Python 3.10. Note that curl may not be installed by default. We recommend using curl to upload the generated .scan files to the OctoSAM upload server.

python3 ./octoscan.pyz
# optionally install curl:
# sudo apt update
# sudo apt install curl

SLES 15 minimal install

The python3 command points to Python 3.6. Execute the scanner with an account that has read permissions to all parts of the filesystem you want to scan for Java. Note that the sudo command may not be installed on SLES 15 minimal

python3 octoscan.pyz

Alpine 3

Note

Calling the scanner without root permission is not supported on Alpine.

Alpine uses BusyBox, some commands may differ slightly from their GNU pendants. The --javaexclude option is ignored on Alpine.

apk update
apk add --update --no-cache python3 
python octoscan.pyz