Guarda una demo×
×

Guarda NinjaOne in azione!

Inviando questo modulo, accetto La politica sulla privacy di NinjaOne.

Come utilizzare PowerShell per cancellare le code di stampa

Tutti noi ci affidiamo alle stampanti, sia negli uffici sia quando lavoriamo da remoto. Tuttavia, per quanto siano essenziali, le stampanti possono essere a volte esigenti. Per i professionisti IT e i Managed Service Provider (MSP), mantenere l’efficienza dei server di stampa è molto importante. Quindi quando si presentano problemi con le stampanti come la necessità di cancellare le code di stampa, disporre di un metodo efficace per risolverli diventa prezioso. 

Informazioni sulle code di stampa 

La coda di stampa è un’area di archiviazione temporanea per i lavori di stampa in attesa di essere stampati. Quando si invia un documento ad una stampante, il documento non viene inviato direttamente all’hardware della stampante. Invece, il file viene prima inviato alla coda di stampa. Da qui, la coda di stampa gestisce in modo efficiente questi lavori, inviandoli alla stampante quando sono pronti. 

Tuttavia, come ogni sistema, la coda di stampa può presentare dei problemi. Forse un particolare lavoro si blocca, impedendo l’elaborazione dei lavori successivi. Forse una stampante non è in linea e la coda si accumula. Queste interruzioni possono causare ritardi e inefficienze operative. 

È qui che lo script PowerShell per cancellare le code di stampa discusso in questo post diventa importante. È progettato per cancellare le code di stampa e tutti i processi al suo interno, assicurando operazioni di stampa senza problemi. Per utilizzare lo script per cancellare le code di stampa, assicurati di avere i privilegi di amministratore. 

Lo script

#Requires -Version 5.1

<#
.SYNOPSIS
    Clears Print Queue for all printers
.DESCRIPTION
    Clears Print Queue for all printers.
    This script will stop the printer spooler service, clear all print jobs, and start the printer spooler service.
    If some print jobs are not cleared, then a reboot might be needed before running this script again.
.EXAMPLE
    No parameters needed
.OUTPUTS
    String
.NOTES
    Minimum OS Architecture Supported: Windows 10, Windows Server 2016
    Release Notes:
    Initial Release
    (c) 2023 NinjaOne
    By using this script, you indicate your acceptance of the following legal terms as well as our Terms of Use at https://www.ninjaone.com/terms-of-use.
    Ownership Rights: NinjaOne owns and will continue to own all right, title, and interest in and to the script (including the copyright). NinjaOne is giving you a limited license to use the script in accordance with these legal terms. 
    Use Limitation: You may only use the script for your legitimate personal or internal business purposes, and you may not share the script with another party. 
    Republication Prohibition: Under no circumstances are you permitted to re-publish the script in any script library or website belonging to or under the control of any other software provider. 
    Warranty Disclaimer: The script is provided “as is” and “as available”, without warranty of any kind. NinjaOne makes no promise or guarantee that the script will be free from defects or that it will meet your specific needs or expectations. 
    Assumption of Risk: Your use of the script is at your own risk. You acknowledge that there are certain inherent risks in using the script, and you understand and assume each of those risks. 
    Waiver and Release: You will not hold NinjaOne responsible for any adverse or unintended consequences resulting from your use of the script, and you waive any legal or equitable rights or remedies you may have against NinjaOne relating to your use of the script. 
    EULA: If you are a NinjaOne customer, your use of the script is subject to the End User License Agreement applicable to you (EULA).
.COMPONENT
    Printer
#>

[CmdletBinding()]
param ()

begin {
    function Test-IsElevated {
        $id = [System.Security.Principal.WindowsIdentity]::GetCurrent()
        $p = New-Object System.Security.Principal.WindowsPrincipal($id)
        $p.IsInRole([System.Security.Principal.WindowsBuiltInRole]::Administrator)
    }
}

process {
    if (-not (Test-IsElevated)) {
        Write-Error -Message "Access Denied. Please run with Administrator privileges."
        exit 1
    }
    Write-Host "Stopping print spooler service"
    $StopProcess = Start-Process -FilePath "C:WINDOWSsystem32net.exe" -ArgumentList "stop", "spooler" -Wait -NoNewWindow -PassThru
    # Exit Code 2 usually means the service is already stopped
    if ($StopProcess.ExitCode -eq 0 -or $StopProcess.ExitCode -eq 2) {
        Write-Host "Stopped print spooler service"
        # Sleep just in case the spooler service is taking some time to stop
        Start-Sleep -Seconds 10
        Write-Host "Clearing all print queues"
        Remove-Item -Path "$env:SystemRootSystem32spoolPRINTERS*" -Force -ErrorAction SilentlyContinue
        Write-Host "Cleared all print queues"

        Write-Host "Starting print spooler service"
        $StartProcess = Start-Process -FilePath "C:WINDOWSsystem32net.exe" -ArgumentList "start", "spooler" -Wait -NoNewWindow -PassThru
        if ($StartProcess.ExitCode -eq 0) {
            Write-Host "Started print spooler service"
        }
        else {
            Write-Host "Could not start Print Spooler service. net start spooler returned exit code of $($StartProcess.ExitCode)"
            exit 1
        }
    }
    else {
        Write-Host "Could not stop Print Spooler service. net stop spooler returned exit code of $($StopProcess.ExitCode)"
        exit 1
    }
    exit 0
}

