-
Notifications
You must be signed in to change notification settings - Fork 285
Multiple Instances
- ✅ 2.1* | ⛔ 2.0 | ⛔ 1.9 | ...
Explain the caveats and workarounds to running QZ Tray on a multi-user workstation.
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.
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"
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
tostealWebsocket=true
.
-- OR -- - Administrators can edit
qz-tray.properties
and add a linewebsocket.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 ofqz:launch
)