首页
4K壁纸
直播
统计分析
友情链接
搜索
1
#1031 – TABLE STORAGE ENGINE FOR ” DOESN’T HAVE THIS OPTION解决方法
1,112 阅读
2
让浏览器不显示 https 页面中 http 请求警报 http-equiv=”Content-Security-Policy” content=”upgrade-insecure-requests”
845 阅读
3
报错代码:ERROR 1227 (42000)-解决办法
639 阅读
4
微信个人商户号养号建议
528 阅读
5
解决移动端position:fixed随软键盘移动的问题
479 阅读
PHP
Mysql
Linux
Reids
Java
常用笔记
学习
乱七八糟
Search
标签搜索
php
千卡云支付
Mysql
Linux
redis
千卡云
千卡易支付
Nginx
shell
JS
JSON
支付宝
CentOS
Apache
支付
function
database
fastadmin
phpstorm
快捷键
蓝科迪梦
累计撰写
69
篇文章
累计收到
0
条评论
首页
栏目
PHP
Mysql
Linux
Reids
Java
常用笔记
学习
乱七八糟
页面
4K壁纸
直播
统计分析
友情链接
搜索到
69
篇与
的结果
2025-04-07
intellij idea常用快捷键
常用快捷键 Alt+回车 导入包,自动修正 Ctrl+N 查找类 Ctrl+Shift+N 查找文件 Ctrl+Alt+L 格式化代码 Ctrl+Alt+O 优化导入的类和包 Alt+Insert 生成代码(如get,set方法,构造函数等) Ctrl+X 删除行 Ctrl+D 复制行 Ctrl+/ 或 Ctrl+Shift+/ 注释(// 或者 ) Ctrl+J 自动代码 Ctrl+P 方法参数提示 psvm main() souf system.out.pringln() Ctrl+b 或 F4 查看源代码 Ctrl+Alt+T try{}catch(){}finally{} CTRL+ALT+I 自动缩进 CTRL+ALT+O 优化导入的类和包 CIRL+U 大小写切换
2025年04月07日
7 阅读
0 评论
0 点赞
2025-03-29
mysql中 for update 使用方法
for update是在数据库中上锁用的,可以为数据库中的行上一个排它锁。当一个事务的操作未完成时候,其他事务可以读取但是不能写入或更新。 例子: 比如一张表三个字段 , id(商品id), name(商品名字) , count(数量) 当商品抢购时候会显示剩余商品件数,如果并发量大的时候,商品自减的值可能不准确。所以当我们在一个事务中对count字段进行修改的时候,其他事务应该只能读取指定id的count,而不能进行update等操作。这个时候就需要用到for update. sql语句: start transaction ; select * from table_name where id =1 for update ; update table_name set count = count - 1 where id= 1; 此时如果另一个事务也想执行类似的操作: start transaction ; select * from table_name where id =1 for update ; //下面的这行sql会等待,直到上面的事务回滚或者commit才得到执行。 update table_name set count = count - 1 where id= 1; *注:当选中某一个行的时候,如果是通过主键id选中的。那么这个时候是行级锁。 其他的行还是可以直接insert 或者update的。如果是通过其他的方式选中行,或者选中的条件不明确包含主键。这个时候会锁表。其他的事务对该表的任意一行记录都无法进行插入或者更新操作。只能读取。* 那是一种行级锁,一旦用户对某个行施加了行级加锁,则该用户可以查询也可以更新被加锁的数据行,其它用户只能查询但不能更新被加锁的数据行.如果其它用户想更新该表中的数据行,则也必须对该表施加行级锁.即使多个用户对一个表均使用了共享更新,但也不允许两个事务同时对一个表进行更新,真正对表进行更新时,是以独占方式锁表,一直到提交或复原该事务为止。行锁永远是独占方式锁。 只有当出现如下之一的条件,便释放共享更新锁: (1)、执行提交(COMMIT)语句; (2)、退出数据库(LOG OFF) (3)、程序停止运行。 那么,什么时候需要使用for update?就是那些需要业务层面数据独占时,可以考虑使用for update。场景上,比如火车票订票,在屏幕上显示邮票,而真正进行出票时,需要重新确定一下这个数据没有被其他客户端修改。所以,在这个确认过程中,可以使用for update。这是统一的解决方案方案问题,需要前期有所准备
2025年03月29日
6 阅读
0 评论
0 点赞
2025-03-26
phpMyAdmin登录时指定服务器ip和端口的方法
1、打开phpMyAdmin目录, 在此目录下是否有config.sample.inc.php文件,如果存在,那么将其改名为config.inc.php;为避免修改失误所造成的损失,强烈建议先备份 config.sample.inc.php 文件为 config.sample.inc.php.bak; 2、在phpMyAdmin的配置文件 config.inc.php 中加上一个配置项 $cfg['AllowArbitraryServer'] = true; /* 允许自定义服务器,默认为false */ 设置多选服务器 $i++; $cfg['Servers'][$i]['auth_type'] = 'cookie'; /* Server parameters */ $cfg['Servers'][$i]['host'] = '172.22.0.16'; $cfg['Servers'][$i]['compress'] = false; $cfg['Servers'][$i]['AllowNoPassword'] = false;
2025年03月26日
9 阅读
0 评论
0 点赞
2025-03-18
/usr/sbin/mysqld: Can't open file: '**.frm'(errno: 24 - Too many open files)
kangle主机开的主机多了mysql就容易挂,每次都要重启mysql才能解决,今天抽空查了下日志,看到大量这个报错: /usr/sbin/mysqld: Can't open file: '**.frm'(errno: 24 - Too many open files) 主要原因: lock tables时候文件打开句柄太多导致,可以适当调大文件打开数句柄。 解决方法: 在 /etc/mysql/my.conf 中,你需要增加MySQLs内部 open_files_limit。 所以暂时将这个添加到配置并重启 MySQL。 [mysqld] open_files_limit = 100000 /bin/systemctl restart mysqld.service ============================ 因为kangle主机有很多的小白用户,发现存在很多死进程,为了保证稳定性和长期免维护,又在定时任务中加了定期重启mysql 配置crond服务启动计划需要编辑etc目录下的crontab文件内容,直接用Vim编辑它: vim /etc/crontab vim编辑命令不熟的可以搜索一下,不难,添加一行,比如我要每天凌晨2:30自动重启一次mysql就添加下面这样一行: 30 2 * * * root /bin/systemctl restart mysqld.service 保存重启下crontabs就可以了. /bin/systemctl restart crond.service
2025年03月18日
23 阅读
0 评论
0 点赞
2025-03-18
mysql查询json字段
一张openvpn表里存了一个stop字段是json类型的 表名:openvpn 字段:id int(11) , stop json(255) 假如stop的数据: { "surplus": 119, "opentime": 0 } 1.查询该stop里status这个字段数据: SELECT id,JSON_EXTRACT(stop,'$.status') as status FROM `openvpn` 2.查询该stop里status这个字段为0的数据: SELECT id,JSON_EXTRACT(stop,'$.status') as status FROM `openvpn` WHERE JSON_EXTRACT(stop,'$.status') = 0 3.查询该stop里status这个字段不为1且id大于10000的数据: SELECT id,JSON_EXTRACT(stop,'$.status') as status FROM `openvpn` WHERE JSON_EXTRACT(stop,'$.status') != 1 AND `id` > 10000 备注:通过json_extract函数,获取到了json对象的特定key的值
2025年03月18日
17 阅读
0 评论
0 点赞
2025-03-18
which is not functionally dependent on columns in GROUP BY clause
报错信息:which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by 在对连接表进行select查找时出现以上报错信息。 打开【my.ini】文件 添加如下代码在【mysqld】中 sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION 保存,重启mysql即可
2025年03月18日
19 阅读
0 评论
0 点赞
2025-03-10
php二维数组根据指定键值重新排序
/** * @Notes: * 二维数组根据指定键值重新排序 * @Interface arr_sort * @author [MengShuai] [<133814250@qq.com>] */ public static function arr_sort($arr,$field='id',$order='SORT_ASC'){ $sort = array( 'order' => $order, //排序顺序标志 SORT_DESC 降序;SORT_ASC 升序 'field' => $field, //排序字段 ); $arrSort = array(); foreach($arr AS $uniqid => $row){ foreach($row AS $key=>$value){ $arrSort[$key][$uniqid] = $value; } } if($sort['order']){ array_multisort($arrSort[$sort['field']], constant($sort['order']), $arr); } return $arr; } 测试数据: $userdb = array( 0 => array( 'uid' => 100, 'name' => 'Sandra Shush', 'url' => 'urlof100' ), 1 => array( 'uid' => 5465, 'name' => 'Stefanie Mcmohn', 'pic_square' => 'urlof100' ), ); 调用方法: $userdb = arr_sort($userdb,$field='uid',$order='SORT_DESC'); 打印方法: var_export($userdb); 打印结果: array ( 0 => array ( 'uid' => 5465, 'name' => 'Stefanie Mcmohn', 'pic_square' => 'urlof100', ), 1 => array ( 'uid' => 100, 'name' => 'Sandra Shush', 'url' => 'urlof100', ), )
2025年03月10日
27 阅读
0 评论
0 点赞
2025-03-10
中兴F7015TV3光猫相关命令
1、普通用户提权为 admin sendcmd 1 DB set DevAuthInfo 1 Level 1 sendcmd 1 DB save Bash 2、修改超级用户名和密码: sendcmd 1 DB set DevAuthInfo 0 User XXXXXX #(改超级用户名xxxxx) sendcmd 1 DB set DevAuthInfo 0 Pass XXXXXX #(改超级密码xxxxx) Bash 3、修改用户限制: sendcmd 1 DB p CltLmt sendcmd 1 DB set CltLmt 8 Max 20 #(修改最大用户数为20,可以改成其他数目,最大数目不超过255) sendcmd 1 DB set CltLmt 8 Enable 0 sendcmd 1 DB save Bash 4、关闭 TR069 与定时上报(不懂的用户慎操作): sendcmd 1 DB p MgtServer #查看一下当前的电信远程控制 sendcmd 1 DB set MgtServer 0 URL http://127.0.0.1 #把服务器 URL 改掉 sendcmd 1 DB set MgtServer 0 Tr069Enable 0 sendcmd 1 DB set MgtServer 0 PeriodicInformEnable 0 sendcmd 1 DB save Bash 5、劫持 ITMS 注册(不懂的用户慎操作): sendcmd 1 DB set PDTCTUSERINFO 0 Status 0 sendcmd 1 DB set PDTCTUSERINFO 0 Result 1 sendcmd 1 DB save Bash 6、恢复 TR069 与定时上报功能(以甘肃电信为例,每个省份的上报服务器应该不一样) sendcmd 1 DB p MgtServer #查看一下当前的电信远程控制 sendcmd 1 DB set MgtServer 0 URL http://devacs.edatahome.com:9090/ACS-server/ACS sendcmd 1 DB set MgtServer 0 Tr069Enable 1 sendcmd 1 DB set MgtServer 0 PeriodicInformEnable 1 sendcmd 1 DB save Bash 7、关闭开启指示灯 sendcmd 1 DB p WLCInfo #查看 sendcmd 1 DB set WLCInfo 0 WLCStatus 1 #关闭 sendcmd 1 DB set WLCInfo 0 WLCStatus 0 #开启 sendcmd 1 DB save #保存 reboot #重启之后会生效 Bash 8、开永久 telnet(密码 Zte521) sendcmd 1 DB p TelnetCfg sendcmd 1 DB set TelnetCfg 0 Lan_Enable 1 sendcmd 1 DB set TelnetCfg 0 TS_UName root sendcmd 1 DB set TelnetCfg 0 TSLan_UName root sendcmd 1 DB set TelnetCfg 0 TS_UPwd Zte521 sendcmd 1 DB set TelnetCfg 0 TSLan_UPwd Zte521 sendcmd 1 DB set TelnetCfg 0 Max_Con_Num 99 sendcmd 1 DB set TelnetCfg 0 ExitTime 999999 sendcmd 1 DB set TelnetCfg 0 InitSecLvl 3 sendcmd 1 DB set TelnetCfg 0 CloseServerTime 9999999 sendcmd 1 DB set TelnetCfg 0 Lan_EnableAfterOlt 1 sendcmd 1 DB save Bash 9、删除 WiFi 前缀 sendcmd 1 DB set WLANCfg 0 ESSIDPrefix #(设置2.4G的ssid前缀为空) sendcmd 1 DB set WLANCfg 4 ESSIDPrefix #(设置5G的ssid前缀为空) sendcmd 1 DB save Bash 10、查询 / 切换区域码命令 cat /etc/init.d/regioncode #查询 upgradetest sdefconf 226 #切换 (甘肃) Bash 11、查看系统参数 / 修改 PonMac setmac show2 #查看系统参数 setmac 1 32769 EEEEEEEE #修改PonMac Bash 12、其他命令 #禁用TR069远程控制 sendcmd 1 DB set MgtServer 0 PeriodicInformEnable 0 #关闭防火墙; sendcmd 1 DB set FWLevel 0 Level 0 #关闭防火墙并发连接数最大限制 sendcmd 1 DB set FWBase 0 FwConnMaxEnable 0 #改最大并发连接数 sendcmd 1 DB set FWBase 0 ConntrackMax 65535 #允许切换双模 setmac 3 40962 #查看CPU占用率 cat /proc/cpuusage #查看温度 cat /proc/tempsensor #关闭下行GPON光口和WiFi— ip link set mini-olt down rmmod optical rmmod mtlk rmmod mtlkroot
2025年03月10日
10 阅读
0 评论
0 点赞
2025-03-07
PHP中register_shutdown_function函数的基础介绍与用法详解
1. 函数说明 定义:该函数是来注册一个会在PHP中止时执行的函数 参数说明: void register_shutdown_function ( callable $callback [, mixed $parameter [, mixed $... ]] ) 注册一个 callback ,它会在脚本执行完成或者 exit() 后被调用。 callback:待注册的中止回调 parameter:可以通过传入额外的参数来将参数传给中止函数 2. PHP中止的情况 PHP中止的情况有三种: 执行完成 exit/die导致的中止 发生致命错误中止 a. 第一种情况,执行完成 <?php function test() { echo '这个是中止方法test的输出'; } register_shutdown_function('test'); echo 'before' . PHP_EOL; 运行: before 这个是中止方法test的输出 注意:输出的顺序,等执行完成了之后才会去执行register_shutdown_function的中止方法test b. 第二种情况,exit/die导致的中止 <?php function test() { echo '这个是中止方法test的输出'; } register_shutdown_function('test'); echo 'before' . PHP_EOL; exit(); echo 'after' . PHP_EOL; 运行: before 这个是中止方法test的输出 后面的after并没有输出,即exit或者是die方法导致提前中止。 c. 第三种情况,发送致命错误中止 <?php function test() { echo '这个是中止方法test的输出'; } register_shutdown_function('test'); echo 'before' . PHP_EOL; // 这里会发生致命错误 $a = new a(); echo 'after' . PHP_EOL; 运行: before Fatal error: Uncaught Error: Class 'a' not found in D:\laragon\www\php_book\test.php on line 12 Error: Class 'a' not found in D:\laragon\www\php_book\test.php on line 12 Call Stack: 0.0020 360760 1. {main}() D:\laragon\www\php_book\test.php:0 这个是中止方法test的输出 后面的after也是没有输出,致命错误导致提前中止了。 3. 参数 第一个参数支持以数组的形式来调用类中的方法,第二个以及后面的参数都是可以当做额外的参数传给中止方法。 <?php class Shutdown { public function stop() { echo "这个是stop方法的输出"; } } // 当PHP终止的时候(执行完成或者是遇到致命错误中止的时候)会调用new Shutdown的stop方法 register_shutdown_function([new Shutdown(), 'stop']); // 将因为致命错误而中止 $a = new a(); // 这一句并没有执行,也没有输出 echo '必须终止'; 也可以在类中执行: <?php class TestDemo { public function __construct() { register_shutdown_function([$this, "f"], "hello"); } public function f($str) { echo "class TestDemo->f():" . $str; } } $demo = new TestDemo(); echo 'before' . PHP_EOL; /** 运行: before class TestDemo->f():hello */ 4. 同时调用多个 可以多次调用 register_shutdown_function,这些被注册的回调会按照他们注册时的顺序被依次调用。 不过注意的是,如果在第一个注册的中止方法里面调用exit方法或者是die方法的话,那么其他注册的中止回调也不会被调用。 代码: <?php /** * 可以多次调用 register_shutdown_function,这些被注册的回调会按照他们注册时的顺序被依次调用。 * 注意:如果你在f方法(第一个注册的方法)里面调用exit方法或者是die方法的话,那么其他注册的中止回调也不会被调用 */ /** * @param $str */ function f($str) { echo $str . PHP_EOL; // 如果下面调用exit方法或者是die方法的话,其他注册的中止回调不会被调用 // exit(); } // 注册第一个中止回调f方法 register_shutdown_function("f", "hello"); class TestDemo { public function __construct() { register_shutdown_function([$this, "f"], "hello"); } public function f($str) { echo "class TestDemo->f():" . $str; } } $demo = new TestDemo(); echo 'before' . PHP_EOL; /** 运行: before hello class TestDemo->f():hello 注意:如果f方法里面调用了exit或者是die的话,那么最后的class TestDemo->f():hello不会输出 */ 5. 用处 该函数的作用: 析构函数:在PHP4的时候,由于类不支持析构函数,所以这个函数经常用来模拟实现析构函数 致命错误的处理:使用该函数可以用来捕获致命错误并且在发生致命错误后恢复流程处理 代码如下: <?php /** * register_shutdown_function,注册一个会在php中止时执行的函数,中止的情况包括发生致命错误、die之后、exit之后、执行完成之后都会调用register_shutdown_function里面的函数 * Created by PhpStorm. * User: Administrator * Date: 2017/7/15 * Time: 17:41 */ class Shutdown { public function stop() { echo 'Begin.' . PHP_EOL; // 如果有发生错误(所有的错误,包括致命和非致命)的话,获取最后发生的错误 if (error_get_last()) { print_r(error_get_last()); } // ToDo:发生致命错误后恢复流程处理 // 中止后面的所有处理 die('Stop.'); } } // 当PHP终止的时候(执行完成或者是遇到致命错误中止的时候)会调用new Shutdown的stop方法 register_shutdown_function([new Shutdown(), 'stop']); // 将因为致命错误而中止 $a = new a(); // 这一句并没有执行,也没有输出 echo '必须终止'; 运行: Fatal error: Uncaught Error: Class 'a' not found in D:\laragon\www\php_book\1_23_register_shutdown.php on line 31 Error: Class 'a' not found in D:\laragon\www\php_book\1_23_register_shutdown.php on line 31 Call Stack: 0.0060 362712 1. {main}() D:\laragon\www\php_book\1_23_register_shutdown.php:0 Begin. Array ( [type] => 1 [message] => Uncaught Error: Class 'a' not found in D:\laragon\www\php_book\1_23_register_shutdown.php:31 Stack trace: #0 {main} thrown [file] => D:\laragon\www\php_book\1_23_register_shutdown.php [line] => 31 ) Stop. 注意:PHP7中新增了Throwable异常类,这个类可以捕获致命错误,即可以使用try...catch(Throwable $e)来捕获致命错误,代码如下: <?php try { // 将因为致命错误而中止 $a = new a(); // 这一句并没有执行,也没有输出 echo 'end'; } catch (Throwable $e) { print_r($e); echo $e->getMessage(); } 运行: Error Object ( [message:protected] => Class 'a' not found [string:Error:private] => [code:protected] => 0 [file:protected] => C:\laragon\www\php_book\throwable.php [line:protected] => 5 [trace:Error:private] => Array ( ) [previous:Error:private] => [xdebug_message] => Error: Class 'a' not found in C:\laragon\www\php_book\throwable.php on line 5 Call Stack: 0.0000 349856 1. {main}() C:\laragon\www\php_book\throwable.php:0 ) Class 'a' not found 这样的话,PHP7中使用Throwable来捕获的话比使用register_shutdown_function这个函数来得更方便,也更推荐Throwable。 注意:Error类也是可以捕获到致命错误,不过Error只能捕获致命错误,不能捕获异常Exception,而Throwable是可以捕获到错误和异常的,所以更推荐。 6.巧用register_shutdown_function判断php程序是否执行完 还有一种应用场景就是:要做一个消费队列,因为某条有问题的数据导致致命错误,如果这条数据不处理掉,那么整个队列都会导致瘫痪的状态,这样可以用以下方法来解决。即:如果捕获到有问题的数据导致错误,则在回调函数中将这条数据处理掉就可以了。 php范例参考与解析: <?php register_shutdown_function('myFun'); //放到最上面,不然如果下面有致命错误,就不会调用myFun了。 $execDone = false; //程序是否成功执行完(默认为false) /** ********************* 业务逻辑区************************* */ $tas = 3; if($tas == 3) { new daixiaorui(); } /** ********************* 业务逻辑结束************************* */ $execDone = true; //由于程序由上至下执行,因此当执行到此后,则证明逻辑没有出现致命的错误。 function myFun() { global $execDone; if($execDone === false) { file_put_contents("E:/myMsg.txt", date("Y-m-d H:i:s")."---error: 程序执行出错。\r\n", FILE_APPEND); /******** 以下可以做一些处理 ********/ } } 总结 register_shutdown_function这个函数主要是用在处理致命错误的后续处理上(PHP7更推荐使用Throwable来处理致命错误),不过缺点也很明显,只能处理致命错误Fatal error,其他的错误包括最高错误Parse error也是没办法处理的。
2025年03月07日
38 阅读
0 评论
0 点赞
2024-12-31
解决PHP连接Redis报read error on connection错误
背景 项目由于并发很高,所以将之前连接redis使用短连接改成了长连接,结果导致出现了抛出了read error on connection 出现原因 php有一个配置项default_socket_timeout表示一个socket连接的超时时间,默认是60s,而phpredis这个扩展的底层连接redis是使用的socket,所以当一个连接在60秒内没有被使用的时候,下次连接就会抛出这个异常。 解决方案 方案1 修改php.ini(不推荐) 在php.ini中设置default_socket_timeout = -1,然后重启php-fpm 方案2 程序中设置 使用ini_set函数 ini_set('default_socket_timeout', -1); // 不超时 方案3 使用redis的option 在连接redis时setOption $this->redis->setOption(Redis::OPT_READ_TIMEOUT, -1); 注意设置没有超时时间都要设置成-1 而不是0
2024年12月31日
56 阅读
0 评论
0 点赞
2024-10-22
PHP中 HTTP_HOST 和 SERVER_NAME 的区别
最近在开发站群软件,用到了根据访问域名判断子站点的相关问题。PHP获取当前域名有两个变量 HTTP_HOST 和 SERVER_NAME,我想知道两者的区别以及哪个更加可靠。 首先我想说,百度上那些转来转去的文章都是扯淡! 有说相同的,有说不同的,都没说明原因,没经过验证就互相转来转去的,浪费观众时间。 下面说说本人经过亲自验证 + 查阅官方文档 + 官方BUG列表 + 官方邮件列表 + sitepoint + webmasterworld + google的总结: 相同点: 当满足以下三个条件时,两者会输出相同信息。 1. 服务器为80端口 2. apache的conf中ServerName设置正确 3. HTTP/1.1协议规范 不同点: 1. 通常情况: $_SERVER[“HTTP_HOST”] 在HTTP/1.1协议规范下,会根据客户端的HTTP请求输出信息。 $_SERVER[“SERVER_NAME”] 默认情况下直接输出apache的配置文件httpd.conf中的ServerName值。 2. 当服务器为非80端口时: $_SERVER[“HTTP_HOST”] 会输出端口号,例如:mimiz.cn:8080 $_SERVER[“SERVER_NAME”] 会直接输出ServerName值 因此在这种情况下,可以理解为:HTTP_HOST = SERVER_NAME : SERVER_PORT 3. 当配置文件httpd.conf中的ServerName与HTTP/1.0请求的域名不一致时: httpd.conf配置如下: <virtualhost *> ServerName mimiz.cn ServerAlias www.mimiz.cn </virtualhost> 客户端访问域名www.mimiz.cn $_SERVER[“HTTP_HOST”] 输出 www.mimiz.cn $_SERVER[“SERVER_NAME”] 输出 mimiz.cn 所以,在实际程序中,应尽量使用_SERVER[“HTTP_HOST”] ,比较保险和可靠。
2024年10月22日
61 阅读
0 评论
0 点赞
2024-10-22
fas_openvpn进程守护
/var/www/html/目录下新建monitor.php,开启755权限 原来的守护脚本for循环里加一句:cd /var/www/html/;php monitor.php &>/dev/null monitor.php如下: <?php require('system.php'); $overtime = 10; $time = time(); $path_log = R.'/monitor.txt'; //log大于3MB则清空 if(filesize($path_log) > 1024*1024*3){ file_put_contents($path_log, ""); } if(strstr(end(file($path_log)), date('Y-m-d H:i:s')) != false){ exit('已经监控过啦'); } $files[0]["file"] = "openvpn_api/online_1194.txt"; $files[0]["telnet"] = "systemctl stop openvpn@server1194;systemctl start openvpn@server1194"; $files[1]["file"] = "openvpn_api/online_1195.txt"; $files[1]["telnet"] = "systemctl stop openvpn@server1195;systemctl start openvpn@server1195"; $files[2]["file"] = "openvpn_api/online_1196.txt"; $files[2]["telnet"] = "systemctl stop openvpn@server1196;systemctl start openvpn@server1196"; $files[3]["file"] = "openvpn_api/online_1197.txt"; $files[3]["telnet"] = "systemctl stop openvpn@server1197;systemctl start openvpn@server1197"; $files[4]["file"] = "openvpn_api/user-status-udp.txt"; $files[4]["telnet"] = "systemctl stop openvpn@server-udp;systemctl start openvpn@server-udp"; $msg = ''; foreach ($files as $k => $v){ $arr = [ 'file' => $v['file'], 'uptime' => date("Y-m-d H:i:s",filemtime($v['file'])), 'nowtime' => date("Y-m-d H:i:s",time()), ]; // var_export($arr); if((filemtime($v['file'])+$overtime) < $time){ $msg .= $v['file']; systemi("{$v['telnet']}"); file_put_contents($path_log,date('Y-m-d H:i:s').' 异常重启项:'.json_encode($arr)."\r\n",FILE_APPEND); } } if($msg == '') { echo "暂无异常"; file_put_contents($path_log,date('Y-m-d H:i:s').' 暂无异常。'."\r\n",FILE_APPEND); }else{ echo "异常项已重启:{$msg}"; }
2024年10月22日
52 阅读
0 评论
0 点赞
2024-10-22
PHP中register_shutdown_function函数的基础介绍与用法详解
1. 函数说明 定义:该函数是来注册一个会在PHP中止时执行的函数 参数说明: void register_shutdown_function ( callable $callback [, mixed $parameter [, mixed $... ]] ) 注册一个 callback ,它会在脚本执行完成或者 exit() 后被调用。 callback:待注册的中止回调 parameter:可以通过传入额外的参数来将参数传给中止函数 2. PHP中止的情况 PHP中止的情况有三种: 执行完成 exit/die导致的中止 发生致命错误中止 a. 第一种情况,执行完成 <?php function test() { echo '这个是中止方法test的输出'; } register_shutdown_function('test'); echo 'before' . PHP_EOL; 运行: before 这个是中止方法test的输出 注意:输出的顺序,等执行完成了之后才会去执行register_shutdown_function的中止方法test b. 第二种情况,exit/die导致的中止 <?php function test() { echo '这个是中止方法test的输出'; } register_shutdown_function('test'); echo 'before' . PHP_EOL; exit(); echo 'after' . PHP_EOL; 运行: before 这个是中止方法test的输出 后面的after并没有输出,即exit或者是die方法导致提前中止。 c. 第三种情况,发送致命错误中止 <?php function test() { echo '这个是中止方法test的输出'; } register_shutdown_function('test'); echo 'before' . PHP_EOL; // 这里会发生致命错误 $a = new a(); echo 'after' . PHP_EOL; 运行: before Fatal error: Uncaught Error: Class 'a' not found in D:\laragon\www\php_book\test.php on line 12 Error: Class 'a' not found in D:\laragon\www\php_book\test.php on line 12 Call Stack: 0.0020 360760 1. {main}() D:\laragon\www\php_book\test.php:0 这个是中止方法test的输出 后面的after也是没有输出,致命错误导致提前中止了。 3. 参数 第一个参数支持以数组的形式来调用类中的方法,第二个以及后面的参数都是可以当做额外的参数传给中止方法。 <?php class Shutdown { public function stop() { echo "这个是stop方法的输出"; } } // 当PHP终止的时候(执行完成或者是遇到致命错误中止的时候)会调用new Shutdown的stop方法 register_shutdown_function([new Shutdown(), 'stop']); // 将因为致命错误而中止 $a = new a(); // 这一句并没有执行,也没有输出 echo '必须终止'; 也可以在类中执行: <?php class TestDemo { public function __construct() { register_shutdown_function([$this, "f"], "hello"); } public function f($str) { echo "class TestDemo->f():" . $str; } } $demo = new TestDemo(); echo 'before' . PHP_EOL; /** 运行: before class TestDemo->f():hello */ 4. 同时调用多个 可以多次调用 register_shutdown_function,这些被注册的回调会按照他们注册时的顺序被依次调用。 不过注意的是,如果在第一个注册的中止方法里面调用exit方法或者是die方法的话,那么其他注册的中止回调也不会被调用。 代码: <?php /** * 可以多次调用 register_shutdown_function,这些被注册的回调会按照他们注册时的顺序被依次调用。 * 注意:如果你在f方法(第一个注册的方法)里面调用exit方法或者是die方法的话,那么其他注册的中止回调也不会被调用 */ /** * @param $str */ function f($str) { echo $str . PHP_EOL; // 如果下面调用exit方法或者是die方法的话,其他注册的中止回调不会被调用 // exit(); } // 注册第一个中止回调f方法 register_shutdown_function("f", "hello"); class TestDemo { public function __construct() { register_shutdown_function([$this, "f"], "hello"); } public function f($str) { echo "class TestDemo->f():" . $str; } } $demo = new TestDemo(); echo 'before' . PHP_EOL; /** 运行: before hello class TestDemo->f():hello 注意:如果f方法里面调用了exit或者是die的话,那么最后的class TestDemo->f():hello不会输出 */ 5. 用处 该函数的作用: 析构函数:在PHP4的时候,由于类不支持析构函数,所以这个函数经常用来模拟实现析构函数 致命错误的处理:使用该函数可以用来捕获致命错误并且在发生致命错误后恢复流程处理 代码如下: <?php /** * register_shutdown_function,注册一个会在php中止时执行的函数,中止的情况包括发生致命错误、die之后、exit之后、执行完成之后都会调用register_shutdown_function里面的函数 * Created by PhpStorm. * User: Administrator * Date: 2017/7/15 * Time: 17:41 */ class Shutdown { public function stop() { echo 'Begin.' . PHP_EOL; // 如果有发生错误(所有的错误,包括致命和非致命)的话,获取最后发生的错误 if (error_get_last()) { print_r(error_get_last()); } // ToDo:发生致命错误后恢复流程处理 // 中止后面的所有处理 die('Stop.'); } } // 当PHP终止的时候(执行完成或者是遇到致命错误中止的时候)会调用new Shutdown的stop方法 register_shutdown_function([new Shutdown(), 'stop']); // 将因为致命错误而中止 $a = new a(); // 这一句并没有执行,也没有输出 echo '必须终止'; 运行: Fatal error: Uncaught Error: Class 'a' not found in D:\laragon\www\php_book\1_23_register_shutdown.php on line 31 Error: Class 'a' not found in D:\laragon\www\php_book\1_23_register_shutdown.php on line 31 Call Stack: 0.0060 362712 1. {main}() D:\laragon\www\php_book\1_23_register_shutdown.php:0 Begin. Array ( [type] => 1 [message] => Uncaught Error: Class 'a' not found in D:\laragon\www\php_book\1_23_register_shutdown.php:31 Stack trace: #0 {main} thrown [file] => D:\laragon\www\php_book\1_23_register_shutdown.php [line] => 31 ) Stop. 注意:PHP7中新增了Throwable异常类,这个类可以捕获致命错误,即可以使用try...catch(Throwable $e)来捕获致命错误,代码如下: <?php try { // 将因为致命错误而中止 $a = new a(); // 这一句并没有执行,也没有输出 echo 'end'; } catch (Throwable $e) { print_r($e); echo $e->getMessage(); } 运行: Error Object ( [message:protected] => Class 'a' not found [string:Error:private] => [code:protected] => 0 [file:protected] => C:\laragon\www\php_book\throwable.php [line:protected] => 5 [trace:Error:private] => Array ( ) [previous:Error:private] => [xdebug_message] => Error: Class 'a' not found in C:\laragon\www\php_book\throwable.php on line 5 Call Stack: 0.0000 349856 1. {main}() C:\laragon\www\php_book\throwable.php:0 ) Class 'a' not found 这样的话,PHP7中使用Throwable来捕获的话比使用register_shutdown_function这个函数来得更方便,也更推荐Throwable。 注意:Error类也是可以捕获到致命错误,不过Error只能捕获致命错误,不能捕获异常Exception,而Throwable是可以捕获到错误和异常的,所以更推荐。 6.巧用register_shutdown_function判断php程序是否执行完 还有一种应用场景就是:要做一个消费队列,因为某条有问题的数据导致致命错误,如果这条数据不处理掉,那么整个队列都会导致瘫痪的状态,这样可以用以下方法来解决。即:如果捕获到有问题的数据导致错误,则在回调函数中将这条数据处理掉就可以了。 php范例参考与解析: <?php register_shutdown_function('myFun'); //放到最上面,不然如果下面有致命错误,就不会调用myFun了。 $execDone = false; //程序是否成功执行完(默认为false) /** ********************* 业务逻辑区************************* */ $tas = 3; if($tas == 3) { new daixiaorui(); } /** ********************* 业务逻辑结束************************* */ $execDone = true; //由于程序由上至下执行,因此当执行到此后,则证明逻辑没有出现致命的错误。 function myFun() { global $execDone; if($execDone === false) { file_put_contents("E:/myMsg.txt", date("Y-m-d H:i:s")."---error: 程序执行出错。\r\n", FILE_APPEND); /******** 以下可以做一些处理 ********/ } } 总结 register_shutdown_function这个函数主要是用在处理致命错误的后续处理上(PHP7更推荐使用Throwable来处理致命错误),不过缺点也很明显,只能处理致命错误Fatal error,其他的错误包括最高错误Parse error也是没办法处理的。
2024年10月22日
62 阅读
0 评论
0 点赞
2024-10-22
fastadmin基层库类修改历史
添加生成选强项框额外生成id类,并将[]转为_ /extend/fast/Form/select(),407行 $id = str_replace(['[',']'],"_",$name); return "<select id='".$id."' {$options}>{$list}</select>"; 假设$name=row[type_id],则最终js调用方法为 $(function(){ $("#row_type_id_").change(function(){ //要触发的事件 console.log('111') }); });
2024年10月22日
69 阅读
0 评论
0 点赞
2024-10-13
ss-panel-v3-mod_Uim修改笔记
为了方便后期维护,做个记录吧,自己用着舒服 码云地址:https://gitee.com/bufanyun/ss-panel-v3-mod_Uim 1.简化用户操作,隐藏ss、ssr教程和下载 \resources\views\material\user\index.tpl \resources\views\material\user\tutorial.tpl 修改内容不再贴出 都是html 2.加入slimphp自带的debug \config\routes.php $debug = true; $configuration = [ 'settings' => [ 'debug' => $debug, 'whoops.editor' => 'sublime', 'displayErrorDetails' => $debug ] ]; //error_reporting(E_ALL); //set_error_handler(function ($severity, $message, $file, $line) { // if (error_reporting() & $severity) { // throw new \ErrorException($message, 0, $severity, $file, $line); // } //}); 3.增加易支付模块 \config\.config.php 加入新的支付配置参数 $System_Config['payment_system']='epay'; #epay易支付 #鼎云支付:http://pay.xianweicm.com $System_Config['epay_partner']= ''; //商户ID $System_Config['epay_key']= ''; //商户KEY $System_Config['epay_apiurl'] = ''; //支付API地址 \config\routes.php //加入新的路由 $app->group('/user', function () { //支付跳转 131行 $this->get('/code/epay', App\Services\Payment::class . ':purchase'); } $app->group('/payment', function () { //异步回调加入get请求支持 161行 $this->get('/notify', App\Services\Payment::class . ':notify'); }); \app\Services\Payment.php 引用新的类 use App\Services\Gateway\Epay getClient(){方法 21行,加入新的指针对象 switch ($method) { case ('epay'): return new Epay(); } \app\Services\Gateway\Epay.php \\增加完整的模块操作 \extra\epay\require.php \\上传易支付sdk包 sdk包下载地址: https://gitee.com/bufanyun/pay/tree/master/SDK/lib 4.取消360浏览拦截 \public\assets\js\fuck.js 隐藏底部判断方法 5.修改composer中 Illuminate database底层 \vendor\esdeathlove\datatables\src\Datatables.php 方法generate() 213行,解决一个php7的报错 if(count((array)$this->edit) > 0) // if (count($this->edit) > 0)
2024年10月13日
90 阅读
0 评论
0 点赞
1
2
...
5