Merge pull request #334 from cnlh/dev

Dev
pull/341/head
ffdfgdfg 2019-12-27 13:19:34 +08:00 committed by GitHub
commit 3875bbfa17
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
11 changed files with 99 additions and 20 deletions

View File

@ -1,5 +1,5 @@
#/bash/sh #/bash/sh
export VERSION=0.25.3 export VERSION=0.25.4
sudo apt-get install gcc-mingw-w64-i686 sudo apt-get install gcc-mingw-w64-i686
env GOOS=windows GOARCH=386 CGO_ENABLED=1 CC=i686-w64-mingw32-gcc go build -ldflags "-s -w -extldflags -static -extldflags -static" -buildmode=c-shared -o npc_sdk.dll cmd/npc/sdk.go env GOOS=windows GOARCH=386 CGO_ENABLED=1 CC=i686-w64-mingw32-gcc go build -ldflags "-s -w -extldflags -static -extldflags -static" -buildmode=c-shared -o npc_sdk.dll cmd/npc/sdk.go
@ -175,5 +175,5 @@ echo "$DOCKER_PASSWORD" | docker login -u "$DOCKER_USERNAME" --password-stdin
export DOCKER_CLI_EXPERIMENTAL=enabled export DOCKER_CLI_EXPERIMENTAL=enabled
docker run --rm --privileged docker/binfmt:66f9012c56a8316f9244ffd7622d7c21c1f6f28d docker run --rm --privileged docker/binfmt:66f9012c56a8316f9244ffd7622d7c21c1f6f28d
docker buildx create --use --name mybuilder docker buildx create --use --name mybuilder
docker buildx build --tag ffdfgdfg/nps:$VERSION --output type=image,push=true --file Dockerfile.nps --platform=linux/amd64,linux/arm64,linux/386,linux/arm . docker buildx build --tag ffdfgdfg/nps:$VERSION --tag ffdfgdfg/nps:latest --output type=image,push=true --file Dockerfile.nps --platform=linux/amd64,linux/arm64,linux/386,linux/arm .
docker buildx build --tag ffdfgdfg/npc:$VERSION --output type=image,push=true --file Dockerfile.npc --platform=linux/amd64,linux/arm64,linux/386,linux/arm . docker buildx build --tag ffdfgdfg/npc:$VERSION --tag ffdfgdfg/npc:latest --output type=image,push=true --file Dockerfile.npc --platform=linux/amd64,linux/arm64,linux/386,linux/arm .

View File

@ -1,6 +1,6 @@
![logo](logo.svg) ![logo](logo.svg)
# NPS <small>0.25.2</small> # NPS <small>0.25.4</small>
> 一款轻量级、高性能、功能强大的内网穿透代理服务器 > 一款轻量级、高性能、功能强大的内网穿透代理服务器

View File

@ -40,4 +40,6 @@
nps-update.exe update nps-update.exe update
``` ```
更新完成后,执行执行`sudo nps start`或者`nps.exe start`重新运行即可完成升级 更新完成后,执行执行`sudo nps start`或者`nps.exe start`重新运行即可完成升级
如果无法更新成功可以直接自行下载releases压缩包然后覆盖原有的nps二进制文件和web目录

View File

@ -36,6 +36,8 @@ npc-update.exe update
更新完成后,执行执行`sudo npc start`或者`npc.exe start`重新运行即可完成升级 更新完成后,执行执行`sudo npc start`或者`npc.exe start`重新运行即可完成升级
如果无法更新成功可以直接自行下载releases压缩包然后覆盖原有的npc二进制文件
## 配置文件模式 ## 配置文件模式
此模式使用nps的公钥或者客户端私钥验证各种配置在客户端完成同时服务端web也可以进行管理 此模式使用nps的公钥或者客户端私钥验证各种配置在客户端完成同时服务端web也可以进行管理
``` ```

View File

@ -2,7 +2,7 @@
<manifest <manifest
xmlns:android="http://schemas.android.com/apk/res/android" xmlns:android="http://schemas.android.com/apk/res/android"
android:versionCode="1" android:versionCode="1"
android:versionName="0.25.3" android:versionName="0.25.4"
package="org.nps.client" package="org.nps.client"
platformBuildVersionCode="15" platformBuildVersionCode="15"
platformBuildVersionName="4.0.4-1406430"> platformBuildVersionName="4.0.4-1406430">

View File

