公司开发用到WorkerMan框架,开发RPC服务,用于拉取用户信息和协助用户注册。

workman 官网:http://www.workerman.net/workerman

老版本:

workerman : 3.1.
GatewayWorker : 1.0.x 查看GatewayWorker版本:http://www.workerman.net/gatewaydoc/faq/get-gateway-version.html

近来,错误日志 workerman.log 中频繁报错:

-- :: createGlobalClientId fail GatewayWorker\Lib\StoreDriver\Redis :
-- :: storeClientAddress fail.
-- :: createGlobalClientId fail GatewayWorker\Lib\StoreDriver\Redis :
-- :: storeClientAddress fail.

根据workerman 框架开发者李亮 的说法,更新GatewayWorker 版本能解决这问题。

老版本文件的目录结构:

service/

├── Applications (目录)
│   └── CHWRPC(目录)
│     ├── Event.php
│     ├── start_businessworker.php
│     └── start_gateway.php
├── GatewayWorker (目录)
├── start.php
├── Workerman (目录)
└── workerman.log

更新GatewayWorker 版本:

升级前准备:

1、备份整个service 目录文件

2、查看官方文档,升级的提醒:http://www.workerman.net/gatewaydoc/appendices/upgrade.html

3、下载并解压源码包:

  1)下载页面:http://www.workerman.net/download,下载 GatewayWorker 的 zip压缩文件

  2)解压:unzip GatewayWorker-master.zip

  3)源码包文件的基本目录结构如下:

  GatewayWorker-master/

  ├── Applications (目录)
  │   └── YourApp (目录)
  │      ├── Events.php
  │      ├── start_businessworker.php
  │      ├── start_gateway.php
  │      └── start_register.php
  ├── GatewayWorker (目录)
  ├── start.php
  ├── Workerman (目录)
  └── workerman.log

升级步骤:

1、停止服务: php start.php stop

2、需要同时将GatewayWorker 和 Workerman 版本更新,不然会报错。将GatewayWorker-master目录中的GatewayWorker 和 Workerman 目录文件,覆盖到 service 目录中

3、

修改文件名,将service/Applications/CHWRPC/Event.php 改名为 Events.php

修改类名, 修改 Events.php 中 class Event 为 class Events

4、拷贝GatewayWorker-master/Applications/YourApp/start_register.php 到 service/Applications/CHWRPC/ 中

<?php
/**
* This file is part of workerman.
*
* Licensed under The MIT License
* For full copyright and license information, please see the MIT-LICENSE.txt
* Redistributions of files must retain the above copyright notice.
*
* @author walkor<walkor@workerman.net>
* @copyright walkor<walkor@workerman.net>
* @link http://www.workerman.net/
* @license http://www.opensource.org/licenses/mit-license.php MIT License
*/
use \Workerman\Worker;
use \GatewayWorker\Register; // 自动加载类
require_once __DIR__ . '/../../Workerman/Autoloader.php'; // register 服务必须是text协议
$register = new Register('text://0.0.0.0:1236'); // 如果不是在根目录启动,则运行runAll方法
if(!defined('GLOBAL_START')) {
Worker::runAll();
}

5、新增一行内容到service/Applications/CHWRPC/start_gateway.php

# echo "$gateway->registerAddress = '127.0.0.1:1236';" >> start_gateway.php
## 服务注册地址
## 单机部署ip为127.0.0.1
## 端口与start_register.php中监听端口一致

6、新增一行内容到service/Applications/CHWRPC/start_businessworker.php

# echo "$worker->registerAddress = '127.0.0.1:1236';" >> start_businessworker.php
注意:端口要和start_register.php中监听端口一致。

7、如果业务有依赖client_id类型,需要将client_id由原来整型改为字符串

8、重启服务,进入debug模式:php start.php start

9、如果没有报错,则将服务放到后台运行:php start.php start -d

新版本:

workerman : 3.3.4
GatewayWorker : 2.0.7

调试模式下,遇到的几个问题:

1、

警告信息:

Deprecated: Lib\MongoDB::_connect(): The Mongo class is deprecated, please use the MongoClient class in /home/service/Applications/CHWRpc/Lib/MongoDB.php on line 

分析:

MongoDB.php的第1859行:

$this->_connection = new \Mongo($this->_connection_string, $options);

_connect() 方法里初始化连接时,用到的 Mongo 类已经被废弃了,建议使用 MongoClient 类。

解决:

将_connection() 方法中用到的 Mongo 类改为 MongoClient 类,即:

$this->_connection = new \MongoClient($this->_connection_string, $options);

2、

警告信息:

Strict Standards: Non-static method Modules\NickName::boy_1() should not be called statically in /home/service/Applications/CHWRpc/Modules/NickName.php on line 

分析:

boy_1() 的声明是一个普通方法,而调用时却采用静态方法调用,因此出现警告信息。

解决方法:

boy_1() 方法的声明修改为: static function boy_1(){ ... }

GatewayWorker 版本升级过程和注意点的更多相关文章

  1. 22 Zabbix系统版本升级过程

    点击返回:自学Zabbix之路 点击返回:自学Zabbix4.0之路 点击返回:自学zabbix集锦 22 Zabbix系统版本升级过程 Zabbix升级与其他相类似系统升级一样,前提一定做好备份,备 ...

  2. MQTT版本升级过程及源码解析

    MQTT版本升级过程及源码解析 首先说一下为什么要写这篇文章呢,在我发现网上对MQTT的文章介绍实在太少了,可能也是使用这个的频率比较低吧!还有对问题的定位以及解决的方式和办法也太少了,所以特意写这篇 ...

  3. 记一次 React Native 大版本升级过程——从0.40到0.59

    去年把公司几个react native 相关的项目升级了下,已经过去一段时间了,这里系统整理下之前的整个过程. 背景 之前到公司的时候发现公司用的还是0.40的版本,据了解,当时项目做的比较早,导航用 ...

  4. 虹软人脸识别—版本升级接口修改说明(C#)

    自虹软发布了免费.离线版本人脸识别SDK,在Github上陆续分享了各个版本对应的 C# Demo.因为公司项目一直在使用虹软的SDK,因此每当虹软官网有新版本发布,我都会进行了解,并结合Demo进行 ...

  5. IOS零碎技术整理(3)-获取wifi列表

    1.   该功能实现基于MobileApple80211框架来进行开发,而目前该框架成为了私有框架,其中的API均为私有API. 如果使用这些API可能导致应用不能上app store或者ios版本升 ...

  6. 注解的基本盘点 -- 《Java编程思想》

    注解(元数据)为我们在代码中添加信息提供了一种形式化的方法,使我们可以在之后的某一个时刻非常方便地使用这些数据. ---<Java编程思想> 其实注解可以理解为一个工具类,只要使用了这个工 ...

  7. Javascript触屏手势库-JTouch(更新V1.1)

    作者:痞子|时间:2013-05-21|分类目录:js,javascript,jquery教程|Tag标签: javascript.jTouch|阅读(857) 7 条评论 Javascript触屏手 ...

  8. [置顶] API相关工作过往的总结之整体介绍

    此系列的总结文章,仅仅是我个人工作总结,有考虑不周之处还请各位同行多多指教. API(Application Programming Interface,应用程序编程接口)是一些预先定义的函数,目的是 ...

  9. Promise实现小球的运动

        Promise简要说明 Promise可以处理一些异步操作:如像setTimeout.ajax处理异步操作是一函数回调的方式;当然ajax在jQuery版本升级过程中,编写方式也有所变动. P ...

随机推荐

  1. 在IIS 10中注册自定义的IHttpModule

    环境:Visual Studio 2015, IIS Express 10, ASP.NET 4.5 演示代码:http://files.cnblogs.com/files/joe-yang/Rewr ...

  2. JS取出特定字符前后的字符串,针对一串字符里面的单个字符前后的字符串

    //针对一串自负里面的单个字符前后的字符串<!doctype html> <html> <head> <meta charset="utf-8&qu ...

  3. 为什么Arduino独占鳌头并站稳脚跟?

    出处: http://bbs.dfrobot.com.cn/thread-793-1-1.html 为什么Arduino独占鳌头并站稳脚跟? 每个月,我都会在<Make>杂志上发表几篇社论 ...

  4. Web Service 实践之 REST vs RPC

    作者:朱涛 出处:http://www.cnblogs.com/mindsbook/archive/2009/11/17/web_service_RESTvsRPC.html Web Service ...

  5. [置顶] Linux 常用命令集锦

    出处:http://www.vaikan.com/what-are-the-most-useful-swiss-army-knife-one-liners-on-unix/ Linux命令行里的&qu ...

  6. [BZOJ1322]Destroying The Graph

    题目大意:有一张有向图,对于每个点,有两种操作:1. 删掉它的所有入边2. 删掉它的所有出边对每个点的每个操作均有不同的价值.求使得图上没有边的最小价值.解题思路:考虑把点拆成入点和出点,然后就是二分 ...

  7. BZOJ 3262 陌上花开 (三维偏序CDQ+树状数组)

    题目大意: 题面传送门 三维偏序裸题 首先,把三元组关于$a_{i}$排序 然后开始$CDQ$分治,回溯后按$b_{i}$排序 现在要处理左侧对右侧的影响了,显然现在左侧三元组的$a_{i}$都小于等 ...

  8. UDP Linux编程(客户端&服务器端)

    服务器端 服务器不用绑定地址,他只需要进行绑定相应的监听端口即可. #include <sys/types.h> #include <sys/socket.h> #includ ...

  9. ansible 连通测试

    [root@ftp:/root] > ansible ansible01 -m ping ansible01 | UNREACHABLE! => { "changed" ...

  10. Nginx Zabbix

    https://www.cnblogs.com/wangxiaoqiangs/archive/2016/04/20/5412111.html