centos pptp搭建,windows网关配置

2024-01-05 00:40

本文主要是介绍centos pptp搭建,windows网关配置,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

一、安装

二、配置

三、运行 

四、防火墙

五、限速

六、常见问题

七、windows网关设置


一、安装

yum install ppp pptpd -y
#需要防火墙转发,如不想使用iptables可使用其他防火墙 
yum install iptables iptables-services

二、配置

vim /etc/pptpd.confdebug #打开日志 /var/log/message
ppp /usr/sbin/pppd
option /etc/ppp/options.pptpd
localip 192.168.0.1
remoteip 192.168.1.234-238,192.168.2.245vim /etc/ppp/options.pptpd
ms-dns 114.114.114.114
ms-dns 8.8.8.8vim /etc/ppp/chap-secrets
# Secrets for authentication using CHAP
# client        server  secret                  IP addresses
# 用户名 协议名称(可为*) 密码 LAN地址(*为自动分配)
'test'  pptpd   "123456" *vim /etc/sysctl.conf
#支持网络转发
net.ipv4.ip_forward=1#指令
sysctl -p

三、运行 

#运行
systemctl start iptables
systemctl start pptpd#开机启动
systemctl enable iptables
systemctl enable pptpd#此时已全部安装运行完成,添加防火墙nat转换后即可进行pptp拨号
/sbin/iptables -t nat -I POSTROUTING -s 192.168.31.0/24 -o em1 -j MASQUERADE

四、防火墙

#pptpd需要打开 gre协议,1723、47端口 以及nat地址转换
#mtu值正常情况是 1356 也可能是1472
/sbin/iptables -I INPUT -p gre -j ACCEPT
/sbin/iptables -I INPUT -p tcp --dport 1723 -j ACCEPT
/sbin/iptables -I INPUT -p tcp --dport 47 -j ACCEPT
/sbin/iptables -t nat -I POSTROUTING -s 192.168.0.0/24 -o em1 -j MASQUERADE
/sbin/iptables -I FORWARD -p tcp --syn -i ppp+ -j TCPMSS --set-mss 1356

五、限速

# 通过tc进行限速 /etc/ppp/ip-up 不存在的话直接创建一个
yum install /sbin/tc
modprobe sch_htb
echo "modprobe sch_htb" >> /etc/rc.local
vim /etc/ppp/ip-upecho ppp connect Start_Time: `date -d today +%F_%T` >> /var/log/message
down=80kbps
upload=80kbps
iprange=192.168.32.0/24
#down
/sbin/tc qdisc del dev $1 root
/sbin/tc qdisc add dev $1 root handle 2:0 htb
/sbin/tc class add dev $1 parent 2:1 classid 2:10 htb rate $down
/sbin/tc class add dev $1 parent 2:2 classid 2:11 htb rate 1024kbps
/sbin/tc qdisc add dev $1 parent 2:10 handle 1: sfq perturb 1
/sbin/tc filter add dev $1 protocol ip parent 2:0 u32 match ip dst \$iprange flowid 2:10
#upload
/sbin/tc qdisc add dev $1 handle ffff: ingress
/sbin/tc filter add dev $1 parent ffff: protocol ip u32 match ip dst \$iprange police rate $upload burst 100k drop flowid 2:11

六、常见问题

# LCP: timeout sending Config-Requests
# GRE: read(fd=6,buffer=564b0e55e480,len=8196) from PTY failed: status = -1 error = Input/output error, usually caused by unexpected termination of pppd, check option syntax and pppd logs
# CTRL: PTY read or GRE write failed此为网络转发gre问题,确认gre 端口是否打开,若服务器gre正常,则检查客户端路由器以及上层节点是否打开了gre# pptpd可以连接但是无法访问https检查mtu值,pptpd默认mtu是1396,去除tcp协议包头40个字节,iptables设置mss为1356
其他mtu值需要自行尝试了

七、windows网关设置

关闭pptp适配器的【在远程网络上使用默认网关】

 手动配置windows的route路由表

#管理员权限运行
# route -p add [target_ip] mask [net_mask] [pptp_lan]
# -p 永久新增路由 没有该参数时,重启电脑会失效 建议不加该参数,每次连接pptp时手动运行
route add 222.186.61.212 mask 255.255.255.255 192.168.31.240

bat自动化脚本