@ -246,6 +246,15 @@ func (Self *MuxPackager) UnPack(reader io.Reader) (n uint16, err error) {
return return
} }
func (Self *MuxPackager) reset() {
Self.Id = 0
Self.Flag = 0
Self.Length = 0
Self.Content = nil
Self.ReadLength = 0
Self.Window = 0
}
const ( const (
ipV4 = 1 ipV4 = 1
domainName = 3 domainName = 3

View File

@ -93,18 +93,20 @@ type windowBufferPool struct {
func (Self *windowBufferPool) New() { func (Self *windowBufferPool) New() {
Self.pool = sync.Pool{ Self.pool = sync.Pool{
New: func() interface{} { New: func() interface{} {
return make([]byte, PoolSizeWindow, PoolSizeWindow) return make([]byte, PoolSizeWindow)
}, },
} }
} }
func (Self *windowBufferPool) Get() (buf []byte) { func (Self *windowBufferPool) Get() (buf []byte) {
buf = Self.pool.Get().([]byte) buf = Self.pool.Get().([]byte)
return buf[:PoolSizeWindow] buf = buf[:PoolSizeWindow]
return buf
} }
func (Self *windowBufferPool) Put(x []byte) { func (Self *windowBufferPool) Put(x []byte) {
Self.pool.Put(x[:PoolSizeWindow]) // make buf to full x = x[:0] // clean buf
Self.pool.Put(x)
} }
type bufferPool struct { type bufferPool struct {
@ -146,6 +148,7 @@ func (Self *muxPackagerPool) Get() *MuxPackager {
} }
func (Self *muxPackagerPool) Put(pack *MuxPackager) { func (Self *muxPackagerPool) Put(pack *MuxPackager) {
pack.reset()
Self.pool.Put(pack) Self.pool.Put(pack)
} }

View File

@ -91,11 +91,13 @@ func copyStaticFile(srcPath, bin string) string {
if _, err := copyFile(filepath.Join(srcPath, bin), "/usr/local/bin/"+bin); err != nil { if _, err := copyFile(filepath.Join(srcPath, bin), "/usr/local/bin/"+bin); err != nil {
log.Fatalln(err) log.Fatalln(err)
} else { } else {
copyFile(filepath.Join(srcPath, "nps"), "/usr/local/bin/"+bin+"-update") copyFile(filepath.Join(srcPath, bin), "/usr/local/bin/"+bin+"-update")
chMod("/usr/local/bin/"+bin+"-update", 0755)
binPath = "/usr/local/bin/" + bin binPath = "/usr/local/bin/" + bin
} }
} else { } else {
copyFile(filepath.Join(srcPath, "nps"), "/usr/bin/"+bin+"-update") copyFile(filepath.Join(srcPath, bin), "/usr/bin/"+bin+"-update")
chMod("/usr/bin/"+bin+"-update", 0755)
binPath = "/usr/bin/" + bin binPath = "/usr/bin/" + bin
} }
} else { } else {

View File

@ -2,6 +2,7 @@ package mux
import ( import (
"errors" "errors"
"github.com/astaxie/beego/logs"
"io" "io"
"math" "math"
"net" "net"
@ -215,10 +216,10 @@ func (Self *ReceiveWindow) calcSize() {
if n < common.MAXIMUM_SEGMENT_SIZE*10 { if n < common.MAXIMUM_SEGMENT_SIZE*10 {
n = common.MAXIMUM_SEGMENT_SIZE * 10 n = common.MAXIMUM_SEGMENT_SIZE * 10
} }
bufLen := Self.bufQueue.Len() //bufLen := Self.bufQueue.Len()
if n < bufLen { //if n < bufLen {
n = bufLen // n = bufLen
} //}
if n < Self.maxSize/2 { if n < Self.maxSize/2 {
n = Self.maxSize / 2 n = Self.maxSize / 2
} }
@ -227,6 +228,7 @@ func (Self *ReceiveWindow) calcSize() {
n = 2 * Self.maxSize n = 2 * Self.maxSize
} }
if n > (common.MAXIMUM_WINDOW_SIZE / uint32(conns)) { if n > (common.MAXIMUM_WINDOW_SIZE / uint32(conns)) {
logs.Warn("window too large", n)
n = common.MAXIMUM_WINDOW_SIZE / uint32(conns) n = common.MAXIMUM_WINDOW_SIZE / uint32(conns)
} }
// set the maximum size // set the maximum size
@ -444,7 +446,20 @@ func (Self *SendWindow) allow() {
} }
func (Self *SendWindow) sent(sentSize uint32) { func (Self *SendWindow) sent(sentSize uint32) {
atomic.AddUint64(&Self.remainingWait, ^(uint64(sentSize)<<dequeueBits - 1)) var remaining, wait uint32
for {
ptrs := atomic.LoadUint64(&Self.remainingWait)
remaining, wait = Self.unpack(ptrs)
if remaining >= sentSize {
atomic.AddUint64(&Self.remainingWait, ^(uint64(sentSize)<<dequeueBits - 1))
break
} else {
if atomic.CompareAndSwapUint64(&Self.remainingWait, ptrs, Self.pack(0, wait)) {
// just keep the wait status, it will be wait in the next loop
break
}
}
}
} }
func (Self *SendWindow) WriteTo() (p []byte, sendSize uint32, part bool, err error) { func (Self *SendWindow) WriteTo() (p []byte, sendSize uint32, part bool, err error) {

View File

@ -5,7 +5,9 @@ import (
"io" "io"
"math" "math"
"net" "net"
"os"
"sync/atomic" "sync/atomic"
"syscall"
"time" "time"
"github.com/astaxie/beego/logs" "github.com/astaxie/beego/logs"
@ -35,13 +37,17 @@ func NewMux(c net.Conn, connType string) *Mux {
//c.(*net.TCPConn).SetReadBuffer(0) //c.(*net.TCPConn).SetReadBuffer(0)
//c.(*net.TCPConn).SetWriteBuffer(0) //c.(*net.TCPConn).SetWriteBuffer(0)
_ = c.SetDeadline(time.Time{}) _ = c.SetDeadline(time.Time{})
fd, err := getConnFd(c)
if err != nil {
logs.Warn(err)
}
m := &Mux{ m := &Mux{
conn: c, conn: c,
connMap: NewConnMap(), connMap: NewConnMap(),
id: 0, id: 0,
closeChan: make(chan struct{}, 1), closeChan: make(chan struct{}, 1),
newConnCh: make(chan *conn), newConnCh: make(chan *conn),
bw: new(bandwidth), bw: NewBandwidth(fd),
IsClose: false, IsClose: false,
connType: connType, connType: connType,
pingCh: make(chan []byte), pingCh: make(chan []byte),
@ -58,6 +64,26 @@ func NewMux(c net.Conn, connType string) *Mux {
return m return m
} }
func getConnFd(c net.Conn) (fd *os.File, err error) {
switch c.(type) {
case *net.TCPConn:
fd, err = c.(*net.TCPConn).File()
if err != nil {
return
}
return
case *net.UDPConn:
fd, err = c.(*net.UDPConn).File()
if err != nil {
return
}
return
default:
err = errors.New("mux:unknown conn type, only tcp or kcp")
return
}
}
func (s *Mux) NewConn() (*conn, error) { func (s *Mux) NewConn() (*conn, error) {
if s.IsClose { if s.IsClose {
return nil, errors.New("the mux has closed") return nil, errors.New("the mux has closed")
@ -392,13 +418,19 @@ type bandwidth struct {
readStart time.Time readStart time.Time
lastReadStart time.Time lastReadStart time.Time
bufLength uint32 bufLength uint32
fd *os.File
calcThreshold uint32
}
func NewBandwidth(fd *os.File) *bandwidth {
return &bandwidth{fd: fd}
} }
func (Self *bandwidth) StartRead() { func (Self *bandwidth) StartRead() {
if Self.readStart.IsZero() { if Self.readStart.IsZero() {
Self.readStart = time.Now() Self.readStart = time.Now()
} }
if Self.bufLength >= common.MAXIMUM_SEGMENT_SIZE*300 { if Self.bufLength >= Self.calcThreshold {
Self.lastReadStart, Self.readStart = Self.readStart, time.Now() Self.lastReadStart, Self.readStart = Self.readStart, time.Now()
Self.calcBandWidth() Self.calcBandWidth()
} }
@ -410,7 +442,21 @@ func (Self *bandwidth) SetCopySize(n uint16) {
func (Self *bandwidth) calcBandWidth() { func (Self *bandwidth) calcBandWidth() {
t := Self.readStart.Sub(Self.lastReadStart) t := Self.readStart.Sub(Self.lastReadStart)
atomic.StoreUint64(&Self.readBandwidth, math.Float64bits(float64(Self.bufLength)/t.Seconds())) bufferSize, err := syscall.GetsockoptInt(int(Self.fd.Fd()), syscall.SOL_SOCKET, syscall.SO_RCVBUF)
//logs.Warn(bufferSize)
if err != nil {
logs.Warn(err)
Self.bufLength = 0
return
}
if Self.bufLength >= uint32(bufferSize) {
atomic.StoreUint64(&Self.readBandwidth, math.Float64bits(float64(Self.bufLength)/t.Seconds()))
// calculate the hole socket buffer, the time meaning to fill the buffer
//logs.Warn(Self.Get())
} else {
Self.calcThreshold = uint32(bufferSize)
}
// socket buffer size is bigger than bufLength, so we don't calculate it
Self.bufLength = 0 Self.bufLength = 0
} }

View File

@ -1,6 +1,6 @@
package version package version
const VERSION = "0.25.3" const VERSION = "0.25.4"
// Compulsory minimum version, Minimum downward compatibility to this version // Compulsory minimum version, Minimum downward compatibility to this version
func GetVersion() string { func GetVersion() string {