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 - -batchoption).
- 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 - matlabroot\toolbox\parallel\bin\- matlabroot- C:\Program Files\MATLAB\R2025b.
- 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, - polyspaceserverroot- C:\Program Files\Polyspace Server\R2025b
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 R2025b Polyspace Server product, the analysis must run using another R2025b Polyspace Server product.
Configure mjs Service Settings
Before starting MATLAB
            Parallel Server (the mjs service), you must perform a minimum
                    configuration.
- Navigate to - matlabroot\toolbox\parallel\bin- matlabroot- C:\Program Files\MATLAB\R2025b.
- Modify the file - mjs_def.bat(Windows®) or- mjs_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
                            matlabroot\toolbox\parallel\binmatlabrootC:\Program Files\MATLAB\R2025b. 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 -vhostnamemjs_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-bug-finder-server -batch -scheduler hostname|MJSName@hostname [options] [-mjs-username name]
- polyspaceserverroot- C:\Program Files\Polyspace Server\R2025b.
- hostname- MJSName- If you use the - startjobmanagercommand to start the MATLAB Job Scheduler,- MJSName- -name.
- 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 Bug Finder Analysis Engine Options. 
- 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 -upload (Polyspace Access)