PHP7扩展开发之配置项

2024-09-08 14:08
文章标签 配置 开发 扩展 php7

本文主要是介绍PHP7扩展开发之配置项,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

我们经常使用的一些扩展,有的会在php.ini文件中会有一些配置项。这些配置项控制扩展的行为。如 opcache扩展,经常使用的配置项如下:

[opcache]
; 模块地址
zend_extension=opcache.so
; 开关打开
opcache.enable=1
; 开启CLI
opcache.enable_cli=1
; 可用内存, 酌情而定, 单位为:Mb
opcache.memory_consumption=528
; Zend Optimizer + 暂存池中字符串的占内存总量.(单位:MB)
opcache.interned_strings_buffer=8
; 对多缓存文件限制, 命中率不到 100% 的话, 可以试着提高这个值
opcache.max_accelerated_files=10000
; Opcache 会在一定时间内去检查文件的修改时间, 这里设置检查的时间周期, 默认为 2, 定位为秒
opcache.revalidate_freq=60
; 打开快速关闭, 打开这个在PHP Request Shutdown的时候回收内存的速度会提高
opcache.fast_shutdown=1

那么如何实现读取配置文件中的配置项,并应用到扩展中呢?这个是本节要讨论的话题。本文将定义几个配置项,并演示如何读取和修改配置项。配置项如下:

[say]
extension=say.so
say.number=101
say.string=abc
say.boolean=1

代码

基础代码

这个扩展,我们将在say扩展上增加相关代码。say扩展相关代码大家请看这篇博文。PHP7扩展开发之hello word 文中已经详细介绍了如何创建一个扩展和提供了源码下载。

代码实现

使用ext_skel命令生成的代码默认已经有配置项相关的代码,只是出于被注释状态。配置项的实现分以下几步。
第一步:声明变量
这一步声明的变量用于存储从配置文件中读取的配置项值。

//定义一个全局变量类型,代码在php_say.h文件中
ZEND_BEGIN_MODULE_GLOBALS(say)zend_long  global_number;char *global_string;zend_bool global_boolean;
ZEND_END_MODULE_GLOBALS(say)//声明一个全局变量
ZEND_DECLARE_MODULE_GLOBALS(say)

第二步:设置配置项参数
这一步主要是指定一些处理配置项的参数。
所有的配置项参数都必须在PHP_INI_BEGIN()PHP_INI_END()之间。代码如下:

PHP_INI_BEGIN()STD_PHP_INI_ENTRY("say.number",      "100", PHP_INI_ALL, OnUpdateLong, global_value, zend_say_globals, say_globals)STD_PHP_INI_ENTRY("say.string", "ab", PHP_INI_ALL, OnUpdateString, global_string, zend_say_globals, say_globals)STD_PHP_INI_ENTRY("say.boolean", "0", PHP_INI_ALL, OnUpdateBool, global_string, zend_say_globals, say_globals)
PHP_INI_END()

第三步:加载配置项
这一步主要是把配置项从配置文件中读取出来,根据第二步设置的参数,赋值给第一步声明的变量。
宏方法REGISTER_INI_ENTRIES();是用于加载配置文件的。这个宏方法默认是被注释掉,在PHP_MINIT_FUNCTION方法中。只要把注释给去掉即可。

PHP_MINIT_FUNCTION(say)
{......REGISTER_INI_ENTRIES();
}

第四步:读取配置项
在PHP扩展中读取配置项值,需要使用一个宏方法SAY_G()。这个宏方法定义在php_say.h中。
现在,我们定义一个方法show_ini()来显示配置项内容。代码如下:

PHP_FUNCTION(show_ini)
{zval arr;array_init(&arr);add_assoc_long_ex(&arr, "say.number", 10, SAY_G(global_number));add_assoc_string_ex(&arr, "say.string", 10, SAY_G(global_string));add_assoc_bool_ex(&arr, "say.boolean", 11, SAY_G(global_boolean));RETURN_ZVAL(&arr, 0, 1);
}

调用show_ini()方法

<?php$ini = show_ini();var_dump($ini);
?>

输出结果如下:

$ php ./test.php
array(3) {["say.number"]=>int(101)["say.string"]=>string(3) "abc"["say.boolean"]=>bool(true)
}

第五步:销毁配置项
这一步主要是为了在PHP进程结束时,释放配置项占用的资源。
销毁配置项是通过宏方法UNREGISTER_INI_ENTRIES()来实现的。这个方法默认在PHP_MSHUTDOWN_FUNCTION方法中。默认是被注释掉的。只要把注释去掉就可以了。代码如下:

PHP_MSHUTDOWN_FUNCTION(say)
{UNREGISTER_INI_ENTRIES();......
}

ZEND_BEGIN_MODULE_GLOBALS() ZEND_END_MODULE_GLOBALS() 用于定义一个全局变量结构体类型。把宏方法展开后的代码如下:

typedef struct _zend_say_globals {zend_long  global_number; //数字char *global_string; //字符串zend_bool global_boolean; //布尔
} zend_say_globals;

ZEND_DECLARE_MODULE_GLOBALS()是使用上面定义的类型,声明一个全局变量。展开后如下:

zend_say_globals say_globals;

定义了一个全局变量say_globals。

STD_PHP_INI_ENTRY()用于设置每个配置项的参数。这个宏方法有这么几个参数:
第一个参数:配置项在配置文件ini中的名称
第二个参数:默认值。当ini文件中不存在这个配置项时,使用这个默认值
第三个参数:修改范围。就是设置都在那些场景下可以修改。详细的可以查 PHP_INI_ALL
第四个参数:当赋值给全局变量前,会调用的函数。PHP内核已经给出了常用的几个函数。如OnUpdateLong
第五个参数:全局变量的成员名。对应zend_say_globals结构体中的成员。表明读取的值会赋值给这个成员。
第六个参数:全局变量的类型。就是上面定义的结构体。
第七个参数:全局变量名称。

SAY_G()用于读取全局变量的值。如,SAY_G(global_number)展开后的代码如下:

say_globals.global_number

源码下载

tar.gz格式下载
zip格式下载

原文链接:PHP7扩展开发之配置项

这篇关于PHP7扩展开发之配置项的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1148321

相关文章

Zookeeper安装和配置说明

一、Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪集群模式。 ■ 单机模式:Zookeeper只运行在一台服务器上,适合测试环境; ■ 伪集群模式:就是在一台物理机上运行多个Zookeeper 实例; ■ 集群模式:Zookeeper运行于一个集群上,适合生产环境,这个计算机集群被称为一个“集合体”(ensemble) Zookeeper通过复制来实现

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

CentOS7安装配置mysql5.7 tar免安装版

一、CentOS7.4系统自带mariadb # 查看系统自带的Mariadb[root@localhost~]# rpm -qa|grep mariadbmariadb-libs-5.5.44-2.el7.centos.x86_64# 卸载系统自带的Mariadb[root@localhost ~]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

hadoop开启回收站配置

开启回收站功能,可以将删除的文件在不超时的情况下,恢复原数据,起到防止误删除、备份等作用。 开启回收站功能参数说明 (1)默认值fs.trash.interval = 0,0表示禁用回收站;其他值表示设置文件的存活时间。 (2)默认值fs.trash.checkpoint.interval = 0,检查回收站的间隔时间。如果该值为0,则该值设置和fs.trash.interval的参数值相等。

NameNode内存生产配置

Hadoop2.x 系列,配置 NameNode 内存 NameNode 内存默认 2000m ,如果服务器内存 4G , NameNode 内存可以配置 3g 。在 hadoop-env.sh 文件中配置如下。 HADOOP_NAMENODE_OPTS=-Xmx3072m Hadoop3.x 系列,配置 Nam

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

wolfSSL参数设置或配置项解释

1. wolfCrypt Only 解释:wolfCrypt是一个开源的、轻量级的、可移植的加密库,支持多种加密算法和协议。选择“wolfCrypt Only”意味着系统或应用将仅使用wolfCrypt库进行加密操作,而不依赖其他加密库。 2. DTLS Support 解释:DTLS(Datagram Transport Layer Security)是一种基于UDP的安全协议,提供类似于

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

OpenHarmony鸿蒙开发( Beta5.0)无感配网详解

1、简介 无感配网是指在设备联网过程中无需输入热点相关账号信息,即可快速实现设备配网,是一种兼顾高效性、可靠性和安全性的配网方式。 2、配网原理 2.1 通信原理 手机和智能设备之间的信息传递,利用特有的NAN协议实现。利用手机和智能设备之间的WiFi 感知订阅、发布能力,实现了数字管家应用和设备之间的发现。在完成设备间的认证和响应后,即可发送相关配网数据。同时还支持与常规Sof