Udostępnij za pośrednictwem


Jak sparametryzować pliki konfiguracji w usłudze Service Fabric

W tym artykule pokazano, jak sparametryzować plik konfiguracji w usłudze Service Fabric. Jeśli nie znasz jeszcze podstawowych pojęć związanych z zarządzaniem aplikacjami dla wielu środowisk, zobacz Zarządzanie aplikacjami dla wielu środowisk.

Procedura parametryzacji plików konfiguracji

W tym przykładzie zastąpisz wartość konfiguracji przy użyciu parametrów we wdrożeniu aplikacji.

  1. <Otwórz plik MyService>\PackageRoot\Config\Settings.xml w projekcie usługi.

  2. Ustaw nazwę i wartość parametru konfiguracji, na przykład rozmiar pamięci podręcznej równy 25, dodając następujący kod XML:

     <Section Name="MyConfigSection">
       <Parameter Name="CacheSize" Value="25" />
     </Section>
    
  3. Zapisz i zamknij plik.

  4. <Otwórz plik MyApplication>\ApplicationPackageRoot\ApplicationManifest.xml.

  5. W pliku ApplicationManifest.xml zadeklaruj parametr i wartość domyślną w elemecie Parameters . Zaleca się, aby nazwa parametru zawierała nazwę usługi (na przykład "MyService").

     <Parameters>
       <Parameter Name="MyService_CacheSize" DefaultValue="80" />
     </Parameters>
    
  6. ServiceManifestImport W sekcji pliku ApplicationManifest.xml dodaj ConfigOverrides element iConfigOverride, odwołując się do pakietu konfiguracji, sekcji i parametru.

     <ConfigOverrides>
       <ConfigOverride Name="Config">
           <Settings>
             <Section Name="MyConfigSection">
                 <Parameter Name="CacheSize" Value="[MyService_CacheSize]" />
             </Section>
           </Settings>
       </ConfigOverride>
     </ConfigOverrides>
    

Uwaga

W przypadku, gdy dodajesz ConfigOverride, usługa Service Fabric zawsze wybiera parametry aplikacji lub wartość domyślną określoną w manifeście aplikacji.

Uzyskiwanie dostępu do sparametryzowanych konfiguracji w kodzie

Dostęp do konfiguracji można uzyskać programowo w pliku settings.xml. Weźmy na przykład następujący plik XML konfiguracji:

<Settings
	xmlns:xsd="http://www.w3.org/2001/XMLSchema"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xmlns="http://schemas.microsoft.com/2011/01/fabric">
	<!-- Add your custom configuration sections and parameters here -->
	<Section Name="MyConfigSection">
		<Parameter Name="MyParameter" Value="Value1" />
	</Section>
</Settings>     

Użyj następującego kodu, aby uzyskać dostęp do parametrów:

CodePackageActivationContext context = FabricRuntime.GetActivationContext();
var configSettings = context.GetConfigurationPackageObject("Config").Settings;
var data = configSettings.Sections["MyConfigSection"];
foreach (var parameter in data.Parameters)
{
  ServiceEventSource.Current.ServiceMessage(this.Context, "Working-{0} - {1}", parameter.Name, parameter.Value);
}

W tym miejscu Parameter.Name będzie wartość MyParameter i Parameter.Value będzie wartością Value1

Następne kroki

Aby uzyskać informacje o innych funkcjach zarządzania aplikacjami, które są dostępne w programie Visual Studio, zobacz Zarządzanie aplikacjami usługi Service Fabric w programie Visual Studio.