Code For Colorful Life
PHP扩展与Zend扩展区别
本文参考自PHP Wiki: Extensions
数据结构区别
通常在php.ini中,通过extension=*
加载的扩展我们称为PHP扩展,通过zend_extension=*
加载的扩展我们称为Zend扩展,但从源码的角度来讲,PHP扩展应该称为“模块”(源码中以module命名),而Zend扩展称为“扩展”(源码中以extension命名)。
两者最大的区别在于向引擎注册的钩子。少数的扩展,例如xdebug、opcache,既是PHP扩展,也是Zend扩展,但它们在php.ini中的加载方式得用zend_extension=*
,具体原因下文会说明。
Read more...
MySQL MHA主库高可用方案学习
环境
- VMWare 3台虚拟机,CentOS 7
- MySQL 5.7.12
- MHA 0.56
安装
MySQL采用RPM包直接装,初始密码为grep 'temporary password' /var/log/mysqld.log
。如果需要的话,可以清空/var/lib/mysql
目录,然后执行mysqld --initialize
重新初始化数据库目录。
MHA源码安装,RPM安装会出问题:Can't locate MHA/NodeConst.pm in @INC
。另外需要安装一些perl的依赖:yum install perl-DBD-MySQL perl-Config-Tiny perl-Log-Dispatch perl-Parallel-ForkManager cpan
。
Read more...
ELK入门实践
ELK主要由Elasticsearch、Logstash、Kibana三个软件组成,用于日志的快速搜索和分析。官网地址:elastic
- Logstash: 将log进行处理后存入Elasticsearch中
- Elasticsearch: 存储log,建立索引,提供搜素(过滤、聚合),支持横向扩展、高可用
- Kibana: 将Elasticsearch中存储的log以图表的方式展示出来
由于Kibana现在还没有联合查询的功能,所以本文采用Kibi(Kibana的一个fork增强版本)。
对于ELK的快速入门书籍可查看:ELKstack 中文指南,详细了解的话请参考官方文档。
本文主要讲述了使用ELK进行日志分析的实践,以分析我们开发组开发环境的nginx access log为例子。
Read more...
swoole_server SWOOLE_PROCESS模式执行探讨
swoole_server的SWOOLE_PROCESS模式是一个比较复杂的运行模式,因为存在了大量的进程间通信,复杂的连接管理等。
其工作模式大致如下图,这里省略掉Manager、Task进程:
Read more...
swoole框架中swoole_client的实现
swoole_client的实现源码主要在swoole-src/swoole_client.c中。
swoole_client有同步和异步两种使用方式,如下:
同步方式:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
<?php
$client = new swoole_client(SWOOLE_SOCK_TCP);
if (!$client->connect('127.0.0.1', 9501, 0.5))
{
die("connect failed.");
}
if (!$client->send("hello world"))
{
die("send failed.");
}
$data = $client->recv();
if (!$data)
{
die("recv failed.");
}
$client->close();
Read more...
PHP Generator的实现
对于Generator的实现,关键的数据结构是_zend_execute_data,已在这篇文章:PHP内核的一点探索——execute_data 介绍了。本文只是粗略的说明了Generator的实现~
Generator的创建
Generator的实现代码在Zend/zend_generators.c中,我们无法直接new一个Generator对象,如果直接new的话会报如下错误:
PHP Catchable fatal error: The "Generator" class is reserved for internal use and cannot be manually instantiated
在源码中可看到原因:
1
2
3
4
5
6
7
static zend_function *zend_generator_get_constructor(zval *object TSRMLS_DC) /* {{{ */
{
zend_error(E_RECOVERABLE_ERROR, "The \"Generator\" class is reserved for internal use and cannot be manually instantiated");
return NULL;
}
/* }}} */
Read more...