7. OS X
created: May 3, 2009
updated: Sep 1, 2011
Enable VPN server in OS X for remote access via iPhone, Windows, and OS X clients
This guide outlines how to enable the built-in VPN service (vpnd) in client versions of OS X, as Apple has neglected to mention (let alone explain) the possibility under non-server editions of OS X. Standard disclaimer applies, as always: You are 100% responsible for your own actions. Using this guide, visiting a link, downloading a program, in short, living, is done entirely at your own risk (and joy).
I. Diagram of Example Network
The domain name and IP addresses above are for example purposes only and will likely differ on your networks.
II. Enabling vpnd on the iMac
- Download iVPN-2.4b.zip and iVPN-Help-2.4b.pdf (the source code is also available: iVPN-2.4b-src.zip).
- Copy iVPN.app to your Applications folder
- Launch iVPN.app
- Click "No" when asked about downloading the new version
- Click the PPTP button to disable PPTP
- Click the L2TP button to enable L2TP
- Enter a username, password, and shared secret. Do not lose these.
- Optionally select "Store in Keychain"
- For the IP Address Range, choose a range of IP addresses in your LAN that you will reserve for VPN clients. In this example, we'll use 192.168.50.200 - 192.168.50.204.
- Our router in this example is 192.168.50.1, the subnet mask is 255.255.255.0, our primary DNS server is 192.168.50.1, and we'll use one of the OpenDNS servers for our secondary: 22.214.171.124
- Click "On" to enable the VPN server and enter your OS X user password when prompted.
- We can now check "Start server at boot time" if desired (this option uses the deprecated but functional /Library/StartupItems)
- Quit iVPN. You should never need to open it again, as its only purpose is to configure/enable vpnd.
III. Port forwarding
- You may need to enable VPN passthrough on your router and/or forward the following UDP ports to the VPN server: 500, 1701, 4500. For help with port forwarding, see PortForward.com.
III. Connecting to VPN from iPhone, Windows, or OS X
- The aforementioned PDF has detailed instructions for connecting to your VPN from iPhone, Windows, and Mac OS X. Make sure to follow the L2TP instructions.
- You'll need to know the public IP address or domain name of the modem/router. If you don't have a static IP address, you may want to setup a dynamic DNS account.
- For those who prefer to setup vpnd manually (as opposed to using iVPN):
- See also: PPTP/L2TP VPN Server on Mac OS X Leopard Client, which addresses a possible connection problem with Windows XP SP2 or higher.
- There are loads of fun things you can do once connected to your VPN, but here's one: if you enable Screen Sharing on your VPN server (System Preferences > Sharing), access it from a connected Mac (and optionally any VNC client) via Cmd+K > vnc://server_ip_or_name.
- After 2.4b, iVPN became shareware. Its new homepage can be found here. I decided to avoid the shareware version after reading comments here and here.
- The new and vastly superior EasyVPN offers similar functionality to iVPN, but includes Lion support, launchd (as opposed to StartupItem) startup, and a price tag of only $4.99 (versus £14.99 for the current version of iVPN).
- The VPN server log can be found at: /var/log/ppp/vpnd.log . Here are a few example lines:
#Start-Date: 2009-04-28 20:57:29 HST
#Fields: date time s-comment
2009-04-28 20:57:29 HST Loading plugin /System/Library/Extensions/L2TP.ppp
2009-04-28 20:57:30 HST Server 'com.apple.ppp.l2tp' moved to background
2009-04-28 20:57:30 HST Listening for connections...
2009-04-28 21:41:03 HST Incoming call... Address given to client = 192.168.50.200
Tue Apr 28 21:41:03 2009 : L2TP incoming call in progress from '192.0.2.11'...
Tue Apr 28 21:42:19 2009 : Connection terminated.
Tue Apr 28 21:42:19 2009 : Connect time 1.3 minutes.
Tue Apr 28 21:42:19 2009 : Sent 73588 bytes, received 15502 bytes.
Tue Apr 28 21:42:19 2009 : L2TP disconnecting...
Tue Apr 28 21:42:19 2009 : L2TP disconnected
2009-04-28 21:42:19 HST --> Client with address = 192.168.50.200 has hungup
2009-04-28 21:43:10 HST terminating on signal 15
#End-Date: 2009-04-28 21:43:10 HST