2019-12-30 02:09:13 -08:00
|
|
|
|
|
|
|
|
|
# nps
|
2020-01-08 07:17:50 -08:00
|
|
|
|
![](https://img.shields.io/github/stars/ehang-io/nps.svg) ![](https://img.shields.io/github/forks/ehang-io/nps.svg)
|
2019-12-30 02:09:13 -08:00
|
|
|
|
[![Gitter](https://badges.gitter.im/cnlh-nps/community.svg)](https://gitter.im/cnlh-nps/community?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge)
|
2020-01-08 07:17:50 -08:00
|
|
|
|
[![Build Status](https://travis-ci.org/ehang-io/nps.svg?branch=master)](https://travis-ci.org/ehang-io/nps)
|
|
|
|
|
![GitHub All Releases](https://img.shields.io/github/downloads/ehang-io/nps/total)
|
2019-12-30 02:09:13 -08:00
|
|
|
|
|
2020-01-08 06:24:03 -08:00
|
|
|
|
[README](https://github.com/ehang-io/nps/blob/master/README.md)|[中文文档](https://github.com/ehang-io/nps/blob/master/README_zh.md)
|
2020-01-02 07:57:13 -08:00
|
|
|
|
|
2019-12-30 02:09:13 -08:00
|
|
|
|
nps是一款轻量级、高性能、功能强大的**内网穿透**代理服务器。目前支持**tcp、udp流量转发**,可支持任何**tcp、udp**上层协议(访问内网网站、本地支付接口调试、ssh访问、远程桌面,内网dns解析等等……),此外还**支持内网http代理、内网socks5代理**、**p2p等**,并带有功能强大的web管理端。
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
## 背景
|
2020-01-08 06:24:03 -08:00
|
|
|
|
![image](https://github.com/ehang-io/nps/blob/master/image/web.png?raw=true)
|
2019-12-30 02:09:13 -08:00
|
|
|
|
|
|
|
|
|
1. 做微信公众号开发、小程序开发等----> 域名代理模式
|
|
|
|
|
|
|
|
|
|
2. 想在外网通过ssh连接内网的机器,做云服务器到内网服务器端口的映射,----> tcp代理模式
|
|
|
|
|
|
|
|
|
|
3. 在非内网环境下使用内网dns,或者需要通过udp访问内网机器等----> udp代理模式
|
|
|
|
|
|
|
|
|
|
4. 在外网使用HTTP代理访问内网站点----> http代理模式
|
|
|
|
|
|
|
|
|
|
5. 搭建一个内网穿透ss,在外网如同使用内网vpn一样访问内网资源或者设备----> socks5代理模式
|
|
|
|
|
## 特点
|
|
|
|
|
- 协议支持全面,兼容几乎所有常用协议,例如tcp、udp、http(s)、socks5、p2p、http代理...
|
|
|
|
|
- 全平台兼容(linux、windows、macos、群辉等),支持一键安装为系统服务
|
|
|
|
|
- 控制全面,同时支持服务端和客户端控制
|
|
|
|
|
- https集成,支持将后端代理和web服务转成https,同时支持多证书
|
|
|
|
|
- 操作简单,只需简单的配置即可在web ui上完成其余操作
|
|
|
|
|
- 展示信息全面,流量、系统信息、即时带宽、客户端版本等
|
|
|
|
|
- 扩展功能强大,该有的都有了(缓存、压缩、加密、流量限制、带宽限制、端口复用等等)
|
|
|
|
|
- 域名解析具备自定义header、404页面配置、host修改、站点保护、URL路由、泛解析等功能
|
|
|
|
|
- 服务端支持多用户和用户注册功能
|
|
|
|
|
|
2020-01-08 06:24:03 -08:00
|
|
|
|
**没找到你想要的功能?不要紧,点击[进入文档](https://ehang-io.github.io/nps)查找吧**
|
2019-12-30 02:09:13 -08:00
|
|
|
|
## 快速开始
|
|
|
|
|
|
|
|
|
|
### 安装
|
2020-01-08 06:24:03 -08:00
|
|
|
|
> [releases](https://github.com/ehang-io/nps/releases)
|
2019-12-30 02:09:13 -08:00
|
|
|
|
|
|
|
|
|
下载对应的系统版本即可,服务端和客户端是单独的
|
|
|
|
|
|
|
|
|
|
### 服务端启动
|
|
|
|
|
下载完服务器压缩包后,解压,然后进入解压后的文件夹
|
|
|
|
|
|
|
|
|
|
- 执行安装命令
|
|
|
|
|
|
|
|
|
|
对于linux|darwin ```sudo ./nps install```
|
|
|
|
|
|
|
|
|
|
对于windows,管理员身份运行cmd,进入安装目录 ```nps.exe install```
|
|
|
|
|
|
|
|
|
|
- 启动
|
|
|
|
|
|
|
|
|
|
对于linux|darwin ```sudo nps start```
|
|
|
|
|
|
|
|
|
|
对于windows,管理员身份运行cmd,进入程序目录 ```nps.exe start```
|
|
|
|
|
|
|
|
|
|
```安装后windows配置文件位于 C:\Program Files\nps,linux和darwin位于/etc/nps```
|
|
|
|
|
|
|
|
|
|
**如果发现没有启动成功,可以查看日志(Windows日志文件位于当前运行目录下,linux和darwin位于/var/log/nps.log)**
|
|
|
|
|
- 访问服务端ip:web服务端口(默认为8080)
|
|
|
|
|
- 使用用户名和密码登陆(默认admin/123,正式使用一定要更改)
|
|
|
|
|
- 创建客户端
|
|
|
|
|
|
|
|
|
|
### 客户端连接
|
|
|
|
|
- 点击web管理中客户端前的+号,复制启动命令
|
|
|
|
|
- 执行启动命令,linux直接执行即可,windows将./npc换成npc.exe用cmd执行
|
|
|
|
|
|
2020-01-08 06:24:03 -08:00
|
|
|
|
如果需要注册到系统服务可查看[注册到系统服务](https://ehang-io.github.io/nps/#/use?id=注册到系统服务)
|
2019-12-30 02:09:13 -08:00
|
|
|
|
|
|
|
|
|
### 配置
|
|
|
|
|
- 客户端连接后,在web中配置对应穿透服务即可
|
2020-01-08 06:24:03 -08:00
|
|
|
|
- 更多高级用法见[完整文档](https://ehang-io.github.io/nps/)
|
2019-12-30 02:09:13 -08:00
|
|
|
|
|
|
|
|
|
## 贡献
|
|
|
|
|
- 如果遇到bug可以直接提交至dev分支
|
|
|
|
|
- 使用遇到问题可以通过issues反馈
|
|
|
|
|
- 项目处于开发阶段,还有很多待完善的地方,如果可以贡献代码,请提交 PR 至 dev 分支
|
|
|
|
|
- 如果有新的功能特性反馈,可以通过issues或者qq群反馈
|