Following is the default configuration. With this setting, the external API may be called with any of the IPs within the range
To achieve this objective, I chose to use NAT Gateway and related components. we need to complete the following tasks in order to implement the solution:
- Integrate the Web App with a Subnet in a Virtual Network
- Create a Public IP
- Create and Configure a NAT Gateway
- Associate the Web App with the NAT Gateway
- Test
If we had the external API or resource within a private network (e.g On-Premises) we could've used Hybrid Connections.
Let's discuss the implementation of each item
1. Integrate the Web App with a Subnet in a Virtual Network
Create a virtual network and a subnet or consume an existing virtual network
Next, navigate to your Web App, go to the Networking section, and enable Virtual Network Integration to connect it to the designated subnet.
2. Create a Public IP
3.Create and Configure a NAT Gateway
Specify Outbound IP. We can specify multiple public IP addresses if we want once NAT Gateway is configured
Specify the Subnet
4.Associate the Web App with the NAT Gateway
Since resources are within the same network, the NAT Gateway will be automatically configured with your Web App
5. Test
Let's test the solution. To validate the setup, I deployed a sample .NET API that calls an external service, which returns the calling IP address.
[ApiController]
[Route("api/[controller]")]
public class GatewayTestController : ControllerBase
{
private readonly HttpClient _httpClient;
public GatewayTestController(HttpClient httpClient)
{
_httpClient = httpClient;
}
[HttpGet]
public async Task GetOutboundIp()
{
// Call external API over internet
var response = await _httpClient.GetAsync("https://httpbin.org/ip");
if (!response.IsSuccessStatusCode)
{
return StatusCode((int)response.StatusCode, "Failed to get outbound IP");
}
var callerIP = await response.Content.ReadAsStringAsync();
return Ok(callerIP);
}
}
Following is the response I get. This matches exactly with the Public IP I provisioned
No comments:
Post a Comment