我的个人知识库网站最近数据通过爬虫新增到300万条数据后网站明显开始卡顿,开始以为是淘宝的服务器性能太差劲,没在意,但是后来实在卡的无法打开。于是我今天从早到晚都在优化慢查询,全部优化完成依然很慢。。。于是我打开代码震惊的发现如下代码:
$this->isloadcategories || $this->LoadCategories();
每次访问网站都会从DB加载全部的分类,我的知识库分类达到8000多条,这不得卡死。发现原因我并没有想去专门优化它,直接注释掉,速度直接起飞,没时间折腾,有点无语这种设计。Zblog是真的不适合数据量比较大的网站。
文件位置在zblogphp.php
开发com组件可以用c++,vc++,net,我比较熟悉net,演示用dnet(1).创建项目:启动vs2017,新建项目,选择Visual C# ->Windows桌面->类库通用windows(2). 修改Com项目:点击 项目->项目属性,再点击应用程序->程序集信息,...
PHP不像net支持多继承,自身只支持单继承,为了解决这个问题,php出了Trait这个特性,减少单继承语言的限制。并且能让代码复用率更高。说白了就是一个对象的属性和方法扩展工具一样。例如:trait exts { public f...
<?php /** * @throws Exception */ function curl() { throw new \Exception('err...
php7.1引入了PHP异步信号处理函数pcntl_async_signals() 来处理阻塞问题。在php7之前信号处理方式有2种,第一种是基于ticks来每执行一行代码来触发执行信号监听,第二种是直接while(true){ //监听信号 }第一种方式如果某行的代码阻塞时间较长会影响...
<?php //如果支持exec函数,可以使用的方式 exec('chcp 65001'); //如果exec函数因安全问题禁用,可以使用的方式 pclose(popen('chcp 65001', 'r'));...
经常我们下载国外资源容易被墙,可以通过php脚本获取远程文件流然后输出给我们的浏览器来下载。<?php //设置下载文件的url $url = 'https://mirrors.huaweicloud.com/ubuntukylin/ubuntukylin-19....