hyperf | 萌推 PHP 微服务化改造

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介: 刚进萌推时输出的一份文档, 现在回头看来, 有不少地方值得推敲. 先放到 blog 上, 权且抛砖引玉吧.

刚进萌推时输出的一份文档, 现在回头看来, 有不少地方值得推敲. 先放到 blog 上, 权且抛砖引玉吧.

微服务基础 & 选型

服务化架构演进

微服务现状, 以 spring 为例, 怎么把单体服务 -> 微服务

microservice - spring cloud

PHP 微服务现状: 包含 hyperf 框架实现的支持
hyperf doc: 包含框架组件 + 脚手架

开发组支持, 全部都是线上在使用, 统计截止时间 2019.05:

  • 李/武: KnowYourself - 在线教育
  • 黄/张: KK - 新零售
  • dayday: 萌推

迁移计划

  • 评审, 可行性分析, 现有业务贴合度
  • 技术培训:

    • 微服务化概念
    • swoole服务器开发入门(全协程)

      • 根据 swoole wiki 整理: swoole| swoole wiki 笔记
      • NP(network programming)基础
      • swoole 协程
      • swoole 核心模块/各功能组件一览
    • hyperf框架基础:

      • hyperf-component: 框架核心, 由开发组维护, 欢迎一起参与
      • hyperf-skeleton: 开发组提供的全量 demo, 需要的功能都可以在这里找到代码实例
      • doc 已经可以满足常规开发使用
      • 框架核心/特性/快速入门
  • 基础设施搭建与现有基础服务接入

    • hyperf 组件+脚手架+开发环境/测试环境(建议docker, mac 下搭建很快)
    • 日志
    • 监控
    • cache
    • redis
    • mysql
    • 异步队列
    • mq: rabbitmq kafka
    • consul
    • grpc
    • zipkin
    • ...
  • 业务服务接入, 基础服务可以配合服务的接入过程一步步来

    • 选取非核心service, 加入 A/B test 验证
    • 切换到核心服务

改造过程相关问题

  • 推进: 暂时将微服务改造放到第二优先级, 业务按照 紧急/重要 2个维度来评估是否插入
  • 工程衡量指标

    • 开发效率: 容易卡住的点, 是否需要提供技术培训; 任务时间的评估, 留好buffer
    • 错误率, 错误响应时间(解决问题的效率): 前期 日志/监控/报警 等基础服务, 人员的熟悉
  • 人员分配: 待评估

    • 运维部署, 测试环境/pre/prod, 各环境下的依赖
    • 具体开发人员角色切换
  • 改造过程中的业务痛点问题攻关

    • 熟悉业务, 才能技术上有的放矢
    • 提炼出工作流: 问题 负责人 涉及业务模块 监控日志 处理时效 总结

more

  • 关于工作流的一个例子: db小分队解决慢查 -> 邮件慢查给技术经理 -> 成立小分队(数据分析团队兼任) -> 看慢查, 提建议给业务开发 -> 自己处理, 不确定再和业务开发对
  • 关于2种技术管理风格: 传统 vs film, 传统 -> 技术经理越来越强; film -> 能力越大, 责任越大
  • 关于新人培训: 来源于以前CTO的经验, 结合我几次经历重构的经验, 场景其实出奇的一致(新入职的新, 和重构需要面临的新), 要给「新人超出现有能力的任务」
目录
相关文章
|
9月前
|
JSON 网络协议 PHP
PHP写微服务之Hyperf
PHP写微服务之Hyperf
235 0
PHP写微服务之Hyperf
|
PHP 开发者 微服务
阿里云栖开发者沙龙PHP技术专场-直面PHP微服务架构挑战-高驰涛
阿里云栖开发者沙龙PHP技术专场-直面PHP微服务架构挑战-高驰涛
216 0
阿里云栖开发者沙龙PHP技术专场-直面PHP微服务架构挑战-高驰涛
|
存储 消息中间件 NoSQL
PHP 基于 SW-X 框架,搭建RPC微服务支持
SW-X的微服务也可用于优化FPM业务,底层使用了TCP通讯协议,支持基于AES的数据加解密支持,官方提供了Swoole/FPM下的RPC客户端,并提供了纯基于Redis存储管理的RPC服务中心。
|
弹性计算 监控 Devops
php| php 微服务之旅: devops
本篇属于 `PHP 微服务之旅` 系列, 此系列会持续更新, 敬请期待.
339 0
|
运维 API PHP
php| php 微服务之旅: 配置中心
这篇我们来撸配置中心. 为啥要用配置中心呢? 我用个讨巧的方式来回答这个问题:
517 0
|
消息中间件 API 网络安全
阿里云微服务消息队列MQTT管控 API PHP SDK 测试Quick Start
微消息队列MQTT版是阿里云推出的一款面向移动互联网以及物联网领域的轻量级消息中间件。如果说传统的消息队列中间件一般应用于微服务之间,那么适用于物联网的微消息队列MQTT版则实现了端与云之间的消息传递和真正意义上的万物互联。前面介绍了Java SDK本地调用方法,这里介绍一下PHP SDK快速调用方法。
402 0
阿里云微服务消息队列MQTT管控 API PHP SDK 测试Quick Start
|
消息中间件 大数据 PHP
PHP技术月刊第2期:直面PHP微服务架构挑战
云栖社区“世界上最好的编程语言”——PHP开始发布技术月刊啦。PHP技术月刊将会为大家介绍最新的PHP技术与动态、预告活动、最热问答以及技术直播等,欢迎大家订阅。
2483 0
|
缓存 API PHP
阿里云栖开发者沙龙PHP技术专场-直面PHP微服务架构挑战
在4月20日的阿里云栖开发者沙龙PHP技术专场上,云智慧Technical VP高驰涛为大家介绍了微服务的前世今生,分享了微服务架构实践中所面对的诸多挑战以及相应的应对策略。 以下内容根据演讲视频以及PPT整理而成。
5752 0
|
7月前
|
关系型数据库 MySQL PHP
PHP 原生操作 Mysql
PHP 原生操作 Mysql
81 0
|
7月前
|
关系型数据库 MySQL 数据库连接
PHP 原生连接 Mysql
PHP 原生连接 Mysql
107 0