CentOS 7下安装pptp服务

2023-11-01

一、检查是否支持PPTP

1. 在安装之前查看系统是否支持PPTP

modprobe ppp-compress-18 && echo success #应该输出:success

2. 是否开启TUN/TAP

cat /dev/net/tun #应该输出:cat: /dev/net/tun: File descriptor in bad state

3. 是否开启ppp

cat /dev/ppp #应该输出:cat: /dev/ppp: No such device or address

如果环境不满足上面3个条件,表示很可能不支持pptp

 

二、安装相关软件

1.安装PPP

yum install -y ppp

2.安装epel源

yum install -y epel-release

3.检查是否已添加到源列表中

yum repolist

4.没有则更新源列表

yum -y update

5.安装pptp

yum install -y pptpd

 

注:如出现异常:One of the configured repositories failed (Unknown)

解决方案是:先把epel卸载,更新后再装

yum remove epel-release

yum -y update

yum install epel-release

 

三、修改配置

1.vi /etc/pptpd.conf设置VPN内网IP段

最后IP设置改为:

localip 192.168.100.1

remoteip 192.168.100.234-238,192.168.100.245

2.vi /etc/ppp/options.pptpd

更改DNS项:

ms-dns 8.8.8.8

ms-dns 8.8.4.4

修改日志记录:

nologfd

logfile /var/log/pptpd.log

3.vi /etc/ppp/chap-secrets

设置VPN账号密码(格式:{account} pptpd {password} *)

例:pptptest pptpd 123456 *

 

启动pptp:service pptpd start

关闭pptp:service pptpd stop

重启pptp:service pptpd restart

关闭防火墙,windows下使用使用“添加VPN连接”填写服务IP、用户名、密码连接应该可以连上,这时候本地电脑可以访问VPN服务器,但是不能访问外网

启动防火墙:service firewalld start

关闭防火墙:service firewalld stop

重启防火墙:service firewalld restart

 

四、开启服务器系统路由模式,支持包转发(通过VPN访问外网)

1.vi /etc/sysctl.conf 修改内核参数支持内核转发,增加一行:

net.ipv4.ip_forward=1

sysctl -p  #使设置立刻生效

2.创建规则文件:vi /usr/lib/firewalld/services/pptpd.xml,内容为:

<?xml version="1.0" encoding="utf-8"?>

<service>

    <short>pptpd</short>

    <description>PPTP</description>

    <port protocol="tcp" port="1723"/>

</service>

3.启动防火墙:service firewalld start

4.添加服务:

firewall-cmd --permanent --zone=public --add-service=pptpd

允许防火墙伪装IP:

firewall-cmd --add-masquerade

5.开启47及1723端口:

firewall-cmd --permanent --zone=public --add-port=47/tcp

firewall-cmd --permanent --zone=public --add-port=1723/tcp

6.允许gre协议:

firewall-cmd --permanent --direct --add-rule ipv4 filter INPUT 0 -p gre -j ACCEPT

firewall-cmd --permanent --direct --add-rule ipv4 filter OUTPUT 0 -p gre -j ACCEPT

7.设置规则允许数据包由eth0和ppp+接口中进出

firewall-cmd --permanent --direct --add-rule ipv4 filter FORWARD 0 -i ppp+ -o eth0 -j ACCEPT

firewall-cmd --permanent --direct --add-rule ipv4 filter FORWARD 0 -i eth0 -o ppp+ -j ACCEPT

8.设置转发规则,从源地址发出的所有包都进行伪装,改变地址,由eth0发出:

firewall-cmd --permanent --direct --passthrough ipv4 -t nat -I POSTROUTING -o eth0 -j MASQUERADE -s 192.168.100.0/24

9.重启防火墙:service firewalld restart

奇怪点,到了这步后发现还是无法上网

需要安装iptables增加规则才能访问外网,配置后卸载iptables也没有问题,或许可以用firewall-cmd命令替代,暂时不知道怎么替代命令

yum install -y iptables-services

 

开放pptp端口1723,允许转发

iptables -I INPUT 7 -m state --state NEW -p tcp --dport 1723 -j ACCEPT

iptables -P FORWARD ACCEPT

iptables配置,配置虚拟网段NAT支持。如果pptp客户端不需要上网,可以忽略本步骤。

iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE

解决PPTP服务网速慢,参考网页: http://www.92csz.com/52/1244.html
iptables -I FORWARD -p tcp --syn -i ppp+ -j TCPMSS --set-mss 1356
 

