Configure the F5 BIG-IP as an Explicit Forward Web Proxy Using LTM
In a previous article, I provided a guide on using F5's Access Policy Manager (APM) and Secure Web Gateway (SWG) to provide forward web proxy services. While that guide was for organizations that are looking to provide secure internet access for their internal users, URL filtering as well as securing against both inbound and outbound malware, this guide will use only F5's Local Traffic Manager to allow internal clients external internet access.
This week I was working with F5's very talented professional services team and we were presented with a requirement to allow workstation agents internet access to known secure sites to provide logs and analytics. Of course, this capability can be used to meet a number of other use cases, this was a real-world use case I wanted to share. So with that, let's get to it!
Creating a DNS Resolver
- Navigate to Network > DNS Resolvers > click Create
- Name: DemoDNSResolver
- Leave all other settings at their defaults and click Finished
- Click the newly created DNS resolver object
- Click Forward Zones
- Click Add
In this use case, we will be forwarding all requests to this DNS resolver.
- Name: .
- Address: 8.8.8.8
Note: Please use the correct DNS server for your use case.
- Service Port: 53
- Click Add and Finished
Creating a Network Tunnel
- Navigate to Network > Tunnels > Tunnel List > click Create
- Name: DemoTunnel
- Profile: tcp-forward
- Leave all other settings default and click Finished
Create an http Profile
- Navigate to Local Traffic > Profiles > Services > HTTP > click Create
- Name: DemoExplicitHTTP
- Proxy Mode: Explicit
- Parent Profile: http-explict
- Scroll until you reach Explicit Proxy settings.
- DNS Resolver: DemoDNSResolver
- Tunnel Name: DemoTunnel
- Leave all other settings default and click Finish
Create an Explicit Proxy Virtual Server
- Navigate to Local Traffic > Virtual Servers > click Create
- Name: explicit_proxy_vs
- Type: Standard
- Destination Address/Mask: 10.1.20.254
Note: This must be an IP address the internal clients can reach.
- Service Port: 8080
- Protocol: TCP
Note: This use case was for TCP traffic directed at known hosts on the internet. If you require other protocols or all, select the correct option for your use case from the drop-down menu.
- Protocol Profile (Client): f5-tcp-progressive
- Protocol Profile (Server): f5-tcp-wan
- HTTP Profile: DemoExplicitHTTP
- VLAN and Tunnel Traffic Enabled on: Internal
- Source Address Translation: Auto Map
- Leave all other settings at their defaults and click Finish.
Create a Fast L4 Profile
- Navigate to Local Traffic > Profiles: Protocol: Fast L4 > click Create
- Name: demo_fastl4
- Parent Profile: fastL4
- Enable Loose Initiation and Loose Close as shown in the screenshot below.
- Click Finished
Create a Wild Card Virtual Server
In order to catch and forward all traffic to the BIG-IP's default gateway, we will create a virtual server to accept traffic from our explicit proxy virtual server created in the previous steps.
- Navigate to Local Traffic > Virtual Servers > Virtual Server List > click Create
- Name: wildcard_VS
- Type: Forwarding (IP)
- Source Address: 0.0.0.0/0
- Destination Address: 0.0.0.0/0
- Protocol: *All Protocols
- Service Port: 0 *All Ports
- Protocol Profile: demo_fastl4
- VLAN and Tunnel Traffic: Enabled on...DemoTunnel
- Source Address Translation: Auto Map
- Leave all other settings at their defaults and click Finished.
Testing and Validation
- Navigate to a workstation on your internal network.
- Launch Internet Explorer or the browser of your preference.
- Modify the proxy settings to reflect the explicit_proxy_VS created in previous steps.
- Attempt to access several sites and validate you are able to reach them.
- Whether successful or unsuccessful, navigate to Local Traffic > Virtual Servers > Virtual Server List > click the Statistics tab.
- Validate traffic is hitting both of the virtual servers created above.
- If it is not, for troubleshooting purposes only configure to the virtual servers to accept traffic on All VLANs and Tunnels as well as useful tools such as curl and tcpdump.
You have now successfully configured your F5 BIG-IP to act as an explicit forward web proxy using LTM only. As stated above, this use case is not meant to fulfill all forward proxy use cases. If URL filtering and malware protection are required, APM and SWG integration should be considered. Until next time!
34 Comments
- Ajit
Altostratus
No, these are Amazon VPC endpoints that I am trying to resolve. If I set the same DNS server that I use in the DNS resolver in nslookup command then it resolves without any issues. However, the same DNS server is unable to resolve via the proxy solution. Am I missing something.
- Steve_LyonsRet. Employee
@Ajit, do you have an external self IP configured that allows access to the external internet or whatever you are using as a DNS resolver? You can also run ip route get <server ip address> to determine which IP address is being used to communicate with the DNS resolver.
Honestly this is the first time I am seeing any of these comments so if it is related to internal websites, you should probably be bypassing any type of proxy for internal addresses. If not, let me know and we can figure out how to resolve it.
- Ajit
Altostratus
Facing similar issue. Unable to resolve DNS. Do you have a solution to this problem?
- k20
Nimbostratus
I'm trying to to go to google.com from a workstation inside my network.
- Stanislas_Piro2
Cumulonimbus
@k20 : Do you try to access FQDN or short names?
- k20
Nimbostratus
I got the same error "DNS lookup failed" Have you ever got it figured out?
- Manish_Vashisht
Nimbostratus
Its not working when I configured in Partition. I do not see traffic on Wild CARD VS configured in Partition. I am not sure if above solution supports in F5 Partition.
- Steve_LyonsRet. Employee
As Stanislas mentioned, the network tunnel will maintain the HTTP CONNECT tunnel for SSL traffic using the tcp-forward profile. I just searched for documentation around this and I honestly don't see a ton. I will keep searching and share if I find anything.
- Sergi0
Nimbostratus
I know how to 0.0.0.0/0 works. What is the reason use DemoTunnel not just Internal vlan with wildcard_VS?
- Stanislas_Piro2
Cumulonimbus
@Sergi0 : the Explicit Proxy Virtual Server convert proxy connection with CONNECT method to TCP connection. CONNECT method is usually for HTTPS connection when the proxy must not inspect the content.
This connection is injected into an internal network to be forwarded to the destination.
Then the HTTPS virtual server with destination 0.0.0.0/0 listen on this internal network to enabled SSL Forward Proxy.
Help guide the future of your DevCentral Community!
What tools do you use to collaborate? (1min - anonymous)