百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分析 > 正文

云风skynet-游戏开发核心技术实战:手撕一个高性能网关

liebian365 2025-02-15 16:25 9 浏览 0 评论

专注分享Linux后台服务器开发,包括C/C++,Linux,Nginx,Skynet,ZeroMQ,MySQL,Redis,fastdfs,MongoDB,ZK,流媒体服务器,CDN,P2P,K8S,Docker,TCP/IP,协程,DPDK等等技术,文末领取资料福利包!

一、环境安装

1. centos

yum install -y git gcc readline-devel autoconf

2. ubuntu

apt-get install git build-essential readline-dev autoconf

apt-get install git build-essential libreadline-dev autoconf (for ubuntu 16.04)

3. mac

brew install git gcc readline autocon

二、获取代码以及编译

git clone https://github.com/cloudwu/skynet.git

cd skynet

centos&&ubuntu:

make linux

mac:

make macosx

三、关于 win10

1. 开启开发者模式

系统设置->更新和安全->针对开发人员->开发者模式

2. 启用 linux 子系统组件

系统设置->应用->程序和功能->启动或关闭 windows 功能->适用于 linux 的 windows 子系

统->重启更新

3. 安装 linux 子系统

windows 应用商店->Ubuntu->修改 sources.list

https://mirrors.tuna.tsinghua.edu.cn/help/ubuntu/

选择 18.04LTS

4. 在 win10 中 vscode 安装 wsl 插件

5. 在子系统 Ubuntu 中添加 skynet 源码

四、多核开发与 actor 模型

1. 多进程

a) 消息队列

i. 协议问题

ii. 断线重连

iii. 进程启动顺序问题

iv. 负载均衡问题

v. 数据同步问题

b) RPC

i. 两个系统保持同步问题

c) zk

i. 配置项管理问题

ii. 集群管理

iii. 统一命名问题

iv. 状态同步问题

v. 分布式锁问题

d) 拆分

i. 功能拆分

ii. 热点拆分

2. 多线程

3. 并发模型 :CSP 模型 与 actor 模型

4. 结论:多进程并发实体是进程,多线程并发实体是线程,go 并发实体是 goroutine(协

程),actor 并发实体是 actor(语言层面抽象出来的“进程”)。它们都是在隔离性(运行环

境)与统一性(数据统一)之间作取舍平衡,而 actor 模型在语言层面做运行环境的隔离,

数据同步依然需要通过消息来同步。actor 模型是加强版的多进程解决方案,进程间通信由

socket 转为指针的传递,从而通信变得更加可靠,同时多进程解决方案中,公共开源组件(消

息队列,rpc,zookeeper)解决的问题,在 actor 模型中处理起来更方便。

5. actor 定义:

a) 用于并行计算

b) actor 是最基本的计算单元

c) 基于消息计算

d) actor 之间通过消息沟通并且相互隔离

五、skynet 中的 actor 模型

1. 结构组成

a) 隔离的环境(内存块或 lua 虚拟机)

b) 消息队列

c) 回调函数

2. 实现

a) logger 服务
service-src/service_logger.c

b) lua 服务启动器
service-src/service_snlua.c

六、actor 运行以及消息调度

1. 消息队列

a) 全局消息队列

b) actor 消息队列

2. skynet 中锁的使用

a) 互斥锁

b) 自旋锁

i. worker 轮询消息队列

c) 读写锁

i. handle_storage

d) 条件变量

i. worker 线程的休眠

3. skynet 中线程

a) timer

b) socket

c) worker

i. “权重”来定制消费消息的数量(-1 消费一个,0 全部消费,1 消费一半)

ii. 休眠(条件变量)与唤醒(timer 和 socket)

d) monitor

i. 检查服务消息过载

七、lua 与 c 接口编程

1. lua 数据类型

a) boolean,number,string,function,userdata,lightuserdata,thread,table(__index,__newind

ex,__gc,__len),nil

2. table

a) table.concat

b) table.insert

c) table.remove

d) table.sort

e) hash 表来使用

3. 元表

a) 定制行为 __index, __newindex

b) 只有 table 和 userdata 对象有独自的元表,其他类型只有类型元表

c) 只有 table 可以在 lua 中修改设置元表

d) userdata 只能在 c 中修改设置元表,lua 中不能修改 userdata 元表

4. 协程

a) 一段独立的执行线程

b) 一个 lua 虚拟机中同时只能有一个协程在运行

c) 目的:写的时候是同步的书写方式,而实际内部是异步非阻塞的实现

5. 闭包

a) 表现

i. 函数内部可以访问函数外部的变量

ii. lua 文件是一个匿名函数

b) 实现

i. c 函数以及绑定在 c 函数上的 upvalues(上值)

c) 用 lua_pushcclosure 用来创建 c 闭包

d) 通过 lua_upvalueindex 伪索引来获取上值

6. 虚拟栈

a) 栈上的都是 lua 类型的值

b) lua 调用 c 的函数都得到一个新的栈,独立于之前的栈