保存iptables规则

service iptables save

10.重启防火墙:service firewalld restart

终于可以上网了,浏览器百度输入ip,发现是服务器的ip地址了

观察服务器日志/var/log/pptpd.log,连接断开都有日志打印

Plugin /usr/lib64/pptpd/pptpd-logwtmp.so loaded.
Using interface ppp0
Connect: ppp0 <--> /dev/pts/1
peer from calling number 116.22.2.240 authorized
MPPE 128-bit stateless compression enabled
Cannot determine ethernet address for proxy ARP
local  IP address 192.168.0.1
remote IP address 192.168.1.1


LCP terminated by peer (8Q^WM- ^@<M-Mt^@^@^@^@)
Connect time 0.1 minutes.
Sent 2686 bytes, received 7458 bytes.
Modem hangup
Connection terminated.
 

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

CentOS 7下安装pptp服务 的相关文章

  • 从 Java 读取 /dev/input/js0

    我正在尝试阅读 dev input js0来自Java 但我不断得到 java io IOException Invalid argument at java io FileInputStream read0 Native Method a
  • 如何让 PHP、符号链接和 __FILE__ 很好地协同工作?

    在本地主机上 我有以下目录结构 share www trunk wp content plugins otherfolders share www portfolio wp content symlink Where symlink是一个符
  • 命令行参数中的“-”(破折号)有什么魔力?

    例子 创建 ISO 映像并将其直接刻录到 CD mkisofs V Photos r home vivek photos cdrecord v dev dev dvdrw 更改到上一个目录 cd 侦听端口 12345 并解压发送到该端口的数
  • 干净地销毁System V共享内存段

    我在用shmget shmat and shmctl分别获取和创建共享内存段 将其附加到进程地址空间中并删除它 我想知道进程是否仍然可以使用共享内存段 即使它已被分离并要求使用删除 shmctl id IPC RMID 在一个过程中 我无法
  • 在 Linux 2.6.21 (glibc 2.3.5) 上进行 ARP 和反向 ARP

    我需要在任意 IP 网络上存储对第三方设备的持久引用 其中设备的 IP 地址可能是静态的或由 DHCP 随机分配 我不控制网络上的设备 也不能依赖 DNS 和其他现有的或与设备一起使用的临时网络协议 所以我被指示使用硬件地址和 ARP 进行
  • 在 C 中使用 sqrtf():“未定义对‘sqrtf’的引用”

    我正在使用Linux Ubuntu 12 04 https en wikipedia org wiki Ubuntu version history Ubuntu 12 04 LTS 28Precise Pangolin 29 Precis
  • 如何真正释放 Linux 中的大页面以供新进程使用?

    真的找不到太多关于此的信息 希望有人可以提供帮助 我正在假脱机使用 100GB java 堆作为大数据缓存 为了避免与文件系统缓存等内容发生冲突 并且因为它通常性能更好 我将其分配在大页面中 我保留了 51 200 x 2MB 大页面 一切
  • 如何使用sprof?

    请举例说明 从邮件中找到here http sources redhat com ml libc alpha 2003 07 msg00029 html and here http sourceware org ml binutils 20
  • Bash 中 $() 和 () 之间的区别

    当我打字时ls l echo file 支架的输出 这只是简单的回显 被获取并传递到外部ls l命令 就等于简单的ls l file 当我打字时ls l echo file 我们有错误 因为不能嵌套 内部外部命令 有人可以帮助我理解之间的区
  • 是否可以找到哪个用户位于 localhost TCP 连接的另一端?

    这是一个编程问题 但它是 Linux Unix 特定的 如果我从本地主机获得 TCP 连接 是否有一种简单的方法可以告诉哪个用户在 C 程序内建立了连接而无需 shell 我知道这对于 Unix 域套接字来说并不太难 我已经知道远程 IP
  • 无法为 Python 3.4 创建工作虚拟环境

    I 安装Python 3 4 2 https docs python org 3 using unix html building python和我的 Linux Mint 17 1 中的 Virtualenv 12 0 5 然后我尝试创建
  • 原生 Linux 应用程序可像 ResHacker 一样编辑 Win32 PE

    我想运行自动修改 dll服务 用户提交特定的 dll 我在服务器上修改它 然后用户可以下载 dll的修改版本 是否有任何本机 Linux 应用程序提供常见的 Win32 PE 修改功能 例如图标 字符串 加速器 对话等 至少提供命令行或脚本
  • 在 Ubuntu 上纯粹通过 bash 脚本安装 mysql 5.7

    我想要一个无需任何手动输入即可安装 MySQL 5 7 实例的 bash 脚本 我正在关注数字海洋教程 https www digitalocean com community tutorials how to install mysql
  • gnome-terminal 新选项卡,使用别名作为要执行的命令

    我已经创建了一个别名 bashrc文件如下 alias myproject cd Desktop myproject 当我重新启动终端时保存文件后 输入myproject带我到项目目录 但是当我尝试使用别名作为新的命令参数时gnome te
  • 编写多个mysql脚本

    是否可以在复合脚本中包含其他 mysql 脚本 理想情况下 我不想为包含的脚本创建存储过程 对于较大的项目 我想分层维护几个较小的脚本 然后根据需要组合它们 但现在 我很乐意学习如何包含其他脚本 source是一个内置命令 您可以在 MyS
  • grails 上的同步块在 Windows 上有效,但在 Linux 上无效

    我有一个 grails 应用程序 它依赖于服务中的同步块 当我在 Windows 上运行它时 同步按预期工作 但当我在 ams linux 上运行时 会出现 StaleObjectStateException 该问题在以下示例中重现 cla
  • 如何在 Linux x86_64 上模拟 iret

    我正在编写一个基于 Intel VT 的调试器 由于当 NMI Exiting 1 时 iret 指令在 vmx guest 中的性能发生了变化 所以我应该自己处理vmx主机中的NMI 否则 guest会出现nmi可重入错误 我查了英特尔手
  • sqlite 插入需要很长时间

    我正在将不到 200 000 行插入到 sqlite 数据库表中 我只是在终端中通过 sqlite3 使用一个非常简单的 sql 文件 我打赌它已经运行了至少 30 分钟 这是正常现象还是我应该关闭该过程并尝试不同的方法 sqlite中的插
  • Windows 与 Linux 文本文件读取

    问题是 我最近从 Windows 切换到 Ubuntu 我的一些用于分析数据文件的 python 脚本给了我错误 我不确定如何正确解决 我当前仪器的数据文件输出如下 Header 有关仪器等的各种信息 Data 状态 代码 温度 字段等 0
  • 使用命令行将 MediaWiki 维基文本格式转换为 HTML

    我倾向于编写大量文档 因此 MediaWiki 格式对我来说很容易理解 而且比编写传统 HTML 节省了我很多时间 然而 我也写了一篇博客 发现一直从键盘切换到鼠标来输入正确的 HTML 标签会增加很多时间 我希望能够使用 Mediawik

