Offload Polyspace Analysis from Continuous Integration Server to Another Server
When running static code analysis with Polyspace® as part of continuous integration, you might want the analysis to run on a server that is different from the server running your continuous integration (CI) scripts. For instance:
You might want to perform the analysis on a server that has more processing power. You can offload the analysis from your CI server to the other server.
You might want to submit analysis jobs from several CI servers to a dedicated analysis server, hold the jobs in queue, and execute them as Polyspace Server instances become available.
When you offload an analysis, the compilation phase of the analysis runs on the CI server. After compilation, the analysis job is submitted to the other server and continues on this server. On completion, the analysis results are downloaded back to the CI server. You can then upload the results to Polyspace Access for review, or report the results in some other format.
Install Products
A typical distributed network for offloading an analysis consists of these parts:
Client node(s): Each CI server acts as a client node that submits Polyspace analysis jobs to a cluster.
The cluster consists of a head node and one or more worker nodes. In this example, we use the same computer as the head node and one worker node.
Head node: The head node distributes the submitted jobs to worker nodes.
Worker node(s): Each worker node executes one Polyspace analysis at a time.
Note
The versions of Polyspace on the client and worker nodes must match.
Install these products:
Client nodes: Polyspace Bug Finder™ Server™ or Polyspace Code Prover™ Server to submit jobs from the Continuous Integration server. Note that you do not require licenses for the Polyspace Server products if you use them only for job submission (with the
-batch
option).Head node: MATLAB® Parallel Server™ to manage submissions from multiple clients. An analysis job is created for each submission and placed in a queue. As soon as a worker node is available, the next analysis job from the queue is run on the worker.
Worker node(s): MATLAB Parallel Server and Polyspace Bug Finder Server or Polyspace Code Prover Server on the worker nodes to run a Bug Finder or Code Prover analysis.
In the simplest configuration, where the same computer serves as the head node and one worker node, you install MATLAB Parallel Server and one or both Polyspace Bug Finder Server and Polyspace Code Prover Server on this computer. This example describes the simple configuration but you can generalize the steps to multiple workers on separate computers.
Configure and Start Job Scheduler Services on Head Node and Worker Node
Start a job scheduler service (the MATLAB Job Scheduler or mjs
service) on the computer that acts as the head node and worker node. Before starting
the service, you must perform an initial setup.
Specify Polyspace Installation Paths
MATLAB Parallel Server and Polyspace Server products are installed in two separate folders. The MATLAB Parallel Server installation routes the Polyspace analysis to the Polyspace Server products. To link the two installations, specify the path to the root folder of the Polyspace Server products in your MATLAB Parallel Server installation.
Navigate to
. Here,matlabroot
\toolbox\parallel\bin\
is the MATLAB Parallel Server installation folder, for instance,matlabroot
C:\Program Files\MATLAB\R2024b
.Uncomment and modify the following line in the file
mjs_polyspace.conf
. To edit and save the file, open your editor in administrator mode.POLYSPACE_SERVER_ROOT=polyspaceserverroot
Here,
is the installation path of the server products, for instance:polyspaceserverroot
C:\Program Files\Polyspace Server\R2024b
The Polyspace Server product offloading the analysis must belong to the same release as the Polyspace Server product running the analysis. If you offload an analysis from an R2024b Polyspace Server product, the analysis must run using another R2024b Polyspace Server product.
Configure mjs
Service Settings
Before starting MATLAB
Parallel Server (the mjs
service), you must perform a minimum
configuration.
Navigate to
, wherematlabroot
\toolbox\parallel\bin
is the MATLAB Parallel Server installation folder, for instance,matlabroot
C:\Program Files\MATLAB\R2024b
.Modify the file
mjs_def.bat
(Windows®) ormjs_def.sh
(Linux®). To edit and save the file, open your editor in administrator mode.Read the instructions in the file and uncomment the lines as needed. At a minimum, uncomment these lines that specify:
Host name.
Windows:
Linux:REM set HOSTNAME=%strHostname%.%strDomain%
Explicitly specify your computer host name.#HOSTNAME=`hostname -f`
Security level.
Windows:
Linux:REM set SECURITY_LEVEL=
Explicitly specify a security level to avoid future errors when starting the job scheduler.#SECURITY_LEVEL=""
For security levels 2 and higher, you have to provide a password in a graphical window at the time of job submission.
Start mjs
Service and One Worker
In a command-line terminal, cd
to
,
where matlabroot
\toolbox\parallel\bin
is the
MATLAB
Parallel Server installation folder, for instance, matlabroot
C:\Program Files\MATLAB\R2024b
. Run these commands (directly at the command line or
by using scripts):
mjs install mjs start startjobmanager -name JobScheduler -remotehost hostname -v startworker -jobmanagerhost hostname -jobmanager JobScheduler -remotehost hostname -v
mjs install mjs start startjobmanager -name JobScheduler -remotehost hostname -v startworker -jobmanagerhost hostname -jobmanager JobScheduler -remotehost hostname -v
hostname
is the host name
of your computer. This name is the host name that you specified in the file
mjs_def.bat
(Windows) or mjs_def.sh
(Linux).For more details and configuring services with multiple workers, see:
Install for MATLAB Job Scheduler with Network License Manager (MATLAB Parallel Server)
mjs
(MATLAB Parallel Server)
Offload Analysis from Client Node
Once you have set up the computer that acts as the head node and worker node, you are ready to offload a Polyspace analysis from the client node (the CI server running scripts on Jenkins® on another CI system).
To offload an analysis, enter:
polyspaceserverroot\polyspace\bin\polyspace-code-prover-server -batch -scheduler hostname|MJSName@hostname [options] [-mjs-username name]
is the installation folder of Polyspace Server products on the client node, for instance,polyspaceserverroot
C:\Program Files\Polyspace Server\R2024b
.
is the host name of the computer that hosts the head node of the MATLAB Parallel Server cluster.hostname
is the name of the MATLAB Job Scheduler on the head node host.MJSName
If you use the
startjobmanager
command to start the MATLAB Job Scheduler,
is the argument of the optionMJSName
-name
.
are the Polyspace analysis options. These options are the same as that of a local analysis. For instance, you can use these options:options
-sources-list-file
: Specify a text file that has one source file name per line.-options-file
: Specify a text file that has one option per line.-results-dir
: Specify a download folder for storing results after analysis.
For the full list of options, see Complete List of Polyspace Code Prover Analysis Options.
is the user name required for job submissions using MATLAB Parallel Server. This credential is required only if you use a security level of 1 or higher for MATLAB Parallel Server submissions. See Set MATLAB Job Scheduler Cluster Security (MATLAB Parallel Server).name
For security levels 2 and higher, you have to provide a password in a graphical window at the time of job submission. To avoid this prompt in the future, you can specify that the password be remembered on the computer.
The analysis executes locally on the CI server up to the end of the compilation phase. After compilation, the analysis job is submitted to the other server. On completion, the analysis results are downloaded back to the CI server. You can then upload the results to Polyspace Access for review, or report the results in some other format.
See Also
polyspace-access
(Polyspace Access)