rem 批量新增route路由bat脚本
@echo off
chcp 65001
net.exe session 1>NUL 2>NUL || (echo 请以管理员权限运行goto end
)for /f "tokens=2 delims=:" %%i in ('ipconfig^|findstr "192.168.31"') do (set pptp_lan=%%igoto out
)
echo 未查询到pptp的lanip
goto end:: 标签
:out
echo Get pptp_lan IP: %pptp_lan%rem route -p add [target_ip] mask [net_mask] [pptp_lan]
rem -p 永久新增路由 没有该参数时,重启电脑会失效 建议不加该参数,每次连接pptp时手动运行
rem route add ip mask 255.255.255.255 %pptp_lan%route add 180.101.49.11 mask 255.255.255.255 %pptp_lan%echo route %pptp_lan% list
route print | findstr %pptp_lan%pause
exit 0:end
echo end
pause
rem 批量删除route路由脚本
@echo off
chcp 65001
net.exe session 1>NUL 2>NUL || (echo 请以管理员权限运行goto end
)for /f "tokens=2 delims=:" %%i in ('ipconfig^|findstr "192.168.31"') do (set pptp_lan=%%igoto out
)
echo 未查询到pptp的lanip
goto end:: 标签
:out
echo Get pptp_lan IP: %pptp_lan%rem route -p add [target_ip] mask [net_mask] [pptp_lan]
rem -p 永久新增路由 没有该参数时,重启电脑会失效 建议不加该参数,每次连接pptp时手动运行
rem route add 222.186.61.212 mask 255.255.255.255 %pptp_lan%route delete xx.xx.xx.xxecho route %pptp_lan% list
route print | findstr %pptp_lan%pause
exit 0:end
echo end
pause

这篇关于centos pptp搭建,windows网关配置的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/571107

相关文章

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析

浅谈配置MMCV环境,解决报错,版本不匹配问题

《浅谈配置MMCV环境,解决报错,版本不匹配问题》:本文主要介绍浅谈配置MMCV环境,解决报错,版本不匹配问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录配置MMCV环境,解决报错,版本不匹配错误示例正确示例总结配置MMCV环境,解决报错,版本不匹配在col

Nginx中配置HTTP/2协议的详细指南

《Nginx中配置HTTP/2协议的详细指南》HTTP/2是HTTP协议的下一代版本,旨在提高性能、减少延迟并优化现代网络环境中的通信效率,本文将为大家介绍Nginx配置HTTP/2协议想详细步骤,需... 目录一、HTTP/2 协议概述1.HTTP/22. HTTP/2 的核心特性3. HTTP/2 的优

Python 安装和配置flask, flask_cors的图文教程

《Python安装和配置flask,flask_cors的图文教程》:本文主要介绍Python安装和配置flask,flask_cors的图文教程,本文通过图文并茂的形式给大家介绍的非常详细,... 目录一.python安装:二,配置环境变量,三:检查Python安装和环境变量,四:安装flask和flas

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.

MySQL双主搭建+keepalived高可用的实现

《MySQL双主搭建+keepalived高可用的实现》本文主要介绍了MySQL双主搭建+keepalived高可用的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、测试环境准备二、主从搭建1.创建复制用户2.创建复制关系3.开启复制,确认复制是否成功4.同

SpringCloud动态配置注解@RefreshScope与@Component的深度解析

《SpringCloud动态配置注解@RefreshScope与@Component的深度解析》在现代微服务架构中,动态配置管理是一个关键需求,本文将为大家介绍SpringCloud中相关的注解@Re... 目录引言1. @RefreshScope 的作用与原理1.1 什么是 @RefreshScope1.

SpringBoot日志配置SLF4J和Logback的方法实现

《SpringBoot日志配置SLF4J和Logback的方法实现》日志记录是不可或缺的一部分,本文主要介绍了SpringBoot日志配置SLF4J和Logback的方法实现,文中通过示例代码介绍的非... 目录一、前言二、案例一:初识日志三、案例二:使用Lombok输出日志四、案例三:配置Logback一

springboot security之前后端分离配置方式

《springbootsecurity之前后端分离配置方式》:本文主要介绍springbootsecurity之前后端分离配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的... 目录前言自定义配置认证失败自定义处理登录相关接口匿名访问前置文章总结前言spring boot secu

一文详解SpringBoot响应压缩功能的配置与优化

《一文详解SpringBoot响应压缩功能的配置与优化》SpringBoot的响应压缩功能基于智能协商机制,需同时满足很多条件,本文主要为大家详细介绍了SpringBoot响应压缩功能的配置与优化,需... 目录一、核心工作机制1.1 自动协商触发条件1.2 压缩处理流程二、配置方案详解2.1 基础YAML