Skip to content

Multiple Instances

Tres Finocchiaro edited this page Aug 10, 2021 · 12 revisions

Compatibility

  • ✅ 2.1* | ⛔ 2.0 | ⛔ 1.9 | ...

Objective

Explain the caveats and workarounds to running QZ Tray on a multi-user workstation.

Singleton

QZ Tray is a singleton application and it cannot support multiple simultaneous instances on the same machine because QZ Tray uses a localhost websocket connection (wss://) from the browser to a single port on the PC. If a second instance of QZ Tray were allowed, the websocket would succeed to the first available port, rendering it useless.

Some options to help with this limitation:

  • If your environment requires multiple users using QZ Tray simultaneously, consider setting up a dedicated Print Server for this.
  • If your environment only requires one user using QZ Tray at a time, see Stealing Instance below.

Symptoms

Since QZ Tray will start automatically with the computer, this singleton limitation can pose a problem on a shared workstation. By default, QZ Tray will attempt to start automatically upon login however if another user is running QZ Tray, it will detect the other instance and quietly shutdown. This is usually observed by the following behavior:

"QZ Tray icon disappears from the system tray"

"When I double-click on the QZ Tray icon, it shows up for a second and then goes away"

"There's link on the web page to start QZ Tray (e.g. qz:launch but it doesn't work if someone else is signed onto the computer"

Stealing Instance

Since 2.1.4, QZ Tray supports stealing another instance, which can be helpful on shared workstations. There are several ways to toggle this behavior on:

  • Administrators can set an environment variable called QZ_OPTS to stealWebsocket=true.
    -- OR --
  • Administrators can edit qz-tray.properties and add a line websocket.steal=true. This file can be found by clicking QZ Tray, Advanced, Diagnostic, Browse App folder (secure environments may store this file in the User or Shared folder)
    -- OR --
  • Administrators can start QZ Tray with the command-line flag --steal
    -- OR --
  • Web developers can start QZ Tray with the hyperlink qz:steal (instead of qz:launch)
Clone this wiki locally