Skip to content

Instantly share code, notes, and snippets.

@dysinger
Created August 28, 2013 18:22
Show Gist options
  • Save dysinger/6369435 to your computer and use it in GitHub Desktop.
Save dysinger/6369435 to your computer and use it in GitHub Desktop.
Create a VPN on EC2 in 30 seconds
#!/bin/sh
# linux firewall/forwarding
modprobe iptable_nat
echo 1 | tee /proc/sys/net/ipv4/ip_forward
iptables -t nat -A POSTROUTING -s 10.10.10.1/2 -o eth0 -j MASQUERADE
# install openvpn
apt-get update && apt-get install -y openvpn
cd /etc/openvpn/
INSTANCE=$(curl http://169.254.169.254/latest/meta-data/public-hostname)
openvpn --genkey --secret ${INSTANCE}.key
cat > openvpn.conf <<OPENVPN
dev tun1
ifconfig 10.10.10.1 10.10.10.2
port 443
proto tcp-server
secret ${INSTANCE}.key
OPENVPN
service openvpn restart
# create a client.zip (for use with tunnelblick or any openvpn clients)
cd /etc/openvpn/
cat > ${INSTANCE}.conf <<OPENVPN
dev tun
dhcp-option DNS 8.8.8.8
ifconfig 10.10.10.2 10.10.10.1
port 443
proto tcp-client
redirect-gateway def1
remote ${INSTANCE}
secret ${INSTANCE}.key
OPENVPN
apt-get install -y zip
zip client.zip ${INSTANCE}.conf ${INSTANCE}.key
# scp /etc/openvpn/client.zip to your machine for use
# imports straight into tunnelblick on a mac
@lucaspiller
Copy link

The URL used for the INSTANCE variable doesn't work for me, but I'm assuming it returns the same as http://ifconfig.me/host.

@rayrod2030
Copy link

@lucaspiller That URL only works from within EC2.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment