分布式框架 one 1.6.7 发布,新增分布式并发模型Actor

栏目: 软件资讯 · 发布时间: 6年前

内容简介:One - 极简 . 高性能 . 松耦合 . 分布式 . 可运行于多种环境(cli,apache/php-fpm,swoole) 码云: https://gitee.com/vicself/one github: https://github.com/lizhichao/one 适用场景 常规web/app后端服务器 游戏/...

One - 极简 . 高性能 . 松耦合 . 分布式 . 可运行于多种环境(cli,apache/php-fpm,swoole)

码云: https://gitee.com/vicself/one
github: https://github.com/lizhichao/one

适用场景

  • 常规web/app后端服务器
  • 游戏/im即时通讯服务器
  • tcp/udp物联网服务器
  • 综合性项目,各种混合协议通讯

修复问题

使用文件(file)缓存时,不设置过期时间缓存失败问题。

新增

  • 新增模型方法flushTableInfo,主动刷新数据表结构缓存。
  • 分布式并发模型Actor

Actor 是什么?

是一种与共享内存对应的并发模型,具有资源独占性。可以理解为一个对象,它有属性和方法。

主要方法

  1. Actor::init() 创建Actor
  2. Actor::drop($actor_id) 删除Actor
  3. Actor::call($actor_id, $method, $args) Actor通讯

适合场景

每个对象都在变化,对象之间有通讯的场景。

例1 游戏:

每个角色就是一个actor实例:
属性:生命值,攻击力
方法:生命值加/减


class UserActor extends Actor
{
    // 生命值
    private $life_value = 10;

    // 攻击力
    private $power_value = 5;

    // 长连接fd
    public $fd;

    // 返回自己的actor id
    public function getActorId()
    {
        return $this->actor_id;
    }

    // 改变生命值 并 通知客户端
    public function changeLifeValue($n)
    {
        $this->life_value += $n;
        $this->noticeClient();
    }

    // 攻击某个 Actor =>  减少Actor的生命值
    // 被攻击Actor可以其他进程或者其他机器上
    public function fire($actor_id)
    {
        $this->call($actor_id,'changeLifeValue',[$this->power_value]);
    }

    // 通知客户端当前的生命值
    public function noticeClient()
    {
        self::$server->push($this->fd,$this->life_value);
    }
}

// 实例化一个角色
$user1 = UserActor::init();

// 获取这个角色的actor_id
$actor_id = $user1->getActorId();

// 角色死亡 销毁 actor
UserActor::drop($actor_id);

Vs 共享内存方式

每个用户的属性需要储存在一个公共的地方,每次存取都很麻烦。如果改变用户的属性值还需要考虑并发问题。如果属性更多编写起来将非常复杂。
例如:用户a,b,c。 都分布在不同的机器上。a和b同时打到了c;


以上所述就是小编给大家介绍的《分布式框架 one 1.6.7 发布,新增分布式并发模型Actor》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

算法(英文版•第4版)

算法(英文版•第4版)

[美] Robert Sedgewick、[美] Kevin Wayne / 人民邮电出版社 / 2016-3 / 129.00元

本书作为算法领域经典的参考书,全面介绍了关于算法和数据结构的必备知识,并特别针对排序、搜索、图处理和字符串处理进行了论述。第4 版具体给出了每位程序员应知应会的50 个算法,提供了实际代码,而且这些Java 代码实现采用了模块化的编程风格,读者可以方便地加以改造。本书配套网站提供了本书内容的摘要及更多的代码实现、测试数据、练习、教学课件等资源。一起来看看 《算法(英文版•第4版)》 这本书的介绍吧!

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具