随机推荐

  • NACHI机械臂后台SOCKET通讯

    NACHI机械臂后台SOCKET通讯 将机械臂做为服务器 电脑作为客户端 通讯程序在机械臂后台运行 我是先在电脑上写好 导入机械臂文件夹中 转化成机器人语言 再在用户任务这里开启它的任务号码 端口号设置为10030 代码 TCP IP So
  • nginx之配置proxy_set_header

    nginx之配置proxy set header win10客户端请求web服务 win10的ip 192 168 223 1 nginx作为反向代理服务器 192 168 223 136 nginx作为后端web服务器 192 168 2
  • 伦敦金天天实时行情走势图

    伦敦金天天的走势图走势图中都有交易的机会 但高质量的交易信号和进场时机不是经常出现 如果能够过滤掉不佳的交易信号 大家的投资绩效就有望大幅提升 在每天的实时行情走势图中 长影线K线是高胜率的信号 它代表金价拒绝上涨或下跌 伦敦金在实时行情走
  • Spring异步Async和事务Transactional注解

    Spring开发中我们我们常常用到 Transaction和 Async 但这2个注解加在一起很多的开发者不敢用 担心事务不生效 下面我们就仔细讲解一下这2个注解同时运用 文章用3个场景讲述它们之间的运用 相信看完本篇文章你就能灵活运用这2
  • Redis集群详解

    Redis集群详解 Redis有三种集群模式 分别是 主从模式 Sentinel模式 Cluster模式 三种集群模式各有特点 关于Redis介绍可以参考这里 NoSQL 二 Redis Redis官网 https redis io 最新版
  • 基类(父类)private 定义的变量,子类可以使用吗

    基类 父类 private 定义的变量 子类是可以使用的 private变量是传给子类了的但是不可以直接使用 需要我们去用基类里面的函数去初始化或修改继承给子类的private变量 就这样就可以调用private变量了
  • 【camera】【ISP】Lens Shading Correction镜头阴影校正

    ISP LSC 镜头阴影校正 参考 https zhuanlan zhihu com p 389334269 https blog csdn net xiaoyouck article details 77206505 https www
  • MariaDB在Linux环境下的安装及使用

    本操作适合Debain ubuntu和deepin等 此处安装的环境为deepin V23 一 查看是否已安装MariaDB mysql V 二 安装命令 sudo apt get install mariadb server 三 修改配置
  • 第一课:LabView2015中文版安装教程

    1 下载解压缩 双击文件 2015LV WinChn exe 将 点击unzip解压 解压路径为默认为 C National Instruments Downloads LabVIEW Chinese 2015 2 软件成功解压后 自动弹出
  • 了解开发手机的各项参数之显示屏

    现在android手机越来越便宜了 所以开发的话用的最多的还是真机 作为一个程序员 如果拿着手机却在百度找手机的参数 这可不太好 所以 让我们从程序员的角度来了解一下手机显示屏的参数 public class MainActivity ex
  • 云服务器物理机配置,物理机服务器怎么配置

    物理机服务器怎么配置 内容精选 换一换 对于不同的硬件设备 通过在BIOS中设置一些高级选项 可以有效提升服务器性能 服务器上的SMMU一般用来完成设备的地址转换 并且可以实现设备隔离 在虚拟化中很实用 但是在物理机测试场景下 SMMU可能
  • 关于部署vue项目在Linux上的两种方式tomcat以及nignx(3)使用nignx进行部署

    阿丹有话说 前两篇文章主要讲解了将vue中tomcat部署研究了 解决了在后台代码中通过过滤器来解决跨域问题 后期会继续出在tomcat中的代理配置等 本篇文章来将vue项目部署在nignx上 并且通过反向代理来解决跨域请求以及请求转发 使
  • Qt自绘圆盘图控件

    本人使用QPainter自绘了一个圆盘图 下面这张图片为效果图 图片中的所有 圆 刻度线 字体 均为自绘 没有使用图片 使用方法 在Ui中拖拽一个widget控件 然后右键点击该widget控件 选择提升 话不多说 直接上代码 头文件qdi
  • 数字图像处理-基于Matlab水果识别系统(图片识别)

    文件大小 25M 代码行数 315行 主程序 开发环境 Matlab2016a 下载地址 该源码均通过亲自测试可正常运行 简要概述 图像识别主要是研究用计算机代替人去处理大量的物理信息 从而帮助人们建华劳动 机械分类耗时段的特点很符合水果的
  • 【译】用 Rust 实现 csv 解析-part1

    Rust and CSV parsing 译文 用 Rust 实现 csv 解析 part1 原文链接 https blog burntsushi net csv 原文作者 BurntSushi 译文来自 https github com
  • OSPF实验及配置---超详细

    什么是OSPF 开放式最短路径优先OSPF Open Shortest Path First 是IETF组织开发的一个基于链路状态的内部网关协议 Interior Gateway Protocol 目前针对IPv4协议使用的是OSPF Ve
  • 【改进算法】混合鲸鱼WOA和BAT算法(Matlab代码实现)

    欢迎来到本博客 博主优势 博客内容尽量做到思维缜密 逻辑清晰 为了方便读者 座右铭 行百里者 半于九十 本文目录如下 目录 1 概述 2 运行结果 3 参考文献 4 Matlab代码及文献 1 概述 文献来源 鲸鱼优化算法 whale op
  • 接口测试开发之:Python3,订单并发性能实战

    小屌丝 鱼哥 我想写一个接口订单并发性能 能不能给我讲一下 小鱼 接口订单并发 我前篇文章不是写过常见并发框架 然后你在追加一个创建订单和生成订单不就可以了 小屌丝 鱼哥 你说的可轻松 那你能不能来一个 小鱼 好吧 那我就以我某个项目为例
  • open cvBrisk特征检测与匹配

    什么是BRISK算法 BRISK算法是2011年ICCV上 BRISK Binary Robust Invariant Scalable Keypoints 文章中 提出来的一种特征提取算法 也是一种二进制的特征描述算子 它具有较好的旋转不
  • CentOS 7下安装pptp服务

    一 检查是否支持PPTP 1 在安装之前查看系统是否支持PPTP modprobe ppp compress 18 echo success 应该输出 success 2 是否开启TUN TAP cat dev net tun 应该输出 c