golang 并行转串行透明代理

xtxy · · 2116 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

放在这里做个备份


package main

import (
	"fmt"
	"log"
	"net"
)

const (
	realServer = "127.0.0.1:9002"
	selfPort   = 9010
)

type gameConn struct {
	ClientConn net.Conn
	PkgBuf     [maxPkgSize]byte
	PkgLen     int
	Channel    chan int
}

var gbChannel chan int
var connMap map[int](*gameConn)

func main() {
	// Listen on TCP port 2000 on all interfaces.
	ip := net.ParseIP("0.0.0.0")
	addr := net.TCPAddr{ip, selfPort}
	l, err := net.ListenTCP("tcp", &addr)
	if err != nil {
		log.Fatal(err)
	}

	serverConn, err := net.Dial("tcp", realServer)
	if err != nil {
		fmt.Println(err)
		return
	}

	log.Printf("starting server...")

	gbChannel = make(chan int)
	connMap = make(map[int](*gameConn))
	index := 0

	go redisProcess(serverConn)

	for {
		// Wait for a connection.
		conn, err := l.AcceptTCP()
		if err != nil {
			log.Fatal(err)
		}

		go start(conn, index)

		index++
	}
}


package main

import (
	"fmt"
	"net"
)

const (
	maxPkgSize = (4 * 1024 * 1024)
)

func start(netConn net.Conn, id int) {
	connInfo := new(gameConn)
	connInfo.ClientConn = netConn
	connInfo.Channel = make(chan int)

	connMap[id] = connInfo

	var err error
	connInfo.PkgLen, err = netConn.Read(connInfo.PkgBuf[:])
	if err != nil {
		fmt.Println(err)
		return
	} else if connInfo.PkgLen >= maxPkgSize {
		fmt.Printf("too long:%i\n", connInfo.PkgLen)
	} else {
		//		fmt.Printf("length:%i\n", length)
	}

	gbChannel <- id

	for {
		<-connInfo.Channel

		connInfo.PkgLen, err = netConn.Read(connInfo.PkgBuf[:])
		if err != nil {
			fmt.Println(err)
			return
		} else if connInfo.PkgLen >= maxPkgSize {
			fmt.Printf("too long:%i\n", connInfo.PkgLen)
		} else {
			//			fmt.Printf("length:%i\n", length)
		}

		gbChannel <- id
	}
}

func redisProcess(serverConn net.Conn) {
	var pGameConn *gameConn
	var id int
	for {
		id = <-gbChannel

		pGameConn = connMap[id]
		if pGameConn == nil {
			continue
		}

		length, err := serverConn.Write(pGameConn.PkgBuf[:pGameConn.PkgLen])
		if err != nil {
			fmt.Println(err)
			continue
		}

		length, err = serverConn.Read(pGameConn.PkgBuf[:])
		if err != nil {
			fmt.Println(err)
			continue
		} else if length >= maxPkgSize {
			fmt.Printf("too long:%i\n", length)
		} else {
			//		fmt.Printf("length:%i\n", length)
		}

		length, err = pGameConn.ClientConn.Write(pGameConn.PkgBuf[:length])
		if err != nil {
			fmt.Println(err)
			continue
		}

		pGameConn.Channel <- 1
	}

}



版权声明:本文为博主原创文章,未经博主允许不得转载。


有疑问加站长微信联系(非本文作者)

本文来自:CSDN博客

感谢作者:xtxy

查看原文:golang 并行转串行透明代理

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

2116 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传