php后台操作以及一些减缓服务器压力的问题
上次提到一个微信投票系统,做了一个微信重定向解决了,一个授权复用的问题,昨天投票系统正式投入使用;测试的时候没有问题,上线后出现了一点小问题,
一:php页面参数接受和php中 switch 那个先执行?
答案: 是switch先执行
例:在index.php页面
header("location:/api/wx.php?action=putprofile&accessToken=".$accessToken."&openId=".$openId."&headImgUrl=".$headImgUrl."&nickName=".$nickName);
实现跳转到wx.php页面里面带着几个参数 accessToken openId headImgUrl nickName (php中字符链接符 是 " . " );
下面我在wx.php页面进行接收
$accessToken= $_GET["accessToken"];
$openid= $_GET["openId"];
$headimgurl= $_GET["headImgUrl"];
$nickname = $_GET["nickName"];
//接收参数
switch($_GET['action']){
case "initprofile":
initprofile();
break;
case "getprofile";
getprofile();
break;
case "putprofile";
putprofile();
break;
}
function putprofile($openid, $nickname, $headimgurl){
// echo "<script>alert('$openid');</script>";
// echo "<script>alert('$headimgurl');</script>";
// echo "<script>alert('$nickname');</script>";
//die("INSERT INTO v2016_member (mem_nickname, mem_photo, mem_openid, mem_regdate) VALUES({$nickname}, {$headimgurl}, {$$openid}, {$time}");
// $user = db_exec_query("SELECT mem_id FROM v2016_member WHERE mem_openid = '{$openid}' LIMIT 1");
$sql = "SELECT mem_id FROM v2016_member WHERE mem_openid = '{$openid}' LIMIT 1";
$result = mysql_query($sql);
if(!$row = mysql_fetch_assoc($result)){
// echo "<script>alert('gengxin');</script>";
$time = time();
$ins_id = db_exec_update("INSERT INTO v2016_member (mem_nickname, mem_photo, mem_openid, mem_regdate) VALUES('{$nickname}', '{$headimgurl}', '{$openid}', '{$time}'); ");
}
$user = db_exec_query("SELECT * FROM v2016_member WHERE mem_openid = '{$openid}' LIMIT 1");
$info = array(
'mem_id' => $user[0]['mem_id'],
'mem_nickname' => json_decode($user[0]['mem_nickname']),
'mem_photo' => $user[0]['mem_photo'],
'mem_openid' => $user[0]['mem_openid'],
);
//修改php中session的默认时间
// $lifeTime = 46 * 3600;
// session_set_cookie_params($lifeTime);
session_start();
$_SESSION['user'] = $info;
header("location:/band.php");
}
如上述代码所示,开始我以为在执行 putprofile()这个函数的时候 上面那四个参数已经拿到了呢,当时就是往数据库里插不进去,我在putprofile()alert 了一下那四个参数才知道原来在函数执行的时候还没执行
$accessToken= $_GET["accessToken"];
$openid= $_GET["openId"];
$headimgurl= $_GET["headImgUrl"];
$nickname = $_GET["nickName"];
这些代码可把我坑坏了,后来把这些获取参数的代码放到了putprofile()里面才成功的把字段插入到了数据库里面,
原因是:switch的比$_GET先执行
二:SESSION的默认保存时间
php中SESSION的默认保存时间是 1440秒 意思就是时间一过这个缓存就会被清掉
可以手动去修改两种方法:
1:去服务器配置php环境的一个ini的文件里找到 session.gc_maxlifetime 改成你想要的数值就可以了,建议不要改的太长,以免造成服务器内存饱满,响应过慢或者直接瘫痪
2:代码实现:
// $lifeTime = 46 * 3600;
// session_set_cookie_params($lifeTime);
三:服务器压力问题:
这个问题很广很多情况下都会造成服务器压力过大,造成响应过慢,对于写代码的程序猿来说要做的就是把代码优化,至于怎么优化减轻服务器压力,太复杂就不多说了,可以自行百度;
接下来说说我遇到的问题:
1:我的数据库是操作是php MYSQL代码实现的;
2: 多余的代码很多
3:里面有比较多的 SELECT , update等一些操作,没有做到函数复用;
4:服务器运行内存也比较小;
在上述几个情况下,一开始代码没什么问题,后来随着用户越来越多,越来越多,我突然发现打开这个投票系统的响应时间变长了,我ping了一下看了一个速度

