This tutorial will cover deployment of Windows Server 2012 R2's latest version of DirectAccess. While there are multiple ways to configure Direct Access, I tried to pull together what I believe are the best/recommended practices and what I believe would be a common deployment between organizations. If you have any thoughts/feedback on how to improve this deployment, please leave a comment below.
Before beginning, if you are curious what DirectAccess is, here is a brief overview of what it is and what it will allow us to accomplish.
DirectAccess, also known as Unified Remote Access, is a VPN-like technology that provides intranet connectivity to client computers when they are connected to the Internet. Unlike many traditional VPN connections, which must be initiated and terminated by explicit user action, DirectAccess connections are designed to connect automatically as soon as the computer connects to the Internet. DirectAccess was introduced in Windows Server 2008 R2, providing this service to Windows 7 and Windows 8 "Enterprise" edition clients.
http://en.wikipedia.org/wiki/DirectAccess
Prerequisites
- Domain Admin rights to complete the tutorial below
- Windows Server 2012 R2 machine
- Two network cards - One in your internal network, the other in your DMZ
- Joined to your domain
- Latest Windows Updates
(seriously, apply these, there are updates released specifically for DirectAccess)
- DMZ
- PKI Setup (Public Key Infrastructure to issue self-signed certificates)
- Custom template setup for issuing servers with an intended purpose of Server Authentication
- Certificate auto-enrollment has been configured
- Active Directory Security Group designated with Computer Objects allowed to use DirectAccess
- Login to your Server 2012 R2 server we will be using for installing the Direct Access
- Ensure all windows updates have been applied.
data:image/s3,"s3://crabby-images/460d2/460d21a42d85621ba4e00dede8f805b4cc82a396" alt="Latest Windows Updates"
- Open up Server Manager
data:image/s3,"s3://crabby-images/53f74/53f74fd1fd2af08ebfdec2808c81c10359dce054" alt="Server 2012 R2 - Server Manager"
- Select Manage -> Add Roles and Features
data:image/s3,"s3://crabby-images/d3212/d3212305b33382a7f5597a6c383f44bb705fa37a" alt="Server 2012 - Manage - Add Roles and Features"
- Click Next > on the Before you Begin step
data:image/s3,"s3://crabby-images/e6e4c/e6e4c35331d3e4d27e340f502166d6ea80c8583a" alt="Add Roles and Features Wizard - Before you begin"
- Ensure Role-based or feature-based installation is checked and click Next >
data:image/s3,"s3://crabby-images/e10ad/e10ad6c400cab7304857a5a3a649d57855c69aa0" alt="Add Roles and Features Wizard - Select installation type"
- Select Next > on the Select destination server step
data:image/s3,"s3://crabby-images/eb18b/eb18b85bd8da537c042fc6ae747cd038cdf9da00" alt="Add Roles and Features Wizard - Select destination server"
- Check Remote Access and click Next >
data:image/s3,"s3://crabby-images/fbc74/fbc74d7c103446c5efce5e5255b9e722df6921fb" alt="Add Roles and Features Wizard - Server Roles - Remote Access"
- Click Next > on the Select Features step
data:image/s3,"s3://crabby-images/d799a/d799a6add71aff9c16eaf4bd91dff4cf639a31d5" alt="Add Roles and Features Wizard - Server Roles - Features"
- Click Next > on the Remote Access step
data:image/s3,"s3://crabby-images/8fa96/8fa9678e38a8604471f2989655dfe37fecb83ce1" alt="Add Roles and Features Wizard - Remote Access"
- Check DirectAccess and VPN (RAS)
data:image/s3,"s3://crabby-images/d6a3c/d6a3c694b24e5983c1474090dd10d0181440339d" alt="Add Roles and Features Wizard - Remote Access"
- Click the Add Features button on the dialog box that prompts
data:image/s3,"s3://crabby-images/b2e6b/b2e6b0a73954b0b53a1dd0f961c3d41820e7ee91" alt="Add Roles and Features Wizard - Remote Access - Add Features"
- Check DirectAccess and VPN (RAS) and then click Next >
data:image/s3,"s3://crabby-images/b2a9a/b2a9a7b8d895820a894b59d9b101e5ca881f556c" alt="Add Roles and Features Wizard - Remote Access - Select role services"
- Click Next > on the Web Server Role (IIS) page
data:image/s3,"s3://crabby-images/e90d4/e90d44ea54f1a47946e378e57af7fc73123c82fc" alt="Add Roles and Features Wizard - Web Server Roll IIS"
- Click Next > on the Role Services page
data:image/s3,"s3://crabby-images/86bb2/86bb29faa08fb1d96aac59aff3e5c0267498b8ca" alt="Add Roles and Features Wizard - Web Server Roll IIS - Roll Services"
- Check the Restart the destination server automatically if required checkbox and click Yes on the dialog box.
data:image/s3,"s3://crabby-images/c8a67/c8a67fa91a48f357cc88749ef79f341526adee57" alt="Add Roles and Features Wizard - Confirm installation selections"
data:image/s3,"s3://crabby-images/0f13a/0f13a0e1b357acecd3c8c80a9d3adf0ab3f1ceac" alt="Add Roles and Features Wizard - Restart is required dialog"
- Click Install
data:image/s3,"s3://crabby-images/c2ca7/c2ca73272018d45099a1a58e36c7dc906606cfdc" alt="Add Roles and Features Wizard - Confirm installation selections - Restart the destination server automatically if required"
- Click Close when the install has completed
data:image/s3,"s3://crabby-images/b83c8/b83c8c388a099d5971c0e08dc61756f5b5586082" alt="Add Roles and Features Wizard - Results"
- Back in Server Manager, click on Tools -> Remote Access Management (You can ignore the warning icon, the Open the Getting Started Wizard will only do a quick setup of DirectAccess. We want to do a full deployment).
data:image/s3,"s3://crabby-images/1feab/1feab7f6b8e5ffb385dadf7a8f660ef7b615191a" alt="Server Manager - Tools - Remote Access Management"
Here is what the quick deployment looks like. Don't click on this. data:image/s3,"s3://crabby-images/b922a/b922acd8f03a04765d5a110332402e58525bc1a0" alt="Server Manager - Post-Deployment Configuration - DirectAccess"
- On the Remote Access Management Console, click on DirectAccess and VPN on the top left and then click on the Run the Remote Access Setup Wizard.
data:image/s3,"s3://crabby-images/a7ade/a7adeda882e0d6a0d9298a76d82740679e273c24" alt="Remote Access Management Console - DirectAccess and VPN"
- On the Configure Remote Access window, select Deploy DirectAccess only
data:image/s3,"s3://crabby-images/4b5bd/4b5bd7b671f41e5cec2b575e5fd559126360a158" alt="Configure Remote Access - Deploy DirectAccess Only"
- Click on the Configure... button for Step 1: Remote Clients
data:image/s3,"s3://crabby-images/91ce9/91ce9b1c0694bb9501ec11ec41b0f6a0bbb2b3e1" alt="Remote Access Management Console - DirectAccess and VPN - Step 1 Remote Clients"
- Select Deploy full DirectAccess for client access and remote management and click Next >
data:image/s3,"s3://crabby-images/512e0/512e0af4a31bb241d834fbf26ebf7a550fdc1800" alt="Remote Access Setup - Deploy full DirectAccess for client access and remote managment"
- Click on the Add... button
data:image/s3,"s3://crabby-images/c4ad9/c4ad9497614f4a5abdaf1a35dfc84f6213f205a3" alt="Remote Access Setup - Select one or more security grups containing client computers that will be enabled for DirectAccess"
- Select the security group inside of Active Directory that will contain computer objects allowed to use DirectAccess and click OK
data:image/s3,"s3://crabby-images/54f6e/54f6ea4f891a73e4f97ae40ba204e8a154068a81" alt="Remote-Access-Setup-Select-Groups"
- Optionally, uncheck or check Enable DirectAccess for mobile computers only as well as Use force tunneling and click Next >
- If Enable DirectAccess for mobile computers is checked, WMI will query the machine to determine if it is a laptop/tablet. If WMI determines the machine is not a "mobile device", the group policy object will not be applied to those machines in the security group. In short, if checked, DirectAccess will not be applied to computers that are desktops or VMs placed inside the security group.
- If Use force tunneling is checked, computers will always use the direct access server when remote. For example, if the user surfs the web to a public website like jackstromberg.com, the traffic will go through the DirectAccess tunnel and back to the machine, rather than directly to the ISP. Generally, this is used for strict compliance environments that want all network traffic to flow through a central gateway.
data:image/s3,"s3://crabby-images/3a071/3a071cf470d79689bb564f500d2e642a957ffa13" alt="Remote Access Setup - Select Groups - Next"
- Double click on the Resource | Type row
- What this step is trying to do is find a resource on the internal network that the client can "ping" to ensure the DirectAccess client has successfully connected to the internal network.
data:image/s3,"s3://crabby-images/02264/0226406901a0a5b866a0090e2d6273b9ed7b26da" alt="Remote Access Setup - Network Connectivity Assistant - Resource Type"
- Select whether you want the client to verify it has connected to the internal network via a HTTP response or network ping, optionally click the validate button to test the connection, and then click Add
- You may want to add a couple resources for failover testing purposes, however it isn't recommended to list every resource on your internal network.
data:image/s3,"s3://crabby-images/e83b6/e83b6ced0dcfe2de7a5cac4e2b8fca712f8e384b" alt="Remote Access Setup - Network Connectivity Assistant - Configure Corporate Resources for NCA"
- Enter in your Helpdesk email address and DirectAccess connection name (this name will show up as the name of the connection a user would use), and check Allow DirectAccess clients to use local name resolution and click Finish.
- Based on what I could find, checking Allow DirectAccess clients to use local name resolution will allow the DirectAccess client to use the DNS server published by DHCP on the physical network they are connected to. In the event the Network Location server is unavailable, the client would then use the local DNS server for name resolution; allowing the client to at least access some things via DNS.
data:image/s3,"s3://crabby-images/b41d1/b41d196a76b2dea5e9f56fa5b710895c500ef6cd" alt="Remote Access Setup - Network Connectivity Assistant - Helpdesk email address - DirectAccess connection name"
- Click on Configure... next to Step 2: Remote Access Server
data:image/s3,"s3://crabby-images/97e33/97e33795585ded4959f9f1e580608a0ef8682480" alt="Remote Access Management Console - DirectAccess and VPN - Step 2 Remote Access Server"
- On the Remote Access Server Setup page, select Behind an edge device (with two network adapters) and ensure you specify a public facing DNS record that DirectAccess will use to connect back to your environment, and then click Next >
- NOTE: By default, your domain's FQDN will be used, so if you have a .local domain, you will want to switch this to your actual .com, .net, .org, .whatever.
- As an additional side note, hereis some information from the following KB article on what the differences are between each of the topologies. From what I gather, using the dual NIC configuration is Microsoft's best practice from a security standpoint.
- Two adapters—With two network adapters, Remote Access can be configured with one network adapter connected directly to the Internet, and the other is connected to the internal network. Or alternatively the server is installed behind an edge device such as a firewall or a router. In this configuration one network adapter is connected to the perimeter network, the other is connected to the internal network.
- Single network adapter—In this configuration the Remote Access server is installed behind an edge device such as a firewall or a router. The network adapter is connected to the internal network.
data:image/s3,"s3://crabby-images/d997e/d997e722139d52d6ca63e7b5e2fb1d3d50034749" alt="Remote Access Server Setup - Network Topology"
- On the Network Adapters step, select your External (DMZ) and Internal (LAN) adapters.
data:image/s3,"s3://crabby-images/c4f2e/c4f2e2fafd421c7d3abee47fe9f2c45953933d10" alt="Remote Access Server Setup - Network Adapters - External Internal"
- Leave the Remote Access Setup screen open and right click on Start button and select Run
data:image/s3,"s3://crabby-images/b1130/b113088410536c8b499da1299c8d4baa027bf2fe" alt="Server 2012 - Run"
- Type mmc and select OK
data:image/s3,"s3://crabby-images/7ba7e/7ba7eb1f2893beccfd51a41f0780021134652e7f" alt="Server 2012 - Run - mmc"
- Click File -> Add/Remove Snap-in...
data:image/s3,"s3://crabby-images/be4d7/be4d79361546076c1599b59e6319b8aafe83d5ee" alt="mmc - File - Add-Remove Snap-in"
- Select Certificates and click Add >
data:image/s3,"s3://crabby-images/1beb7/1beb70139c2687c46cecf0aeb5577792be16a633" alt="Add or Remote Snap-ins - Certificates"
- Select Computer account and click Next >
data:image/s3,"s3://crabby-images/29d79/29d792663ff6d2896d65686371f2a771e6f71534" alt="Certificates snap-in - Computer Account"
- Ensure Local Computer is selected and click Finish
data:image/s3,"s3://crabby-images/c4930/c4930f2a535c1d59d34e9af7ef1cf0555f0a5389" alt="Certificates snap-in - Select Computer"
- Click OK on the Add or Remove Snap-ins machine
data:image/s3,"s3://crabby-images/c2d92/c2d9214a06f265fa7ae49f80ebdb0e32f06fc7dc" alt="Add or Remove Snap-ins - Certificates - Local Computer"
- Expand Certificates (Local Computer) -> Personal -> Certificates, right click on Certificates and select Request New Certificate...
data:image/s3,"s3://crabby-images/cb5e9/cb5e994d9785d5067df6a61aac18ca9740a52c31" alt="Certificates - All Tasks - Request new certificate"
- Click Next on the Before You Begin screen
data:image/s3,"s3://crabby-images/b6d49/b6d49c9b995bcdf4c934abc3d53dfc0c3aa687dc" alt="Certificate Enrollment - Before You Begin"
- Click Next on the Select Certificate Enrollment Policy
data:image/s3,"s3://crabby-images/6a8e4/6a8e4ae168bb16ee5f9869b61e339166b78472ae" alt="Certificate Enrollment - Select Certificate Enrollment Policy"
- Select your template that will support server authentication and click More information is required to enroll for this certificate. Click here to configure settings.
- Note: The WebServers enrollment policy is not something out of the box configured by Microsoft. You will need to manually login to your certificate authority, duplicate the Web Servers template with the settings you wish, ensure your usergroup can Enroll for a certificate, and then publish it to AD.
- On the Subject tab, enter the following values (substituting in your company's information):
Common name: da.mydomain.com
Country: US
Locality: Honolulu
Organization: My Company
Organization Unit: Information Technology
State: Hawaii
data:image/s3,"s3://crabby-images/6747c/6747ccdfb5a13a18ed95d3d82e2dec9f1991d19e" alt="Certificate Enrollment - Certificate Properties - Subject Tab"
- On the Private Key tab, expand Key options and check Make private key exportable. Click Apply when done.
data:image/s3,"s3://crabby-images/36b3e/36b3e0c14c4cd3c3d8ed2a29bfba15ddb26568db" alt="Certificate Enrollment - Certificate Properties - Private Key Tab"
- Click Enroll.
data:image/s3,"s3://crabby-images/ae324/ae324aed13717c1ddf3990bf8e15faed6cfecf1b" alt="Certificate Enrollment - Request Certificates - Enroll"
- Click Finish.
data:image/s3,"s3://crabby-images/de2ae/de2ae02720b688877987de68ec7aecf7f7ec3f88" alt="Certificate Enrollment - Certificate Installation Results"
- Go back to the Remote Access Setup screen and click Browse...
data:image/s3,"s3://crabby-images/c4f2e/c4f2e2fafd421c7d3abee47fe9f2c45953933d10" alt="Remote Access Server Setup - Network Adapters - External Internal"
- Select your da.mydomain.com certificate we just created and click OK.
data:image/s3,"s3://crabby-images/22a60/22a60c871e5fda6d91e9f6ccb70e9bac1678b513" alt="Remote Access Setup - Select a certificate"
- Click Next >
data:image/s3,"s3://crabby-images/730f4/730f4d27b95f04e7296d77b6e3c5a6d39bd7d219" alt="Remote Access Setup - Network Adapters - External Internal Certificate"
- Check Use computer certificates and check Use an intermediate certificate and then click Browse...
data:image/s3,"s3://crabby-images/1ac0f/1ac0fbe20a2bbcbcf131d0c23cc76f2b03828277" alt="Remote Access Setup - Authentication - Active Directory Credentials"
- Select the certificate authority that will be issuing the client certificates and click click OK
data:image/s3,"s3://crabby-images/ec7b9/ec7b9b20b8a15a044be50d00c43565d0773eef6b" alt="Remote Access Setup - Authentication - Select a certificate"
- Optionally, you may enable Enable Windows 7 client computers to connect via DirectAccess as well as Enforce corporate compliance for DirectAccess clients with NAP. Note: Configuring these two options are not covered in the scope of this tutorial. Click Finish when done.
data:image/s3,"s3://crabby-images/d796a/d796a464e5b6bd284173a99ab1b86fdd7e3e3a8c" alt="Remote Access Setup - Authentication - Finish"
- Click on Configure... next to Step 3: Infrastructure Servers
data:image/s3,"s3://crabby-images/1a3d5/1a3d59f6af67832d46f5bf669375abe19c6f053e" alt="Remote Access Management Console - DirectAccess and VPN - Step 3 Infrastructure Servers"
- On the Remote Access Setup screen, check The network location server is deployed on a remote web server (recommended), type in the website address to the Network Location Server, and click Next >
- So for whatever reason, there aren't many articles explaining what exactly the network location server is and how to set it up. From what I gather, the Network Location Server is merely a server with a website running on it that the client can contact to ensure it has reached the internal network. The webpage can be the default IIS webpage; just ensure the website is NOT accessible externally.
data:image/s3,"s3://crabby-images/42875/42875c67e1ed12cfabbd7740cebb3f631b8f4169" alt="Remote Access Setup - Network Location Server"
- Specify any additional DNS servers you wish to use for name resolution, ensure Use local name resolution if the name does not exist in DNS or DNS servers are unreachable when the client computer is on a private network (recommended) is checked and click Next >
data:image/s3,"s3://crabby-images/90408/9040894d00a215314849716bac4cafc9adcfae26" alt="Remote Access Setup - Infrastructure Server Setup - DNS"
- Check Configure DirectAccess clients with DNS client suffix search list, ensure your local domain's suffix has been added, and click Next >
data:image/s3,"s3://crabby-images/3d2c1/3d2c18eb092e6e5f1972fe087e5aa4f09626a860" alt="Remote Access Setup - DNS Suffix Search List"
- Click Finish on the Management page.
data:image/s3,"s3://crabby-images/0edd4/0edd44dc2708f7405e808814cdb1a971e64bc2f6" alt="Remote Access Setup - Management"
- Click the Configure.... button on Step 4: Application Servers
data:image/s3,"s3://crabby-images/61cb1/61cb1140025cd7678587c0b99ab95453cae8e668" alt="Remote Access Management Console - Step 4 Application Servers"
- Check Do not extend authentication to application servers and click Finish
data:image/s3,"s3://crabby-images/d9656/d96569aab5feaa28581b6f2e073c5a3e2a26aea2" alt="Remote Access Setup - Do not extend authentication to application servers"
- Click Finish... on the Remote Access Management Console page
data:image/s3,"s3://crabby-images/e949f/e949f214cbe8f63eb4972c5b032bc5ebf06e3ff3" alt="Remote Access Management Console - Finish"
- Click Apply on the Remote Access Review page
data:image/s3,"s3://crabby-images/923fb/923fbf577547a9875a039a7201c85dc5a200a0cb" alt="Remote Access Review - Summary of Remote Access configuration settings"
- Click Close once direct access has successfully finished deploying
data:image/s3,"s3://crabby-images/42084/42084424426f56efbf9e3053d31783efc87aa524" alt="Apply Remote Access Setup Wizard Settings - The configuration was applied successfully"
- Login to one of your Windows 8.X Enterprise machines that is inside of your DirectAccess Compuers security group and run a gpupdate from command line to pull down the latest group policy.
- At this point, you should now be able to login to your network via DirectAccess!
NOTES:
Here is a pretty good resource from Microsoft on helping plan your DirectAccess deployment. Once you click on the link, in the bottom left corner, you will find two steps to some good KB articles: http://technet.microsoft.com/en-us/library/jj134262.aspx
Here is another article from Microsoft with a more indepth explanation about where to place the Network Location Server: http://technet.microsoft.com/en-us/library/ee382275(v=ws.10).aspx