How to set up a VPN server on Ubuntu

Install PoPToP Point to Point Tunneling Server:

sudo apt-get install pptpd

Edit /etc/pptpd.conf file:

sudo joe /etc/pptpd.conf

Uncomment the following lines (replace IP range if you like)


Save and exit.

Edit /etc/ppp/pptpd-options file

sudo joe /etc/ppp/pptpd-options

Make sure you have this:

noipx               ## you don't need IPX
mtu 1490	        ## may help your linux client from disconnecting
mru 1490	        ## may help your linux client from disconnecting

Save and exit.

Next step is to add users who can use this connection.

sudo joe /etc/ppp/chap-secrets

The file should look like this:

# Secrets for authentication using CHAP
# client           server      secret                    IP addresses
cviorel            pptpd       my_secret_password        *
another_user       pptpd       his_secret_password       *

Now we need to configure IP Masquerading on the VPN server.
The purpose of IP Masquerading is to allow machines with private, non-routable IP addresses on your network to access the Internet through the machine doing the masquerading.

ufw Masquerading
IP Masquerading can be achieved using custom ufw rules. This is possible because the current back-end for ufw is iptables-restore with the rules files located in /etc/ufw/*.rules. These files are a great place to add legacy iptables rules used without ufw, and rules that are more network gateway or bridge related.
The rules are split into two different files, rules that should be executed before ufw command line rules, and rules that are executed after ufw command line rules.

a) First, packet forwarding needs to be enabled in ufw. Two configuration files will need to be adjusted, in /etc/default/ufw change the DEFAULT_FORWARD_POLICY to “ACCEPT”:


Then edit /etc/ufw/sysctl.conf and uncomment:


Similarly, for IPv6 forwarding uncomment:


b) Now we will add rules to the /etc/ufw/before.rules file. The default rules only configure the filter table, and to enable masquerading the nat table will need to be configured. Add the following to the top of the file just after the header comments:

# nat Table rules
# Forward traffic from eth1 through eth0.
# don't delete the 'COMMIT' line or these nat table rules won't be processed

The comments are not strictly necessary, but it is considered good practice to document your configuration. Also, when modifying any of the rules files in /etc/ufw, make sure these lines are the last line for each table modified:

# don't delete the 'COMMIT' line or these rules won't be processed

First, since we trust pptpd completely, I would accept all traffic to/from my pptpd. I added this lines at the beginning of the filter section.

-A ufw-before-input -i ppp+ -j ACCEPT
-A ufw-before-output -i ppp+ -j ACCEPT

Additionally, I must forward traffic to/from my pptpd. These lines was also added after the above lines.

-A ufw-before-forward -s -j ACCEPT
-A ufw-before-forward -d -j ACCEPT

c) Finally, disable and re-enable ufw to apply the changes:

sudo ufw disable && sudo ufw enable

IP Masquerading should now be enabled. You can also add any additional FORWARD rules to the /etc/ufw/before.rules. It is recommended that these additional rules be
added to the ufw-before-forward chain.

iptables Masquerading
iptables can also be used to enable masquerading.
a) Similar to ufw, the first step is to enable IPv4 packet forwarding by editing /etc/sysctl.conf and uncomment the following line:


If you wish to enable IPv6 forwarding also uncomment:


– Next, execute the sysctl command to enable the new settings in the configuration file:

sudo sysctl -p

– IP Masquerading can now be accomplished with a single iptables rule, which may differ slightly based on your network configuration:

sudo iptables -t nat -A POSTROUTING -s -o ppp0 -j MASQUERADE

The above command assumes that your private address space is and that your Internet-facing device is ppp0. The syntax is broken down as follows:

  • -t nat — the rule is to go into the nat table
  • -A POSTROUTING — the rule is to be appended (-A) to the POSTROUTING chain
  • -s — the rule applies to traffic originating from the specified address space
  • -o ppp0 — the rule applies to traffic scheduled to be routed through the specified network device
  • -j MASQUERADE — traffic matching this rule is to “jump” (-j) to the MASQUERADE target to be manipulated as described above

b) Also, each chain in the filter table (the default table, and where most or all packet filtering occurs) has a default policy of ACCEPT, but if you are creating a firewall in addition to a gateway device, you may have set the policies to DROP or REJECT, in which case your masqueraded traffic needs to be allowed through the FORWARD chain for the above rule to work:

sudo iptables -A FORWARD -s -o ppp0 -j ACCEPT
sudo iptables -A FORWARD -d -m state --state ESTABLISHED,RELATED -i ppp0 -j ACCEPT

The above commands will allow all connections from your local network to the Internet and all traffic related to those connections to return to the machine that initiated them.

c) If you want masquerading to be enabled on reboot, which you probably do, edit /etc/rc.local and add any commands used above. For example add the first command with no filtering:

iptables -t nat -A POSTROUTING -s -o ppp0 -j MASQUERADE

Firewall logs are essential for recognizing attacks, troubleshooting your firewall rules, and noticing unusual activity on your network. You must include logging rules in your firewall for them to be generated, though, and logging rules must come before any applicable terminating rule (a rule with a target that decides the fate of the packet, such as ACCEPT, DROP, or REJECT).

If you are using ufw, you can turn on logging by entering the following in a terminal:

sudo ufw logging on

To turn logging off in ufw, simply replace on with off in the above command.
If using iptables instead of ufw, enter:

sudo iptables -A INPUT -m state --state NEW -p tcp --dport 80 -j LOG --log-prefix "NEW_HTTP_CONN: "

A request on port 80 from the local machine, then, would generate a log in dmesg that looks like this:

[4304885.870000] NEW_HTTP_CONN: IN=lo OUT= MAC=00:00:00:00:00:00:00:00:00:00:00:00:08:00 SRC= DST= LEN=60 TOS=0x00 PREC=0x00 TTL=64 ID=58288 DF PROTO=TCP SPT=53981 DPT=80 WINDOW=32767 RES=0x00 SYN URGP=0

The above log will also appear in /var/log/messages, /var/log/syslog, and /var/log/kern.log. This behavior can be modified by editing /etc/syslog.conf appropriately or by installing and configuring ulogd and using the ULOG target instead of LOG. The ulogd daemon is a userspace server that listens for logging instructions from the kernel specifically for firewalls, and can log to any file you like, or even to a PostgreSQL or MySQL database. Making sense of your firewall logs can be simplified by using a log analyzing tool such as fwanalog, fwlogwatch, or lire.

NOTE: Documentation for this article is taken from

Leave a comment ?


  1. If I don’t want client machines to pass their DNS requests through the tunnel can I ommit the IP masquerading section?

  2. The masquerading part is for your firewall.
    If you want to specify your own DNS, edit your config files inside /etc/ppp.

  3. I’ve been researching this VPN tunnel stuff – seems far superior to proxies – and I get it, but… I want the host to be remote (outside my ISP).

    I want to do this:
    • Buy/Rent a [ ] Dedicated [ ] Virtual machine from some webhost (rackspace, etc.)
    • Install ubuntu on it?
    • Install web-app server (RoR, LAMP, etc.) on it?
    • Install a mail server on it?
    • blog engine, moveable type, etc?
    • LDAP server
    • Have all this crap work together? (obviously, I know dedicated servers for all this would be better, but I’m not imagining anything real intense)

    This is mainly for:
    • web privacy
    • keeping my gadgets/mail/contacts/files synched up
    • me around, getting my nerd on, getting my programming feet wet, etc.

    So, is that how you get a _remote_ VPN tunnel going? Or do you need to sign up for some service and use theirs…. AND…. BIG AND….

    Which hosting providers (U.S. based) can be trusted for privacy? or, in the alternative, which VPN tunneling hosts are a good value/trustworthy?

    Any help at all, I’ve literally been searching for weeks, but everyone stops at how to set this sh_t up without saying WHERE to set it up. I don’t just want to get at my machine from work or my high school computer lab so I can get on myspace.

    Sorry for the gianormous post. Be happy to post elsewhere if anyone can point!


  4. Sorry for the late reply.
    Ubuntu, or any other linux distro is suited for your needs (web server, mail server, LDAP, etc).
    The main reason you would use VPN is privacy. The method I described in the article does not require any action from your ISP. We suppose they do not filter the ports you decide to use on your VPN server configuration.

  5. Ok so i followed your instructions in this nice how-to but i still cant get ufw to let my pptp traffic through. if i disable ufw then it lets me connect but then masqurading doesnt work. any ideas? anything i should add to ufw? im trying to set this up at work so i need to get this going sooner rather than later.

  6. ok i added an execption in ufw to allow the pptp port through:
    sudo ufw allow 1723
    this allows me to connect the the vpn server but IP Masquerading isn’t working, i cant access any websites or anything on the internetfor that matter while connected to the vpn. anythoughts? again i need to get this running asap for work.

  7. @ LilJohn
    Do you have the right network in your /etc/ufw/before.rules file?

  8. ok i found the issue, at the begining you use these perameters:
    and then for ufw masq you use this rule to route the pptp clients traffic:
    -A POSTROUTING -s -o eth0 -j MASQUERADE (aka will not route the ipaddress range you must use (aka
    the following rule will work:

  9. i need help please, im on this step right now:

    # nat Table rules

    # Forward traffic from eth1 through eth0.

    # don’t delete the ‘COMMIT’ line or these nat table rules won’t be processed

    before i continue i have a question that way i wont have future problems, in the localip i put my server local ip address wich is and in the remoteip i only change the 0 for a 1, is that ok? im kind of confuse now, here the reason why i dont want to continue is because this is a Asterisk Server that i build and is working with a SIP Trunk perfect and i dont want to mess it up, so far i have been accessing thru SSH, but i will love to use a VPN connection, any help, thanks in advance!

  10. how I can connect RADIUS and VPN??

  11. disturbingprod

    How would one go about setting up a VPN that only passes certain data through for a certain service. I want to set up a VPN so my remote machines will use their local connection for all web traffic and only antivirus updates go through the VPN.

  12. @disturbingprod
    You can create a normal VPN and using your firewall rules you can define wich traffic goes where.

  13. Top 10 uses for Dedicated/Cloud server « The Tech Tutorial - pingback on August 20, 2010 at 4:34 pm
  14. nithin shetty

    HI, thanks for this beautiful article.

    Can i access my home computer [ inside my lan ] from outside the lan?? ie from some public computer which is connected to internet.

    My computer is also connected

  15. @nithin shetty

  16. I have a client workstation which must connect to a VPN through squid3 proxy server. The client workstation and the proxy server (computer with ubuntu 12.0.4 server and DNS, firewall, mail etc. services) are at my location and have access to them, but the VPN server is in another location and I do not have access to it. What can I do to allow traffic from the client workstation to the VPN server through http proxy ? If you want more details and some schematics, you can ask me : dragos.dragomir at (in english or romanian)

  17. @ddrazvi, you have to allow VPN traffic through squid.

  18. That was my question … how to allow VPN traffic through squid …?

  19. I already did that (I strongly believe that Google is my friend 😎 ), but so far I haven’t find a suitable solution.

  20. Maybe I searched for the wrong solution to my problem … instead of redirecting VPN traffic through proxy, how about bypassing proxy only for the IP of VPN server ? … should that solve my problem ?

  21. To Do List After installing Linux Mint 16 OS | Linux Support - pingback on February 14, 2014 at 1:39 am

Leave a Comment

NOTE - You can use these HTML tags and attributes:
<a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <s> <strike> <strong>

By continuing to use the site, you agree to the use of cookies. more information

The cookie settings on this website are set to "allow cookies" to give you the best browsing experience possible. If you continue to use this website without changing your cookie settings or you click "Accept" below then you are consenting to this.