centos 6.5 搭建vpn環境的例子(digitalocean主機)

來源:互聯網
上載者:User

指令碼

 代碼如下 複製代碼

#!/bin/bash

function installVPN(){
 echo "begin to install VPN services";
 #check wether vps suppot ppp and tun
 
 yum remove -y pptpd ppp
 iptables --flush POSTROUTING --table nat
 iptables --flush FORWARD
 rm -rf /etc/pptpd.conf
 rm -rf /etc/ppp
 
 arch=`uname -m`
 
 wget http://www.hi-vps.com/downloads/dkms-2.0.17.5-1.noarch.rpm
 wget http://wty.name/linux/sources/kernel_ppp_mppe-1.0.2-3dkms.noarch.rpm
 wget http://www.hi-vps.com/downloads/kernel_ppp_mppe-1.0.2-3dkms.noarch.rpm
 wget http://www.hi-vps.com/downloads/pptpd-1.3.4-2.el6.$arch.rpm
 wget http://www.hi-vps.com/downloads/ppp-2.4.5-17.0.rhel6.$arch.rpm


 yum -y install make libpcap iptables gcc-c++ logrotate tar cpio perl pam tcp_wrappers
 rpm -ivh dkms-2.0.17.5-1.noarch.rpm
 rpm -ivh kernel_ppp_mppe-1.0.2-3dkms.noarch.rpm
 rpm -qa kernel_ppp_mppe
 rpm -Uvh ppp-2.4.5-17.0.rhel6.$arch.rpm 
 rpm -ivh pptpd-1.3.4-2.el6.$arch.rpm

 mknod /dev/ppp c 108 0
 echo 1 > /proc/sys/net/ipv4/ip_forward
 echo "mknod /dev/ppp c 108 0" >> /etc/rc.local
 echo "echo 1 > /proc/sys/net/ipv4/ip_forward" >> /etc/rc.local
 echo "localip 172.16.36.1" >> /etc/pptpd.conf
 echo "remoteip 172.16.36.2-254" >> /etc/pptpd.conf
 echo "ms-dns 8.8.8.8" >> /etc/ppp/options.pptpd
 echo "ms-dns 8.8.4.4" >> /etc/ppp/options.pptpd

 pass=`openssl rand 6 -base64`
 if [ "$1" != "" ]
 then pass=$1
 fi

 echo "vpn pptpd ${pass} *" >> /etc/ppp/chap-secrets

 iptables -t nat -A POSTROUTING -s 172.16.36.0/24 -j SNAT --to-source `ifconfig  | grep 'inet addr:'| grep -v '127.0.0.1' | cut -d: -f2 | awk 'NR==1 { print $1}'`
 iptables -A FORWARD -p tcp --syn -s 172.16.36.0/24 -j TCPMSS --set-mss 1356
 service iptables save

 chkconfig iptables on
 chkconfig pptpd on

 service iptables start
 service pptpd start

 echo "VPN service is installed, your VPN username is vpn, VPN password is ${pass}"
 
}

function repaireVPN(){
 echo "begin to repaire VPN";
 mknod /dev/ppp c 108 0
 service iptables restart
 service pptpd start
}

function addVPNuser(){
 echo "input user name:"
 read username
 echo "input password:"
 read userpassword
 echo "${username} pptpd ${userpassword} *" >> /etc/ppp/chap-secrets
 service iptables restart
 service pptpd start
}

echo "which do you want to?input the number."
echo "1. install VPN service"
echo "2. repaire VPN service"
echo "3. add VPN user"
read num

case "$num" in
[1] ) (installVPN);;
[2] ) (repaireVPN);;
[3] ) (addVPNuser);;
*) echo "nothing,exit";;
esac


但是用windows串連vpn的時候提示800錯誤,發現是防火牆沒有開對應的連接埠,網上千篇一律的教程都沒有提這點,要在防火牆裡面加入

 代碼如下 複製代碼

-A RH-Firewall-1-INPUT -p tcp -m state –state NEW -m tcp –dport 1723 -j ACCEPT

這句話開啟1723連接埠即可,簡單說下指令碼用法

下載了 vpn.sh後

 代碼如下 複製代碼


#wget http://www.pztai.com/vpn.sh

#chmod a+x vpn.sh

#./vpn.sh

which do you want to?input the number.
 1. install VPN service --安裝
 2. repaire VPN service --修複
 3. add VPN user --增加新使用者

 代碼如下 複製代碼

#iptables -A INPUT -m state --state NEW -m tcp -p tcp --dport 1723 -j ACCEPT

#service iptables save

#service iptables restart

公用場所不確定wifi安全不安全,可以先連上自己的vpn,再去上網吧。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.