end {}

 

Accedi a oltre 700 script nel Dojo di NinjaOne

Ottieni l’accesso

Implicazioni di sicurezza dello script per cancellare le code di stampa 

Sebbene lo script PowerShell per cancellare le code di stampa sia una manna per la gestione delle stesse, è essenziale essere consapevoli delle sue implicazioni per la sicurezza: 

  1. Privilegi di amministratore: Lo script per cancellare le code di stampa richiede i diritti di amministratore poiché interagisce con i servizi a livello di sistema, come lo spooler di stampa. Se non sei un amministratore, non dovresti eseguire questo script. 
  2. Potenziali vulnerabilità: Se non adeguatamente protetto, i malintenzionati potrebbero sfruttare lo script per cancellare le code di stampa, eliminando i lavori di stampa o addirittura interrompendo i servizi. Assicurati sempre che lo script per cancellare le code di stampa provenga da fonti affidabili e sia conservato in luoghi sicuri. 
  3. Consultazione: In caso di dubbi sulla sicurezza dello script per cancellare le code di stampa, è sempre consigliabile consultare un professionista IT della sicurezza. 

Altri suggerimenti rapidi per la risoluzione dei problemi della stampante 

Problemi con la stampante? Oltre all’utilizzo dello script PowerShell per cancellare le code di stampa, ecco alcuni passaggi generali per la risoluzione dei problemi: 

  1. Controllo dell’alimentazione: Assicurati che il cavo di alimentazione della stampante sia collegato e che il dispositivo sia acceso. 
  2. Connettività: Ricontrolla il collegamento della stampante al computer. 
  3. Pagina di prova: Stampa una pagina di prova per verificare il corretto funzionamento della stampante. 
  4. Riavvio: Spesso un semplice riavvio del computer e della stampante può risolvere molti problemi. 
  5. Supporto del produttore: Se i problemi persistono, si consiglia di contattare il produttore della stampante per ottenere assistenza specifica.

Considerazioni finali

Nel panorama dinamico dell’IT, gli strumenti che semplificano le operazioni e risolvono i problemi del mondo reale sono preziosi. Lo script PowerShell per cancellare le code di stampa è uno di questi strumenti, che garantisce operazioni di stampa efficienti e senza intoppi. Affronta sempre questi script con la consapevolezza del loro scopo, dei benefici e delle potenziali implicazioni.

Passi successivi

La creazione di un team IT efficiente ed efficace richiede una soluzione centralizzata che funga da principale strumento per la fornitura di servizi. NinjaOne consente ai team IT di monitorare, gestire, proteggere e supportare tutti i dispositivi, ovunque essi si trovino, senza la necessità di una complessa infrastruttura locale.

Per saperne di più su NinjaOne Endpoint Management, fai un tour dal vivo, o inizia la tua prova gratuita della piattaforma NinjaOne.

Ti potrebbe interessare anche

Termini e condizioni NinjaOne

Cliccando sul pulsante “Accetto” qui sotto, dichiari di accettare i seguenti termini legali e le nostre condizioni d’uso:

  • Diritti di proprietà: NinjaOne possiede e continuerà a possedere tutti i diritti, i titoli e gli interessi relativi allo script (compreso il copyright). NinjaOne ti concede una licenza limitata per l’utilizzo dello script in conformità con i presenti termini legali.
  • Limitazione d’uso: Puoi utilizzare lo script solo per legittimi scopi personali o aziendali interni e non puoi condividere lo script con altri soggetti.
  • Divieto di ripubblicazione: In nessun caso ti è consentito ripubblicare lo script in una libreria di script appartenente o sotto il controllo di un altro fornitore di software.
  • Esclusione di garanzia: Lo script viene fornito “così com’è” e “come disponibile”, senza garanzie di alcun tipo. NinjaOne non promette né garantisce che lo script sia privo di difetti o che soddisfi le tue esigenze o aspettative specifiche.
  • Assunzione del rischio: L’uso che farai dello script è da intendersi a tuo rischio. Riconosci che l’utilizzo dello script comporta alcuni rischi intrinseci, che comprendi e sei pronto ad assumerti.
  • Rinuncia e liberatoria: Non riterrai NinjaOne responsabile di eventuali conseguenze negative o indesiderate derivanti dall’uso dello script e rinuncerai a qualsiasi diritto legale o di equità e a qualsiasi rivalsa nei confronti di NinjaOne in relazione all’uso dello script.
  • EULA: Se sei un cliente NinjaOne, l’uso dello script è soggetto al Contratto di licenza con l’utente finale (EULA) applicabile.