title | services | ms.date | ms.topic | description | keywords |
---|---|---|---|---|---|
Running multiple dependent services: .NET Core & Visual Studio Code |
azure-dev-spaces |
11/21/2018 |
tutorial |
This tutorial shows you how to use Azure Dev Spaces and Visual Studio Code to debug a multi-service .NET Core application on Azure Kubernetes Service |
Docker, Kubernetes, Azure, AKS, Azure Kubernetes Service, containers, Helm, service mesh, service mesh routing, kubectl, k8s |
In this tutorial, you'll learn how to develop multi-service applications using Azure Dev Spaces, along with some of the added benefits that Dev Spaces provides.
In this section, you will create a second service, mywebapi
, and have webfrontend
call it. Each service will run in separate containers. You'll then debug across both containers.
For the sake of time, let's download sample code from a GitHub repository. Go to https://github.com/Azure/dev-spaces and select Clone or Download to download the GitHub repository. The code for this section is in samples/dotnetcore/getting-started/mywebapi
.
- Open the folder
mywebapi
in a separate VS Code window. - Open the Command Palette (using the View | Command Palette menu), and use auto-complete to type and select this command:
Azure Dev Spaces: Prepare configuration files for Azure Dev Spaces
. This command is not to be confused with theazds prep
command, which configures the project for deployment. - Hit F5, and wait for the service to build and deploy. You'll know it's ready when the Application started. Press Ctrl+C to shut down. message appears in the debug console.
- The endpoint URL will look something like
http://localhost:<portnumber>
. Tip: The VS Code status bar will turn orange and display a clickable URL. It might seem like the container is running locally, but actually it is running in our dev space in Azure. The reason for the localhost address is becausemywebapi
has not defined any public endpoints and can only be accessed from within the Kubernetes instance. For your convenience, and to facilitate interacting with the private service from your local machine, Azure Dev Spaces creates a temporary SSH tunnel to the container running in Azure. - When
mywebapi
is ready, open your browser to the localhost address. Append/api/values
to the URL to invoke the default GET API for theValuesController
. - If all the steps were successful, you should be able to see a response from the
mywebapi
service.
Let's now write code in webfrontend
that makes a request to mywebapi
.
-
Switch to the VS Code window for
webfrontend
. -
Replace the code for the About method in
HomeController.cs
:public async Task<IActionResult> About() { ViewData["Message"] = "Hello from webfrontend"; using (var client = new System.Net.Http.HttpClient()) { // Call *mywebapi*, and display its response in the page var request = new System.Net.Http.HttpRequestMessage(); request.RequestUri = new Uri("http://mywebapi/api/values/1"); if (this.Request.Headers.ContainsKey("azds-route-as")) { // Propagate the dev space routing header request.Headers.Add("azds-route-as", this.Request.Headers["azds-route-as"] as IEnumerable<string>); } var response = await client.SendAsync(request); ViewData["Message"] += " and " + await response.Content.ReadAsStringAsync(); } return View(); }
The preceding code example forwards the azds-route-as
header from the incoming request to the outgoing request. You'll see later how this helps teams with collaborative development.
- At this point,
mywebapi
should still be running with the debugger attached. If it is not, hit F5 in themywebapi
project. - Set a breakpoint inside the
Get(int id)
method that handlesapi/values/{id}
GET requests. This is around line 23 in the Controllers/ValuesController.cs file. - In the
webfrontend
project, set a breakpoint just before it sends a GET request tomywebapi/api/values
. This is around line 32 in the Controllers/HomeController.cs file that you modified in the previous section. - Hit F5 in the
webfrontend
project. - Invoke the web app, and step through code in both services.
- In the web app, the About page will display a message concatenated by the two services: "Hello from webfrontend and Hello from mywebapi."
You now have a multi-container application where each container can be developed and deployed separately.
[!div class="nextstepaction"] Learn about team development in Dev Spaces