发现这个IP的响应时间 最短 7ms 最长 13ms 平均8ms 这也太慢了,对于用户来说,体验太不好了,一直反映打开太慢
后来我就检查我的代码
发现里面有很多的SELECT , update等一些操作,并且多余的代码比较多,要知道本身MYSQL本身会占用较大虚拟内存,再加上数据库操作很耗内存,就造成了服务器压力比较大,响应时间变长的后果;
所以在php页面中药尽量减少数据库的操作,同事对代码做良好的优化,不然就会造成服务器压力大,响应慢的结果。
就这些吧,今天早上我7点跑到公司来维护代码,也是不容易啊!!
快五一了,预祝快乐!!!!
php后台操作以及一些减缓服务器压力的问题的更多相关文章
- 减少服务器压力php生成静态xml文件
一.引 言 在速度上,静态页面要比动态页面的比方php快很多,这是毫无疑问的,但是由于静态页面的灵活性较差,如果不借助数据库或其他的设备保存相关信息的话,整体的管理上比较繁琐,比方修改编辑.比方阅读权 ...
- YII2 实现后台操作记录日志(转)
一.连接linux服务器,创建数据文件 php yii migrate/create user_log 二.修改数据文件 console/migrations/m150721_032220_admin ...
- YII2 实现后台操作记录日志
一.连接linux服务器,创建数据文件 php yii migrate/create user_log 二.修改数据文件 console/migrations/m150721_032220_admin ...
- xadmin后台页面定制和添加服务器监控组件
xadmin定制 项目需要添加服务器监控页面,碍于xadmin不是很好自定义页面,之前写过插件,太麻烦了,还是直接改源码 原理其实很简单,因为xadmin的处理流程和django类似,都是通过拦截UR ...
- 网站服务器压力Web性能测试(1):Apache Bench:Apache自带服务器压力测试工具
一个网站或者博客到底能够承受多大的用户访问量经常是我们在用VPS或者独立服务器搭建网站了最关心的问题,还有不少人喜欢对LNMP或者LAMP进行一些优化以便提高Web性能,而优化后到底有多大的效果,就需 ...
- 降低web服务器压力
一.越来越多的并发连接数 现在的Web系统面对的并发连接数在近几年呈现指数增长,高并发成为了一种常态,给Web系统带来不小的挑战.以最简单粗暴的方式解决,就是增加Web系统的机器和升级硬件配置.虽然现 ...
- Android操作HTTP实现与服务器通信(转)
Android操作HTTP实现与服务器通信 本示例以Servlet为例,演示Android与Servlet的通信. 众所周知,Android与服务器通信通常采用HTTP通信方式和Socket通信方 ...
- juqery 实现 防止当前页面重复点击,以减轻服务器压力
<script> //防止当前页面重复点击,以减轻服务器压力 $(document).ready(function () { var current_url = location.path ...
- C#先执行一段sql等后台操作后再提示是否后续操作confrim
应用场景:例如选择一个单据号打击打印后先去数据库检索是否有打打印过,如果有则提示,已打印,是否再打 如果没有则不提示,直接进行打印. 实现原理:多做一个隐藏按钮去实现打印功能,页面上的打印按钮则进行数 ...
随机推荐
- 面试题:JS中map的陷阱
题目: ['2', '3', '4'].map(parseInt); 请说出上面代码的执行结果 错误回答: [2, 3, 4] 真正答案: [2, NaN, NaN] 解析: 因为 map 的算子是有 ...
- Markdown语法学习(Github/git.oschina.net上README.md书写规范)(转)
晚上在更新git.oschina.net项目时,突然想知道README.md后缀的来源,于是搜了下,发现README.md使用了一种小标记语言Markdown的语法,于是简单的看了一个,特转载如下,为 ...
- MongoDB入门一
一.环境配置 1.下载MongoDB,找到Bin目录下所有的.exe文件,拷贝到G盘MongoDB(新建)下,在MongoDB下建一个data文件,用于存放数据,创建一个logs文件夹,文件夹下创建一 ...
- 快速阅读《QT5.9 c++开发指南》2
1.sample2_2 信号和槽 MFC中最让人印象深刻的就是"消息映射",这里有理由相信,"信号和槽"是这种功能的发扬和扩展.通过简单的 connect(ui ...
- 《学习OpenCV3》第6章课后习题
//Exercises at end of Chapter 5,<learning OpenCV3> #include "stdafx.h" #include < ...
- Codeforces Round 500 (Div 2) Solution
从这里开始 题目地址 瞎扯 Problem A Piles With Stones Problem B And Problem C Photo of The Sky Problem D Chemica ...
- 强大的Django后台管理
Django 后台 django的后台我们只要加少些代码,就可以实现强大的功能.与后台相关文件:每个app中的 admin.py 文件与后台相关 下面示例是做一个后台添加博客文章的例子: 新建一个 名 ...
- bzoj1458: 士兵占领 网络流
链接 https://www.lydsy.com/JudgeOnline/problem.php?id=1458 也可以去luogu 思路 想成倒着删去点,使得依旧满足覆盖!! 左边横,右边列,之间用 ...
- map数据结构
学习map的这种ES6新加的数据结构.在一些构建工具中是非常喜欢使用map这种数据结构来进行配置的,因为map是一种灵活,简单的适合一对一查找的数据结构.我们知道的数据结构,已经有了json和set. ...
- ES6中对象
ES6允许把声明的变量直接赋值给对象,我们看下面的例子. let name="Zachary"; let skill= 'web'; let obj= {name,skill}; ...