Dela via


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 krävs för att skicka en träningskörning i ett experiment. Vanligtvis skapar du inte ett RunConfiguration-objekt direkt, men får ett från en metod som returnerar det, till exempel submit -metoden för Experiment klassen.

RunConfiguration är en basmiljö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änd ett beräkningsmål för att träna din modell.

Initiera en RunConfiguration med standardinställningarna.

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
str

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
str

Det målramverk som används i körningen. Ramverk som stöds är Python, PySpark, TensorFlow och PyTorch.

Standardvärde: None
communicator
str

Den kommunikatör som används i körningen. De kommunikatörer som stöds är None, ParameterServer, OpenMpi och IntelMpi. Tänk på att OpenMpi kräver en anpassad avbildning med OpenMpi installerad. 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 conda_dependencies. När värdet är sant kan en befintlig Python-miljö anges med inställningen python_interpreter.

Standardvärde: None
auto_prepare_environment
Obligatorisk

DEPRECATED. Den här inställningen används inte längre.

command
list[str] eller str

Kommandot som ska skickas för körningen. Kommandoegenskapen kan också användas i stället för skript/argument. Både kommando- och skript-/argumentegenskaper kan inte användas tillsammans för att skicka en körning. Så här skickar du en skriptfil med hjälp av kommandoegenskapen ['python', 'train.py', '-arg1', arg1_val] För att 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 hanteras 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 konfigurationsparametrarna (t.ex. inlärningshastighet, 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 att hantera programberoenden. Processen för att skicka jobb 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örningsmiljöer 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
int

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
int

Antalet noder som ska användas för jobbet.

priority
int

Prioriteten för jobbet 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 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 träder endast i kraft när framework är inställd på TensorFlow och parameterservern communicator . AmlCompute är den enda beräkning som stöds för den här konfigurationen.

mpi

Konfigurationsavsnittet som används för att konfigurera distribuerade MPI-jobbparametrar. Den här parametern börjar gälla endast när framework är inställd på Python och communicator till OpenMpi eller IntelMpi. AmlCompute är den enda beräkningstyp som stöds för den här konfigurationen.

pytorch

Konfigurationsavsnittet som används för att konfigurera distribuerade PyTorch-jobbparametrar. Den här parametern börjar gälla endast när framework är inställd på PyTorch och communicator till Nccl eller Gloo. AmlCompute är den enda beräkningstyp som stöds för den här konfigurationen.

paralleltask

Konfigurationsavsnittet som används för att konfigurera distribuerade parallella jobbparametrar. Den här parametern börjar gälla endast när framework är inställt på Python och communicator till ParallelTask. AmlCompute är den enda beräkningstyp som stöds för den här konfigurationen.

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 ges till 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
str

Stöddatalagringen för projektresursen.

amlcompute

Information om beräkningsmålet som ska skapas under experimentet. Konfigurationen börjar gälla först när beräkningsmålet är AmlCompute.

kubernetescompute

Information om beräkningsmålet som ska användas under experimentet. Konfigurationen börjar gälla först när beräkningsmålet är KubernetesCompute.

services

Slutpunkter till interaktiva 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 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>.

save

Spara RunConfiguration i en fil på disken.

A UserErrorException utlöses när:

  • Det går inte att spara RunConfiguration med det angivna namnet.

  • Ingen name parameter har angetts.

  • Parametern path är ogiltig.

Om path är av formatet <dir_path>/<file_name>, där <dir_path> är en giltig katalog, sparas RunConfiguration på <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.

delete

Ta bort en körningskonfigurationsfil.

Genererar en UserErrorException om konfigurationsfilen inte hittas.

static delete(path, name)

Parametrar

Name Description
path
Obligatorisk
str

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
str

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
str

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
str

Namnet på konfigurationsfilen.

Standardvärde: None

Returer

Typ Description

Körningskonfigurationsobjektet.

save

Spara RunConfiguration i en fil på disken.

A UserErrorException utlöses när:

  • Det går inte att spara RunConfiguration med det angivna namnet.

  • Ingen name parameter har angetts.

  • Parametern path är ogiltig.

Om path är av formatet <dir_path>/<file_name>, där <dir_path> är en giltig katalog, sparas RunConfiguration på <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 sant sparas Conda-miljökonfigurationen i en YAML-fil med namnet "environment.yml".

Standardvärde: False
path
str

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
str

[Krävs] Namnet på konfigurationsfilen.

Standardvärde: None

Returer

Typ Description

Attribut

auto_prepare_environment

Hämta parametern auto_prepare_environment . Det här är en inaktuell och oanvänd inställning.

environment_variables

Miljövariabler för körning.

Returer

Typ Description

Körningsvariabler

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 finns med hjälp av funktionen compute_targets.

Returer

Typ Description
str

Målnamnet