RunConfiguration Klass
Representerar konfiguration för experimentkörningar som riktar sig till olika beräkningsmål i Azure Machine Learning.
RunConfiguration-objektet kapslar in den information som behövs för att skicka en träningskörning i ett experiment. Vanligtvis skapar du inte ett RunConfiguration-objekt direkt utan hämtar ett från en metod som returnerar det, till exempel submit -metoden för Experiment klassen.
RunConfiguration är en grundläggande miljökonfiguration som också används i andra typer av konfigurationssteg som är beroende av vilken typ av körning du utlöser. När du till exempel konfigurerar ett PythonScriptStepkan du komma åt stegets RunConfiguration-objekt och konfigurera Conda-beroenden eller komma åt miljöegenskaperna för körningen.
Exempel på körningskonfigurationer finns i Välj och använda ett beräkningsmål för att träna din modell.
Initiera en RunConfiguration med standardinställningarna.
- Arv
-
azureml._base_sdk_common.abstract_run_config_element._AbstractRunConfigElementRunConfiguration
Konstruktor
RunConfiguration(script=None, arguments=None, framework=None, communicator=None, conda_dependencies=None, _history_enabled=None, _path=None, _name=None, command=None)
Parametrar
Name | Description |
---|---|
script
|
Den relativa sökvägen till Python-skriptfilen. Filsökvägen är relativ till källkatalogen som skickas till submit. Standardvärde: None
|
arguments
|
Kommandoradsargument för Python-skriptfilen. Standardvärde: None
|
framework
|
Det målramverk som används i körningen. Ramverk som stöds är Python, PySpark, TensorFlow och PyTorch. Standardvärde: None
|
communicator
|
Den kommunikatör som används i körningen. De kommunikatorer som stöds är None, ParameterServer, OpenMpi och IntelMpi. Tänk på att OpenMpi kräver en anpassad avbildning med OpenMpi installerat. Använd ParameterServer eller OpenMpi för AmlCompute-kluster. Använd IntelMpi för distribuerade träningsjobb. Standardvärde: None
|
conda_dependencies
|
När det lämnas kvar vid standardvärdet False skapar systemet en Python-miljö, som innehåller de paket som anges i Standardvärde: None
|
auto_prepare_environment
Obligatorisk
|
DEPRECATED. Den här inställningen används inte längre. |
command
|
Kommandot som ska skickas för körningen. Kommandoegenskapen kan också användas i stället för skript/argument. Egenskaper för både kommando och skript/argument kan inte användas tillsammans för att skicka en körning. Skicka en skriptfil med hjälp av kommandoegenskapen ['python', 'train.py', '-arg1', arg1_val] Köra ett faktiskt kommando - ['ls'] Standardvärde: None
|
_history_enabled
|
Standardvärde: None
|
_path
|
Standardvärde: None
|
_name
|
Standardvärde: None
|
Kommentarer
Vi skapar maskininlärningssystem vanligtvis för att lösa ett specifikt problem. Vi kan till exempel vara intresserade av att hitta den bästa modellen som rangordnar webbsidor som kan användas som sökresultat som motsvarar en fråga. Vår sökning efter den bästa maskininlärningsmodellen kan kräva att vi testar olika algoritmer eller överväger olika parameterinställningar osv.
I Azure Machine Learning SDK använder vi begreppet experiment för att fånga upp uppfattningen att olika träningskörningar är relaterade till det problem som de försöker lösa. En Experiment fungerar sedan som en logisk container för dessa träningskörningar, vilket gör det enklare att spåra förloppet mellan träningskörningar, jämföra två träningskörningar direkt osv.
RunConfiguration kapslar in de körningsmiljöinställningar som krävs för att skicka en träningskörning i ett experiment. Den fångar både den delade strukturen för träningskörningar som är utformade för att lösa samma maskininlärningsproblem, samt skillnaderna i konfigurationsparametrar (t.ex. inlärningstakt, förlustfunktion osv.) som skiljer distinkta träningskörningar från varandra.
I vanliga träningsscenarier används RunConfiguration genom att skapa ett ScriptRunConfig objekt som paketeras tillsammans med ett RunConfiguration-objekt och ett körningsskript för träning.
Konfigurationen av RunConfiguration omfattar:
Paketering av experimentkällans katalog inklusive det skickade skriptet.
Ange kommandoradsargumenten för det skickade skriptet.
Konfigurera sökvägen för Python-tolken.
Hämta Conda-konfiguration för för att hantera programberoenden. Jobböverföringsprocessen kan använda konfigurationen för att etablera en tillfällig Conda-miljö och starta programmet i. De temporära miljöerna cachelagras och återanvänds i efterföljande körningar.
Valfri användning av Docker och anpassade basavbildningar.
Valfritt val av att skicka experimentet till flera typer av Azure-beräkning.
Valfritt val av att konfigurera hur du materialiserar indata och laddar upp utdata.
Avancerade körningsinställningar för vanliga körningar som spark och tensorflow.
I följande exempel visas hur du skickar ett träningsskript på den lokala datorn.
from azureml.core import ScriptRunConfig, RunConfiguration, Experiment
# create or load an experiment
experiment = Experiment(workspace, "MyExperiment")
# run a trial from the train.py code in your current directory
config = ScriptRunConfig(source_directory='.', script='train.py',
run_config=RunConfiguration())
run = experiment.submit(config)
I följande exempel visas hur du skickar ett träningsskript i klustret med hjälp av kommandoegenskapen i stället för skript och argument.
from azureml.core import ScriptRunConfig, Experiment
# create or load an experiment
experiment = Experiment(workspace, 'MyExperiment')
# create or retrieve a compute target
cluster = workspace.compute_targets['MyCluster']
# create or retrieve an environment
env = Environment.get(ws, name='MyEnvironment')
# configure and submit your training run
config = ScriptRunConfig(source_directory='.',
command=['python', 'train.py', '--arg1', arg1_val],
compute_target=cluster,
environment=env)
script_run = experiment.submit(config)
Följande exempel visar hur du kör ett kommando i klustret.
from azureml.core import ScriptRunConfig, Experiment
# create or load an experiment
experiment = Experiment(workspace, 'MyExperiment')
# create or retrieve a compute target
cluster = workspace.compute_targets['MyCluster']
# create or retrieve an environment
env = Environment.get(ws, name='MyEnvironment')
# configure and submit your training run
config = ScriptRunConfig(source_directory='.',
command=['ls', '-l'],
compute_target=cluster,
environment=env)
script_run = experiment.submit(config)
Variabler
Name | Description |
---|---|
environment
|
Miljödefinitionen. Det här fältet konfigurerar Python-miljön. Den kan konfigureras för att använda en befintlig Python-miljö eller konfigurera för att konfigurera en temporär miljö för experimentet. Definitionen ansvarar också för att ange nödvändiga programberoenden. |
max_run_duration_seconds
|
Den maximala tid som tillåts för körningen. Systemet försöker automatiskt avbryta körningen om det tog längre tid än det här värdet. |
node_count
|
Antalet noder som ska användas för jobbet. |
priority
|
Jobbets prioritet för schemaläggningsprincipen. |
history
|
Konfigurationsavsnittet som används för att inaktivera och aktivera loggningsfunktioner för experimenthistorik. |
spark
|
När plattformen är inställd på PySpark används avsnittet Spark-konfiguration för att ange standard-SparkConf för det skickade jobbet. |
hdi
|
AVSNITTET FÖR HDI-konfiguration börjar gälla endast när målet är inställt på en Azure HDI-beräkning. HDI-konfigurationen används för att ange YARN-distributionsläget. Standarddistributionsläget är kluster. |
docker
|
Avsnittet Docker-konfiguration används för att ange variabler för Docker-miljön. |
tensorflow
|
Konfigurationsavsnittet som används för att konfigurera distribuerade TensorFlow-parametrar.
Den här parametern börjar gälla endast när |
mpi
|
Konfigurationsavsnittet som används för att konfigurera distribuerade MPI-jobbparametrar.
Den här parametern börjar gälla endast när är inställd på |
pytorch
|
Konfigurationsavsnittet som används för att konfigurera distribuerade PyTorch-jobbparametrar.
Den här parametern börjar gälla endast när är inställd på |
paralleltask
|
Konfigurationsavsnittet som används för att konfigurera distribuerade parallella jobbparametrar.
Den här parametern börjar gälla endast när är inställd på |
data_references
|
Alla datakällor är tillgängliga för körningen under körningen baserat på varje konfiguration. För varje objekt i ordlistan är nyckeln ett namn som anges för datakällan och värdet är en DataReferenceConfiguration. |
data
|
Alla data som ska vara tillgängliga för körningen under körningen. |
datacaches
|
<xref:buildin.list>[DatacacheConfiguration]
Alla data för att göra datacache tillgängligt för körningen under körningen. |
output_data
|
Alla utdata som ska laddas upp och spåras för den här körningen. |
source_directory_data_store
|
Stöddatalager för projektresursen. |
amlcompute
|
Information om beräkningsmålet som ska skapas under experimentet. Konfigurationen börjar bara gälla när beräkningsmålet är AmlCompute. |
kubernetescompute
|
Information om beräkningsmålet som ska användas under experimentet. Konfigurationen börjar bara gälla när beräkningsmålet är KubernetesCompute. |
services
|
Slutpunkter för interaktiv med beräkningsresursen. Tillåtna slutpunkter är Jupyter, JupyterLab, VS Code, Tensorboard, SSH och anpassade portar. |
Metoder
delete |
Ta bort en körningskonfigurationsfil. Genererar en UserErrorException om konfigurationsfilen inte hittas. |
load |
Läs in en tidigare sparad körningskonfigurationsfil från en diskfil. Om Om |
save |
Spara RunConfiguration på en fil på disken. En UserErrorException aktiveras när:
Om Om Den här metoden är användbar när du redigerar konfigurationen manuellt eller när du delar konfigurationen med CLI. |
delete
Ta bort en körningskonfigurationsfil.
Genererar en UserErrorException om konfigurationsfilen inte hittas.
static delete(path, name)
Parametrar
Name | Description |
---|---|
path
Obligatorisk
|
En användare har valt rotkatalog för körningskonfigurationer. Detta är vanligtvis Git-lagringsplatsen eller Python-projektets rotkatalog. Konfigurationen tas bort från en underkatalog med namnet .azureml. |
name
Obligatorisk
|
Namnet på konfigurationsfilen. |
Undantag
Typ | Description |
---|---|
UserErrorException
|
load
Läs in en tidigare sparad körningskonfigurationsfil från en diskfil.
Om path
pekar på en fil läses RunConfiguration in från filen.
Om path
pekar på en katalog, som ska vara en projektkatalog, läses RunConfiguration in från <path>/.azureml/<name> eller <path>/aml_config/<name>.
static load(path, name=None)
Parametrar
Name | Description |
---|---|
path
Obligatorisk
|
En användare har valt rotkatalog för körningskonfigurationer. Detta är vanligtvis Git-lagringsplatsen eller Python-projektets rotkatalog. För bakåtkompatibilitet läses konfigurationen också in från .azureml eller aml_config underkatalog. Om filen inte finns i dessa kataloger läses filen in från den angivna sökvägen. |
name
|
Namnet på konfigurationsfilen. Standardvärde: None
|
Returer
Typ | Description |
---|---|
Körningskonfigurationsobjektet. |
Undantag
Typ | Description |
---|---|
UserErrorException
|
save
Spara RunConfiguration på en fil på disken.
En UserErrorException aktiveras när:
RunConfiguration kan inte sparas med det angivna namnet.
Ingen
name
parameter har angetts.Parametern
path
är ogiltig.
Om path
har formatet <dir_path>/<file_name>, där <dir_path> är en giltig katalog, sparas RunConfiguration i <dir_path>/<file_name>.
Om path
pekar på en katalog, som ska vara en projektkatalog, sparas RunConfiguration på <path>/.azureml/<name> eller <path>/aml_config/<name>.
Den här metoden är användbar när du redigerar konfigurationen manuellt eller när du delar konfigurationen med CLI.
save(path=None, name=None, separate_environment_yaml=False)
Parametrar
Name | Description |
---|---|
separate_environment_yaml
|
Anger om conda-miljökonfigurationen ska sparas. Om det är sant sparas Conda-miljökonfigurationen i en YAML-fil med namnet "environment.yml". Standardvärde: False
|
path
|
En användare har valt rotkatalog för körningskonfigurationer. Detta är vanligtvis Git-lagringsplatsen eller Python-projektets rotkatalog. Konfigurationen sparas i en underkatalog med namnet .azureml. Standardvärde: None
|
name
|
[Krävs] Namnet på konfigurationsfilen. Standardvärde: None
|
Returer
Typ | Description |
---|---|
Undantag
Typ | Description |
---|---|
UserErrorException
|
Attribut
auto_prepare_environment
Hämta parametern auto_prepare_environment
. Det här är en inaktuell och oanvänd inställning.
environment_variables
target
Hämta beräkningsmål där jobbet är schemalagt för körning.
Standardmålet är "lokalt" som refererar till den lokala datorn. Tillgängliga molnberäkningsmål kan hittas med hjälp av funktionen compute_targets.
Returer
Typ | Description |
---|---|
Målnamnet |