专栏首页simdsoftyasio - 轻量级跨平台socket库
原创

yasio - 轻量级跨平台socket库

yasio - Yet Another Socket IO service

yasio 是一个轻量级跨平台的异步socket库,专注于客户端和基于各种游戏引擎的游戏客户端网络服务, 支持win32 & linux & apple & android & win10-universal。

应用案例

  • 红警OL手游项目: 用于客户端网络传输,并且随着该项目于2018年10月17日由腾讯游戏发行正式上线后稳定运行于上百万移动设备上。
  • x-studio软件项目: 用于实现局域网UDP+TCP发现更新机制。
  • xlua集成: 将yasio集成到xlua, 使基于xlua的unity3d可以直接使用yasio的lua绑定接口。

用法

C++

#include "yasio/yasio.hpp"
using namespace yasio;
using namespace yasio::inet;

int main()
{
  io_service service({"www.ip138.com", 80});
  service.set_option(YOPT_S_DEFERRED_EVENT, 0); // 直接在网络线程分派网络事件
  service.start_service([&](event_ptr&& ev) {
    switch (ev->kind())
    {
      case YEK_PACKET: {
        auto packet = std::move(ev->packet());
        fwrite(packet.data(), packet.size(), 1, stdout);
        fflush(stdout);
        break;
      }
      case YEK_CONNECT_RESPONSE:
        if (ev->status() == 0)
        {
          auto transport = ev->transport();
          if (ev->cindex() == 0)
          {
            obstream obs;
            obs.write_bytes("GET /index.htm HTTP/1.1\r\n");

            obs.write_bytes("Host: www.ip138.com\r\n");

            obs.write_bytes("User-Agent: Mozilla/5.0 (Windows NT 10.0; "
                            "WOW64) AppleWebKit/537.36 (KHTML, like Gecko) "
                            "Chrome/79.0.3945.117 Safari/537.36\r\n");
            obs.write_bytes("Accept: */*;q=0.8\r\n");
            obs.write_bytes("Connection: Close\r\n\r\n");

            service.write(transport, std::move(obs.buffer()));
          }
        }
        break;
      case YEK_CONNECTION_LOST:
        printf("The connection is lost.\n");
        break;
    }
  });
  // open channel 0 as tcp client
  service.open(0, YCK_TCP_CLIENT);
  getchar();
}

Lua

local ip138 = "www.ip138.com"
local service = yasio.io_service.new({host=ip138, port=80})
local respdata = ""
-- 传入网络事件处理函数启动网络服务线程,网络事件有: 消息包,连接响应,连接丢失
service.start_service(function(ev)
        local k = ev.kind()
        if (k == yasio.YEK_PACKET) then
            respdata = respdata .. ev:packet():to_string()
        elseif k == yasio.YEK_CONNECT_RESPONSE then
            if ev:status() == 0 then -- status为0表示连接建立成功
                local transport = ev:transport()
                local obs = yasio.obstream.new()
                obs.write_bytes("GET / HTTP/1.1\r\n")

                obs.write_bytes("Host: " .. ip138 .. "\r\n")

                obs.write_bytes("User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/79.0.3945.117 Safari/537.36\r\n")
                obs.write_bytes("Accept: */*;q=0.8\r\n")
                obs.write_bytes("Connection: Close\r\n\r\n")

                service.write(transport, obs)
            end
        elseif k == yasio.YEK_CONNECTION_LOST then
            print("request finish, respdata: " ..  respdata)
        end
    end)
-- 将信道0作为TCP客户端打开,并向服务器发起异步连接,进行TCP三次握手
service.open(0, yasio.YCK_TCP_CLIENT)

-- 由于lua_State和渲染对象,不支持在其他线程操作,因此分派网络事件封装为全局Lua函数,并且以下函数应该在主线程或者游戏引擎渲染线程调用
function gDispatchNetworkEvent(...)
    service.dispatch(128) -- 每帧最多处理128个网络事件
end

_G.yservice = service -- Store service to global table as a singleton instance

使用g++快速运行tcptest测试程序

g++ tests/tcp/main.cpp --std=c++11 -DYASIO_HEADER_ONLY -lpthread -I./ -o tcptest && ./tcptest

使用CMake编译yasio的测试程序和示例程序

git clone https://github.com/simdsoft/yasio
cd yasio
git submodule update --init --recursive
cd build
cmake ..

# 使用CMake命令行编译
# 或者直接用VS打开 yasio.sln 解决方案
cmake --build . --config Debug

特性:

  • 支持IPv6_only网络。
  • 支持处理多个连接的所有网络事件。
  • 支持计时器。
  • 支持TCP粘包处理,业务完全不必关心。
  • 支持Lua绑定。
  • 支持Cocos2d-x jsb绑定。
  • 支持CocosCreator jsb2.0绑定。
  • 支持Unity3D C#绑定。
  • 支持组播。
  • 支持SSL客户端,基于OpenSSL。
  • 支持非阻塞域名解析,基于c-ares。

yasio核心设计,充分利用了多路io复用模型(服务器高并发的基石),以下是框架图

https://github.com/yasio/yasio/blob/master/framework.png

集成指南

https://github.com/yasio/yasio/wiki/Integrate-Guides

更多详细用法,请查看 文档

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • yasio-3.33.0发布了

    距离上一个版本v3.31.3发布,已经过去3个多月,对yasio的维护并没有停歇,v3.33.0主要更新内容如下:

    simdsoft
  • 论跨PC和移动平台socket库yasio的设计和实现原理

    之前分享的文章是对yasio特性和用法的描述:https://blog.csdn.net/xseekerj/article/details/51891362 本...

    simdsoft
  • 基于DNSmasq写了个WEB界面(开源)

    网上找了一下好像没有合适的 DNSmasq WEB 界面,虽然 DNSmasq 配置已经足够简单了,但还是觉得 WEB 管理更加方便。

    砸漏
  • centos7.0体验与之前版本的不同

    今天下午,没事干,在一台机器上装了一个centos7玩一玩,发现与之前版本有很大不同,不知道rhel7是不是也是这样,毕竟现在centos属于redhat了。 ...

    小小科
  • [记] 初次体验小程序绑定合法域名的坑

    游魂
  • 嵌入式人工智能,这是A股公司中科创达的新押注

    李根 发自 北京国际会议中心 量子位 报道 | 公众号 QbitAI ? △ 中科创达上市以来股价 2015年12月,中科创达以“智能终端操作系统”A股上市。...

    量子位
  • js复制插件clipboard全平台兼容

    github项目地址:https://github.com/zenorocha/clipboard.js/

    墨渊
  • 谷歌开放全新自然语言数据集

    近日,谷歌宣布开放两个新的自然语言对话数据集,分别是 Coached Conversational Preference Elicitation(CCPE)和 ...

    AI研习社
  • 生物领域的大数据有多值钱?

    大数据文摘
  • 【经验分享】英国数据分析师讲故事:我是如何走上数据分析之路的?

    我本科毕业于一个三流的二本院校,专业是三流中的三流—市场营销。大学前三年在各种游戏中度过,连兼职和实习的经历都没有。到大四的时候突然开始恐慌,觉得这样下去连工作...

    用户1756920

扫码关注云+社区

领取腾讯云代金券