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

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

内容简介: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》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

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

Agile Web Development with Rails, Third Edition

Agile Web Development with Rails, Third Edition

Sam Ruby、Dave Thomas、David Heinemeier Hansson / Pragmatic Bookshelf / 2009-03-17 / USD 43.95

Rails just keeps on changing. Rails 2, released in 2008, brings hundreds of improvements, including new support for RESTful applications, new generator options, and so on. And, as importantly, we’ve a......一起来看看 《Agile Web Development with Rails, Third Edition》 这本书的介绍吧!

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具

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

HEX HSV 互换工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具