Accesso con privilegi elevati per comandi dotnet
Le procedure consigliate per lo sviluppo di software supportano gli sviluppatori nella scrittura di software con una richiesta minima di privilegi. Per alcuni software, ad esempio gli strumenti di monitoraggio delle prestazioni, è però necessaria un'autorizzazione di amministratore a causa delle regole del sistema operativo. Questo documento descrive gli scenari supportati per la scrittura di questo tipo di software usando .NET Core.
I comandi seguenti possono essere eseguiti con privilegi elevati:
- Comandi
dotnet tool
, ad esempio dotnet tool install. dotnet run --no-build
dotnet-core-uninstall
Non è consigliabile eseguire altri comandi con privilegi elevati. In particolare, non è consigliabile elevare i privilegi con comandi che usano MSBuild, ad esempio dotnet restore, dotnet build e dotnet run. Il problema principale è la gestione delle autorizzazioni, quando un utente passa da account radice ad account con restrizioni dopo l'invio di comandi dotnet. Può succedere che un utente con restrizioni non acceda al file creato da un utente ROOT. Questa situazione può essere risolta in diversi modi che non è necessario analizzare per primi.
È possibile eseguire i comandi come radice, purché non si esegua la transizione tra radice e account con restrizioni. I contenitori Docker vengono ad esempio eseguiti come radice per impostazione predefinita, pertanto hanno questa caratteristica.
Installazione dello strumento globale
Le istruzioni seguenti illustrano il modo consigliato per installare, eseguire e disinstallare gli strumenti per .NET che richiedono autorizzazioni di livello elevato per essere eseguiti.
Installare lo strumento.
Se la cartella %ProgramFiles%\dotnet-tools
è già esistente, eseguire le operazioni seguenti per verificare se il gruppo "Utenti" dispone dell'autorizzazione per scrivere o modificare tale directory:
- Fare clic con il pulsante destro del mouse sulla cartella
%ProgramFiles%\dotnet-tools
e selezionare Proprietà. Verrà visualizzata la finestra di dialogo Proprietà comuni. - Selezionare la scheda Sicurezza. In Nomi gruppi o utenti, controllare se il gruppo "Utenti" ha l'autorizzazione per scrivere o modificare la directory.
- Se il gruppo “Utenti” non può scrivere o modificare la directory, usare un nome di directory diverso durante l’installazione degli strumenti anziché dotnet-tools.
Per installare gli strumenti, eseguire il comando seguente al prompt con privilegi elevati. Verrà creata la cartella dotnet-tools durante l'installazione.
dotnet tool install PACKAGEID --tool-path "%ProgramFiles%\dotnet-tools".
Eseguire lo strumento globale
Opzione 1: usare il percorso completo al prompt con privilegi elevati:
"%ProgramFiles%\dotnet-tools\TOOLCOMMAND"
Opzione 2: aggiungere la cartella appena creata a %Path%
. È necessario eseguire questa operazione una sola volta.
setx Path "%Path%;%ProgramFiles%\dotnet-tools\"
Eseguire con il comando seguente:
TOOLCOMMAND
Disinstallare lo strumento globale
Al prompt con privilegi elevati digitare il comando seguente:
dotnet tool uninstall PACKAGEID --tool-path "%ProgramFiles%\dotnet-tools"
Strumenti locali
L'ambito degli strumenti locali è definito in base ad albero di sottodirectory e utente. Quando vengono eseguiti con privilegi elevati, gli strumenti locali condividono un ambiente utente con restrizioni nell'ambiente con privilegi elevati. In Linux e macOS i file vengono di conseguenza impostati con accesso riservato solo all'utente ROOT. Se l'utente passa nuovamente a un account con restrizioni, l'utente non potrà più accedere o scrivere i file. Non è quindi consigliato installare strumenti che richiedono elevazione come gli strumenti locali. Usare invece l'opzione --tool-path
e seguire le linee guida precedenti per gli strumenti globali.
Elevazione durante lo sviluppo
Durante lo sviluppo potrebbe essere necessario l'accesso con privilegi elevati per testare l'applicazione. Questo scenario è ad esempio comune per le app IoT. È consigliabile compilare l'applicazione senza elevazione ed eseguirla poi elevando i privilegi. Esistono alcuni modelli come quelli riportati di seguito:
Uso di un eseguibile generato, che offre le prestazioni migliori in fase di avvio:
dotnet build sudo ./bin/Debug/netcoreapp3.0/APPLICATIONNAME
Uso del comando dotnet run con il flag
—no-build
per evitare di generare nuovi file binari:dotnet build sudo dotnet run --no-build