Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/brewlin/net-protocol

golang模拟内核协议栈 实现链路层、网络层、传输层、应用层 用户态协议栈 ,基于虚拟网卡TUN/TAP
https://github.com/brewlin/net-protocol

arp ethernet-protocol golang http http-protocol icmp ipv4 ipv6 protocol tap tcp tun udp websocket websocket-protocol

Last synced: 3 months ago
JSON representation

golang模拟内核协议栈 实现链路层、网络层、传输层、应用层 用户态协议栈 ,基于虚拟网卡TUN/TAP

Awesome Lists containing this project

README

        

# net-protocol


GitHub last commit
GitHub
GitHub code size in bytes
GitHub release (latest by date)

基于go 实现链路层、网络层、传输层、应用层 网络协议栈 ,使用虚拟网卡实现 docs: https://wiki.brewlin.com/wiki/github/net-protocol/index/
## @demo && test
相关demo以及协议测试在cmd目录下,`cd ./cmd*`

docker
```
> docker run -d --device /dev/net/tun:/dev/net/tun --privileged brewlin/net-protocol
> docker exec -it containerid /bin/bash
> go run cmd/transport/udp/server/main.go
> go run cmd/transport/udp/net_client.go

```
## @application 应用层
- [x] [http](https://wiki.brewlin.com/wiki/github/net-protocol/index/)
- [x] [websocket](http://wiki.brewlin.com/wiki/github/net-protocol/index/)
- [x] [dns](http://wiki.brewlin.com/wiki/github/net-protocol/index/)

## @transport 传输层
- [x] [tcp](http://wiki.brewlin.com/wiki/github/net-protocol/index/)
- [x] [udp](http://wiki.brewlin.com/wiki/github/net-protocol/index/)
- [x] [port](http://wiki.brewlin.com/wiki/github/net-protocol/index/) 端口机制

## @network 网络层
- [x] [icmp](http://wiki.brewlin.com/wiki/github/net-protocol/index/)
- [x] [ipv4](http://wiki.brewlin.com/wiki/github/net-protocol/index/)
- [x] [ipv6](http://wiki.brewlin.com/wiki/github/net-protocol/index/)

## @link 链路层
- [x] [arp](http://wiki.brewlin.com/wiki/github/net-protocol/index/)
- [x] [ethernet](http://wiki.brewlin.com/wiki/github/net-protocol/index/)

## @物理层
- [x] tun [tap](http://wiki.brewlin.com/wiki/github/net-protocol/index/) 虚拟网卡的实现

## @客户端
发起客户端请求
- [x] [http client](http://wiki.brewlin.com/wiki/github/net-protocol/index/)
- [x] [websocket client](http://wiki.brewlin.com/github/wiki/net-protocol/index/)
- [x] [tcp client](http://wiki.brewlin.com/wiki/github/net-protocol/index/)
- [x] [udp client](http://wiki.brewlin.com/wiki/github/net-protocol/index/)
- [x] [dns client](http://wiki.brewlin.com/wiki/github/net-protocol/index/)
## 协议相关构体
具体细节文档:http://wiki.brewlin.com/wiki/github/net-protocol/index/
### 1.应用层相关协议
应用层暂时只实现了`http`、`websocket`、`dns`协议。都基于tcp、udp等进行二次封装

http protocol:
```
http 协议报文
GET /chat HTTP/1.1
Host: server.example.com
Upgrade: websocket
Connection: Upgrade
Sec-WebSocket-Key: dGhlIHNhbXBsZSBub25jZQ==
Origin: http://example.com
Sec-WebSocket-Protcol: chat, superchat
Sec-WebSocket-Version: 13
```
websocket protocol:
```
websocket 数据帧报文

0 1 2 3 4
0 1 2 3 4 5 6 7 8 1 2 3 4 5 6 7 8 1 2 3 4 5 6 7 8 1 2 3 4 5 6 7 8
+-+-+-+-+-------+-+-------------+-------------------------------+
|F|R|R|R| opcode|M| Payload len | Extended payload length |
|I|S|S|S| (4) |A| (7) | (16/64) |
|N|V|V|V| |S| | (if payload len==126/127) |
| |1|2|3| |K| | |
+-+-+-+-+-------+-+-------------+ - - - - - - - - - - - - - - - +
| Extended payload length continued, if payload len == 127 |
+ - - - - - - - - - - - - - - - +-------------------------------+
| |Masking-key, if MASK set to 1 |
+-------------------------------+-------------------------------+
| Masking-key (continued) | Payload Data |
+-------------------------------- - - - - - - - - - - - - - - - +
: Payload Data continued ... :
+ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - +
| Payload Data continued ... |
+---------------------------------------------------------------+

```
### 2.传输层相关协议
传输层实现了`upd`、`tcp`、等协议,实现了主要接口

tcp protocol:

```
tcp 首部协议报文
0 1 2 3 4
0 1 2 3 4 5 6 7 8 1 2 3 4 5 6 7 8 1 2 3 4 5 6 7 8 1 2 3 4 5 6 7 8
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Source Port | Destination Port |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Sequence Number |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Acknowledgment Number |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Data | |U|A|P|R|S|F| |
| Offset| Reserved |R|C|S|S|Y|I| Window |
| | |G|K|H|T|N|N| |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Checksum | Urgent Pointer |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Options | Padding |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| data |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
```

udp-protocol:
```
udp 协议报文
```

端口机制

### 3.网络层相关协议

ip protocol:
```
ip头部协议报文
0 1 2 3 4
0 1 2 3 4 5 6 7 8 1 2 3 4 5 6 7 8 1 2 3 4 5 6 7 8 1 2 3 4 5 6 7 8
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|Version| LHL | Type of Service | Total Length |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Identification(fragment Id) |Flags| Fragment Offset |
| 16 bits |R|D|M| 13 bits |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Time-To-Live | Protocol | Header Checksum |
| ttl(8 bits) | 8 bits | 16 bits |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Source IP Address (32 bits) |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Destination Ip Address (32 bits) |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Options (*** bits) | Padding |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
```