Skip to main content

Serverkonfiguration

Standardkonfiguration

Die Installationsverzeichnis\appsettings.json wird in der Regel in .NET-Anwendungen verwendet, insbesondere in ASP.NET Core-Anwendungen. Sie dient dazu, Konfigurationseinstellungen für die Anwendung bereitzustellen. Die Datei enthält eine strukturierte Auflistung von Schlüssel-Wert-Paaren, die verschiedene Aspekte der Anwendung konfigurieren können.

Sie kann beispielsweise zur Konfiguration der Datenbankverbindung, Einstellungen für Drittanbieterdiensten oder gar für allgemeine Anwendungseinstellungen verwendet werden.

Die appsettings.json kann auch hierarchisch strukturiert sein. Das bedeutet, dass sie Abschnitte und Untereinstellungen enthalten kann. Dies ermöglicht eine bessere Organisation und Trennung der verschiedenen Konfigurationselemente.

Es ist zu beachten, dass die Verwendung der appsettings.json nicht auf .NET-Anwendungen beschränkt ist. Andere Frameworks und Sprachen, wie zum Beispiel Java oder Python, können ebenfalls ähnliche Konfigurationsdateien verwenden, um Einstellungen für ihre Anwendungen bereitzustellen.

Im Folgenden wird ein kleines Beispiel dargestellt:

{
  "Application": {
    "ApplicationTitle": "Data Connector",
    "HelpUrl": "https://docs.smcteam.de/books/data-connector"
  },
  "Caching": {
    "ExpirationTimeSeconds": 1800
  },
  "Tasks": {
    "UpdateInterval": 1,
    "MaxToastMessages": 3,
    "ToastNotificationDuration": 20
  },
  "ConnectionStrings": {
    "DefaultConnection": "Server=YOURSERVER;Database=DataConnector;Trusted_Connection=True;TrustServerCertificate=True;",
    "HangfireConnection": "Server=YOURSERVER;Database=DataConnector;Trusted_Connection=True;TrustServerCertificate=True;"
  },
  "DatabaseGenerator": {
    "ConnectionString": "Server=YOURSERVER;Database=DataConnector;Trusted_Connection=True;TrustServerCertificate=True;",
    "DefaultSchemaName": "dco",
    "MappingTablePrefix": "",
    "MappingTablePostfix": "Map"
  },
  "RestApi": {
    "RequestBodyReplacementChar": "$"
  },
  "Hangfire": {
    "SchemaName": "DcHangfire"
  },
  "AllowedHosts": "*",
  "Logging": {
    "LogLevel": {
      "Default": "Information",
      "Microsoft": "Warning",
      "Microsoft.Hosting.Lifetime": "Information",
      "Hangfire": "Information"
    }
  },
  "ConnectionStrings"Azure": {
    "DefaultConnection"Enabled": false,
    "Instance": "Server=myServerAddress;Database=myDatabase;Userhttps://login.microsoftonline.com/",
    Id=myUsername;Password=myPassword;"ClientId": "",
    "TenantId": "",
    "CallbackPath": "/signin-oidc"
  },
  "Serilog": {
    "MinimumLevel": {
      "Default": "Information",
      "Override": {
        "Microsoft": "Warning",
        "Microsoft.Hosting.Lifetime": "Information"
      }
    },
    "Using": [
      "Serilog.Expressions"
    ],
    "Enrich": [
      "WithEnvironmentUserName",
      "FromLogContext"
    ],
    "Properties": {
      "ApplicationName": "Data Connector"
    },
    "WriteTo": [
      {
        "Name": "Console",
        "Args": {
          "theme": "Serilog.Sinks.SystemConsole.Themes.AnsiConsoleTheme::Code, Serilog.Sinks.Console",
          "formatter": {
            "type": "Serilog.Templates.ExpressionTemplate, Serilog.Expressions",
            "template": "[{@t:HH:mm:ss} {@l:u3}] <s:{SourceContext}> {@m}\n{@x}"
          }
        }
      },
      {
        "Name": "Async",
        "Args": {
          "configure": [
            {
              "Name": "File",
              "Args": {
                "formatter": {
                  "type": "Serilog.Templates.ExpressionTemplate, Serilog.Expressions",
                  "template": "<![LOG[{EnvironmentUserName} --> {@l:u}: {@m}\n{@x}]LOG]!><time=\"{@t:HH:mm:ss.fffffff}\" date=\"{@t:MM-dd-yyyy}\" component=\"{ApplicationName} {Version}\" context=\"\" type=\"{#if @l = 'Error'}3{#else if @l = 'Warning'}2{#else}1{#end}\" thread=\"\" file=\"\">\n"

                },
                "path": "data_connector.log",
                "shared": "true",
                "fileSizeLimitBytes": "1000000",
                "rollOnFileSizeLimit": true,
                "flushToDiskInterval": "1"
              }
            }
          ]
        }
      }
    ]
  }
}

In diesem Beispiel sind verschiedene Einstellungen enthalten:

  • Unter dem Schlüssel "Logging" befinden sich verschiedene Log-Level-Einstellungen für verschiedene Log-Kategorien.
  • Unter dem Schlüssel "ConnectionStrings" ist eine Verbindungszeichenfolge zur Datenbank angegeben.

Dies ist nur ein einfaches Beispiel. Die tatsächlichen Konfigurationselemente können je nach Anwendungsanforderungen variieren. Die "appsettings.json"-Datei kann beliebig erweitert und angepasst werden, um die spezifischen Einstellungen Ihrer Anwendung zu definieren.

Um das sichere Anpassen von Werten zu gewährleisten, wurde das Programm AppSettings Json Editor geschrieben.

Auf der Seite von Microsoft kann man mehr über Konfigurationen nachlesen.