c) c 调用 lua,每一个协程都有一个栈,没有显示创建那么就是主协程上一个栈

7. 注册表

a) 预定义的表,用来保存任何 c 代码想保存的 lua 值

b) 使用 LUA_REGISTRYINDEX 来索引

八、skynet 网络 IO

1. 阻塞 io 和非阻塞 io

a) 阻塞在网络线程

b) io 操作(read/write)在没有数据到达时是否立刻返回

c) fd 决定了是否阻塞

2. 多路复用以及 epoll

3. epoll_event 与 actor 模型关联

4. 单线程读与多线程写

PS: skynet 实际使用的状态切换来实现的 epoll_wait 后的事件遍历。这里为了在一个循

环中将 skynet 网络功能演示。

九、actor 通信细节

1. skynet.send/skynet.call

2. skynet.redirect

3. skynet.response

4. skynet.ret

【文末福利】:小编整理了一些个人觉得比较好的学习书籍、视频资料共享在群文件里面,有需要的可以私信【1】加群找群主免费领取~更多免费直播技术点击免费即可开始学习C/C++Linux服务器开发/后台架构师【零声教育】-学习视频教程-腾讯课堂

相关推荐

4万多吨豪华游轮遇险 竟是因为这个原因……

(观察者网讯)4.7万吨豪华游轮搁浅,竟是因为油量太低?据观察者网此前报道,挪威游轮“维京天空”号上周六(23日)在挪威近海发生引擎故障搁浅。船上载有1300多人,其中28人受伤住院。经过数天的调...

“菜鸟黑客”必用兵器之“渗透测试篇二”

"菜鸟黑客"必用兵器之"渗透测试篇二"上篇文章主要针对伙伴们对"渗透测试"应该如何学习?"渗透测试"的基本流程?本篇文章继续上次的分享,接着介绍一下黑客们常用的渗透测试工具有哪些?以及用实验环境让大家...

科幻春晚丨《震动羽翼说“Hello”》两万年星间飞行,探测器对地球的最终告白

作者|藤井太洋译者|祝力新【编者按】2021年科幻春晚的最后一篇小说,来自大家喜爱的日本科幻作家藤井太洋。小说将视角放在一颗太空探测器上,延续了他一贯的浪漫风格。...

麦子陪你做作业(二):KEGG通路数据库的正确打开姿势

作者:麦子KEGG是通路数据库中最庞大的,涵盖基因组网络信息,主要注释基因的功能和调控关系。当我们选到了合适的候选分子,单变量研究也已做完,接着研究机制的时便可使用到它。你需要了解你的分子目前已有哪些...

知存科技王绍迪:突破存储墙瓶颈,详解存算一体架构优势

智东西(公众号:zhidxcom)编辑|韦世玮智东西6月5日消息,近日,在落幕不久的GTIC2021嵌入式AI创新峰会上,知存科技CEO王绍迪博士以《存算一体AI芯片:AIoT设备的算力新选择》...

每日新闻播报(September 14)_每日新闻播报英文

AnOscarstatuestandscoveredwithplasticduringpreparationsleadinguptothe87thAcademyAward...

香港新巴城巴开放实时到站数据 供科技界研发使用

中新网3月22日电据香港《明报》报道,香港特区政府致力推动智慧城市,鼓励公私营机构开放数据,以便科技界研发使用。香港运输署21日与新巴及城巴(两巴)公司签署谅解备忘录,两巴将于2019年第3季度,开...

5款不容错过的APP: Red Bull Alert,Flipagram,WifiMapper

本周有不少非常出色的app推出,鸵鸟电台做了一个小合集。亮相本周榜单的有WifiMapper's安卓版的app,其中包含了RedBull的一款新型闹钟,还有一款可爱的怪物主题益智游戏。一起来看看我...

Qt动画效果展示_qt显示图片

今天在这篇博文中,主要实践Qt动画,做一个实例来讲解Qt动画使用,其界面如下图所示(由于没有录制为gif动画图片,所以请各位下载查看效果):该程序使用应用程序单窗口,主窗口继承于QMainWindow...

如何从0到1设计实现一门自己的脚本语言

作者:dong...

三年级语文上册 仿写句子 需要的直接下载打印吧

描写秋天的好句好段1.秋天来了,山野变成了美丽的图画。苹果露出红红的脸庞,梨树挂起金黄的灯笼,高粱举起了燃烧的火把。大雁在天空一会儿写“人”字,一会儿写“一”字。2.花园里,菊花争奇斗艳,红的似火,粉...

C++|那些一看就很简洁、优雅、经典的小代码段

目录0等概率随机洗牌:1大小写转换2字符串复制...

二年级上册语文必考句子仿写,家长打印,孩子照着练

二年级上册语文必考句子仿写,家长打印,孩子照着练。具体如下:...

一年级语文上 句子专项练习(可打印)

...

亲自上阵!C++ 大佬深度“剧透”:C++26 将如何在代码生成上对抗 Rust?

...

取消回复欢迎 发表评论: