gateway配置mysql_gateway中这样使用mysql正确么
start_gateway.php代码:
use \Workerman\Worker;
use \Workerman\WebServer;
use \GatewayWorker\Gateway;
use \GatewayWorker\BusinessWorker;
use \Workerman\Autoloader;
// 自动加载类
require_once __DIR__ . '/../../vendor/autoload.php';
// gateway 进程,这里使用Text协议,可以用telnet测试
// $gateway = new Gateway("tcp://0.0.0.0:8282");
$gateway = new Gateway("websocket://0.0.0.0:2000");
// gateway名称,status方便查看
$gateway->name = 'Device';
// gateway进程数
$gateway->count = 1;
// 本机ip,分布式部署时使用内网ip
$gateway->lanIp = '127.0.0.1';
// 内部通讯起始端口,假如$gateway->count=4,起始端口为4000
// 则一般会使用4000 4001 4002 4003 4个端口作为内部通讯端口
$gateway->startPort = 2900;
// 服务注册地址
$gateway->registerAddress = '127.0.0.1:1238';
// 心跳间隔
$gateway->pingInterval = 10;
$gateway->pingNotResponseLimit = 1;
// 心跳数据
//$gateway->pingData = '{"type":"ping"}';
$gateway->pingData = '';
$db = new \Workerman\MySQL\Connection('host', '3306', 'username', 'password', 'dbName');
// 当客户端连接上来时,设置连接的onWebSocketConnect,即在websocket握手时的回调
$gateway->onConnect = function($connection)
{
$connection->onWebSocketConnect = function($connection , $http_header)
{
global $db;
// $_SERVER 可用这里判断连接来源是否合法,不合法就关掉连接
try
{
// 查询数据库设备Token是否存在
// 查询数据库设备Token是否存在
// 查询数据库设备Token是否存在
// 查询数据库设备Token是否存在
// 查询数据库设备Token是否存在
// 查询数据库设备Token是否存在
}
catch (\Exception $e)
{
echo $e->getMessage();
$connection->close();
}
};
};
// 如果不是在根目录启动,则运行runAll方法
if(!defined('GLOBAL_START'))
{
Worker::runAll();
}
events.php 代码
/**
* 用于检测业务代码死循环或者长时间阻塞等问题
* 如果发现业务卡死,可以将下面declare打开(去掉//注释),并执行php start.php reload
* 然后观察一段时间workerman.log看是否有process_timeout异常
*/
//declare(ticks=1);
use \GatewayWorker\Lib\Gateway;
use Workerman\Worker;
class Events
{
public static $db = null;
public static function onWorkerStart($worker)
{
self::$db = new \Workerman\MySQL\Connection('host', '3306', 'username', 'password', 'dbName');
}
// 当客户端连接时触发
public static function onConnect($client_id)
{
// 向当前client_id发送数据
Gateway::sendToClient($client_id, "Hello $client_id\r\n");
// 向所有人发送
Gateway::sendToAll("$client_id login\r\n");
}
// 当客户端发来消息时触发
public static function onMessage($client_id, $message)
{
// 设置workerman处理一定请求后重启当前进程
static $request_count;
if(++$request_count > 100)
{
// 请求数达到10000后退出当前进程,主进程会自动重启一个新的进程
Worker::stopAll();
}
}
// 当用户断开连接时触发
public static function onClose($client_id)
{
echo $client_id.'断开了'.PHP_EOL;
}
}
两个页面都需要查询数据库
gateway配置mysql_gateway中这样使用mysql正确么相关推荐
- MySQL正确配置my.ini的event_scheduler = ON
MySQL正确配置my.ini的event_scheduler = ON 让事件的定时调度器常开,如下红框圈出部分: 永久性设置方法: 为何要在my.ini中设置: 补充mysql做一个event或j ...
- 在Mac OS X 10.8中配置Apache + PHP + MySQL
用趣味的心态,开发有趣味的应用.简单是一种美丽~~~ 博客园 首页 博问 闪存 新随笔 联系 订阅 管理 随笔- 23 文章- 0 评论- 58 在Mac OS X 10.8中配置Apache ...
- mysql创建test_MySQL中,创建数据库test正确的SQL语句是( )
[多选题]PHP中可以实现循环的是(). [填空题]色彩模型是一种抽象的数学模型,即用________来对色彩进行描述的方法. [填空题]人耳可感受声音频率的范围是 HZ . [填空题]PHP中,多行 ...
- centos中的mysql安装配置_CentOs中mysql的安装与配置
在linux中安装数据库首选MySQL,Mysql数据库的第一个版本就是发行在Linux系统上,其余选择还能够有postgreSQL,oracle等html 在Linux上安装mysql数据库,咱们能 ...
- mysql数据库中count的作用_详解 MySQL中count函数的正确使用方法
1. 描述 在MySQL中,当我们需要获取某张表中的总行数时,一般会选择使用下面的语句 select count(*) from table; 其实count函数中除了*还可以放其他参数,比如常数.主 ...
- PHP开发环境配置:安装与配置Apache、PHP、MySQL、PhpMyAdmin
目标 Ü 在Windows上安装与配置MySQL Ü 在Windows上安装与配置Apache Ü 在Windows上安装与配置PHP 一般情况下,使用P ...
- 关于mysql的项目_项目中常用的MySQL 优化
本文我们来谈谈项目中常用的MySQL优化方法,共19条,具体如下: 一.EXPLAIN 做MySQL优化,我们要善用EXPLAIN查看SQL执行计划. 下面来个简单的示例,标注(1.2.3.4.5)我 ...
- CentOS 6.5 yum安装配置lnmp服务器(Nginx+PHP+MySQL)
以下全部转载于 http://blog.csdn.net/lane_l/article/details/20235909 本人于今晚按照该文章使用centos 6.7 64bit安装成功,做个备份, ...
- CentOS 6.4安装配置LAMP服务器(Apache+PHP5+MySQL)
2019独角兽企业重金招聘Python工程师标准>>> 准备篇: 1.配置防火墙,开启80端口.3306端口 vi /etc/sysconfig/iptables -A ...
最新文章
- java mongodb存base64_阿里JAVA面试分享经验【文末有福利】
- Spring2.5注释驱动与基于注释的MVC
- 【零基础入门数据挖掘】-特征工程
- java编写科赫曲线_分形——科赫曲线
- 创宇技能表_知道创宇研发技能表 一
- (DFS or BFS)Find The Multiple(poj1426)
- 关于静态资源压缩技术
- 为什么使用 Dubbo ? 微服务概述?传统应用的问题?
- 面试官解答:BAT等大厂最需要怎样的程序员
- 2021年认证杯SPSSPRO杯数学建模B题(第一阶段)依巴谷星表中的毕星团求解全过程文档及程序
- 微信小程序轮播中的current_五分钟掌握微信小程序轮播图
- C++移动语义及拷贝优化
- 【佛系养身】男程序员护肤入门
- 什么是裸金属服务器,裸金属服务器适用什么场景?
- 蓝桥杯2013年国赛A组——网络寻路(DFS和中转边巧解)
- 【安全牛学习笔记】w3af
- element 复杂表格渲染(1)
- 计算机除尘 注意事项,数码相机除尘注意事项
- 飞行器识别---综述
- java基础与案例开发详解 pdf下载_Java基础与案例开发详解(张孝祥) pdf_IT教程网...