2013年8月6日星期二

云计算之路-阿里云上:禁用Windows虚拟内存引发的重启 - 博客园团队

本邮件内容由第三方提供,如果您不想继续收到该邮件,可 点此退订
云计算之路-阿里云上:禁用Windows虚拟内存引发的重启 - 博客园团队  阅读原文»

昨天(2013年8月6日)下午,承载www.cnblogs.com主站的两台云服务器分别自动重启了1次,由于这两台云服务器使用了负载均衡(SLB),重启并未影响网站的正常访问。

与这次重启相关的Windows事件日志如下:

云服务器1(8核CPU,8G内存):

14:36:22 —— Windows successfully diagnosed a low virtual memory condition. The following programs consumed the most virtual memory: w3wp.exe (1968) consumed 3200438272 bytes, w3wp.exe (6272) consumed 3027517440 bytes, and w3wp.exe (584) consumed 643993600 bytes.

(15:09:04 —— 重启...)

15:09:56 —— Crash dump initialization failed!(这个错误是因为禁用了虚拟内存无法创建dump)

15:09:58 —— The system has rebooted without cleanly shutting down first. This error could be caused if the system stopped responding, crashed, or lost power unexpectedly.

15:10:43 —— The previous system shutdown at 15:09:04 on ‎2013/‎8/‎6 was unexpected.

云服务器2(8核CPU,8G内存):

17:33:45 —— Windows successfully diagnosed a low virtual memory condition. The following programs consumed the most virtual memory: w3wp.exe (5720) consumed 3194974208 bytes, w3wp.exe (2020) consumed 3034882048 bytes, and w3wp.exe (1832) consumed 517074944 bytes.

(17:40:44 —— 重启...)

17:42:11 —— Crash dump initialization failed!

17:42:12 —— The system has rebooted without cleanly shutting down first. This error could be caused if the system stopped responding, crashed, or lost power unexpectedly.

17:42:40 —— The previous system shutdown at 17:40:44 on ‎2013/‎8/‎6 was unexpected.

从事件日志可以看出,在重启发生前的一段时间内,w3wp进程消耗了大量的虚拟内存(单个w3wp进程最高消耗了近3G),而我们禁用了Windows的虚拟内存,在这种情况下某种未知因素引发了系统Crash,从而造成Windows自动重启。

(你也许会问,Windows默认是启用虚拟内存的,为什么要多此一举禁用它?当时是因为发现启用虚拟内存会造成云服务器CPU占用高、波动大,详见博文云计算之路-阿里云上:两个重要突破。)

为了临时解决这次遇到的重启问题,昨天晚上我们启用了这两台云服务器的虚拟内存。

可是今天我们在写这篇博文的时候,在11:35~11:40左右,这两台云服务器竟然都出现了CPU 100%的问题,造成网站不能正常访问。

今天故障的原因还在进一步分析,如果是启用Windows虚拟内存引起的,那我们就进退两难了——虚拟内存,禁还是不禁?


本文链接:http://www.cnblogs.com/cmt/p/3242739.html,转载请注明。

轻量级php框架phpk v1.0发布 - xpbb  阅读原文»

功能说明

  • OOP编写风格,完全依据面向对象的思想编写
  • 多项目管理,共享数据缓存层
  • 自动压缩js和css文件
  • 内嵌一个js微型内核,易于扩展
  • URL路由,支持3种路由模式
  • hook钩子操作,支持系统外扩展
  • 助手函数,支持外围函数添加
  • 模版视图,模版引擎支持视图,支持本地缓存
  • wedgit,支持单独的区块加载
  • 插件机制,可以很方面的引用第三方类库
  • 多语言,支持多语言扩展
  • 多种加密方式
  • 多缓存机制
  • 多种数据库引擎
  • 支持分布式
  • 多权限认证机制

使用说明

一、如何调用?

把phpk文件夹下载到本地,然后在phpk文件夹上层建立index.php,里面代码如下:

<?php
include './phpk/base.php';
?>

 然后访问index.php,然后你就会看到“欢迎使用phpk框架!” 

二、如何配置?

如果第一步访问成功,你就会在项目的根目录发现多了几个文件夹,分别是plugins、data、projects、projects/www。当然还有根目录下的config.inc.php,这个文件是项目总配置文件,代码如下:

<?php
//全局配置声明在这个文件中.
$CONFIG['system']['db']['driver'] = 'mysql';//数据库类型
$CONFIG['system']['db']['charset'] = 'utf8';//数据库编码
$CONFIG['system']['db']['prefix'] = 'ig_';//表名前缀
$CONFIG['system']['db']['master']['host'] = 'localhost';//主库地址
$CONFIG['system']['db']['master']['database'] = 'itest';//数据库名称
$CONFIG['system']['db']['master']['port'] = '3306';//默认端口
$CONFIG['system']['db']['master']['user'] = 'root';//数据库帐号
$CONFIG['system']['db']['master']['password'] = '123456';//数据库密码
$CONFIG['system']['app']['allow_dir'] = array("www","wap","admin","tools");//系统允许的应用
$CONFIG['system']['app']['auto_detect'] = 1; //是否自动侦测是wap还是web
$CONFIG['system']['app']['defalut_web_path'] = 'www';//默认的应用目录
$CONFIG['system']['app']['defalut_wap_path'] = 'wap';//默认的手机应用目录
$CONFIG['system']['security'] = '_phpk_@#!%DFDS_'; // 系统的加密字符串
$CONFIG['language']['switch_on'] = 1; //是否打开语言包
$CONFIG['language']['default_lang'] = 'zh-cn';//默认语言
$CONFIG['language']['auto_detect'] = 1; //是否自动侦测语言
$CONFIG['language']['get_var'] = 'lang'; //前端get获取语言包的字符
$CONFIG['language']['lang_list'] = 'zh-cn';//语言包列表,用逗号隔开

  在projects/www文件夹下面也会多出一个项目配置文件config.inc.php,代码如下:

<?php
//项目配置声明在这个文件中.
$CONFIG['debug'] = 1; // 项目的调试模式,1为打开,0为关闭
$CONFIG['route']['url_type'] = 2; // url模式,1为字符串模式,2为pathinfo模式
$CONFIG['route']['default_controller'] = 'index'; // 默认控制器文件
$CONFIG['route']['default_action'] = 'index'; // 默认action接口
$CONFIG['output']['charset'] = 'utf-8'; // 页面字符集
$CONFIG['output']['errorlog'] = 0; // 是否记录错误日志
$CONFIG['output']['forceheader']= 0; // 强制输出页面字符集,用于避免某些环境乱码,0为关闭,1为开启
$CONFIG['output']['gzip'] = 0; // 是否采用 Gzip 压缩输出
$CONFIG['output']['tmpl_cache'] = 0; // 是否开启模版缓存,0为内存输出做调试模式用,1为检测缓存输出做开发模式用,2为调用缓存输出,3做正式环境用
$CONFIG['output']['layout_on'] = 1; // 是否开启布局,0为关闭,1为开启
$CONFIG['output']['layout_name'] = 'layout'; // 布局的文件
$CONFIG['output']['layout_item'] = '{_content}'; // 布局的内部替换的标签名称
$CONFIG['output']['tmpl_suffix'] = '.php';// 模版的后缀
$CONFIG['output']['default_tmpl'] = 'default'; // 默认模版目录
$CONFIG['output']['csszip'] = 1; // 是否压缩css文件,1为压缩,0为不压缩
$CONFIG['output']['jszip'] = 1; // 是否压缩js文件,1为压缩,0为不压缩
$CONFIG['loader']['libs'] = array();// 是否加载外围的类
$CONFIG['loader']['helpers'] = array();// 是否加载外围函数
$CONFIG['loader']['hooks'] = array();// 是否加载钩子
$CONFIG['session']['prefix'] = 'pk_'; // session的前缀
$CONFIG['session']['id'] = 'phpk'; // session的id
$CONFIG['session']['expire'] = 1200; // session的超时时间
$CONFIG['session']['auto_start'] = 1; // 是否自启动session,1为开启,0为关闭
$CONFIG['cookie']['prefix'] = 'pk_'; // cookie的前缀
$CONFIG['cookie']['path'] = '/'; // cookie的有效路径
$CONFIG['cookie']['expire'] = 1200; // cookie的超时时间
$CONFIG['cookie']['domain'] = ''; // cookie的作用域
$CONFIG['cache']['type'] = 'file'; // 缓存类型
$CONFIG['cache']['table'] = 'tb_cache'; // 缓存表的名称
$CONFIG['cache']['prefix'] = 'cache_'; // 缓存前缀
$CONFIG['cache']['time'] = 3600; // 缓存过期时间
$CONFIG['cache']['check'] = true; // 是否进行缓存的数据校验
$CONFIG['cache']['compress'] = true; // 是否缓存压缩
$CONFIG['auth']['auth_on'] = 1; //是否启动权限认证
$CONFIG['auth']['auth_type'] = 'phpk'; //权限认证方式

  项目配置文件继承了项目总配置文件,也可以对项目总配置文件重写。这样做的好处是,增加了项目的灵活性。

三、如何使用模版?

首先要写controller文件,在projects/www/controllers/indexController.class.php文件夹里,这样写:

<?php
class IndexController extends Controller
{
function index ()
{
$welcome = "欢迎使用phpk框架!";
$this->assign('welcome', $welcome);
$this->display('welcome');
}
}

模版文件支持layout,可以在projects/www/views/layouts/layout.php这样写,(这个文件的名字可以在项目里配置,也可以单独指定)

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title><?php echo $welcome;?></title>
</head>
<body>
{_content}
</body>
</html>

  

然后在projects/www/views/default/index.php模版文件里这样写:

<?php echo $welcome;?>

phpk模版支持js和css简写调用:

{css cssfile1,cssfile2}
{js jsfile1,jsfile2}

也支持一些静态调用方法,比如:{img}{js}{css}{pro}{url}{public}等,尽量做到简单、精简、规范。

phpk的内置模版引擎可以不用本地缓存,直接内存输出,也可以在项目完成后直接调用缓存文件。

四、如何数据查询?

phpk框架摒弃了一般框架的orm(关系数据库映射),让用户更加容易上手。下面是一个模型用例(projects/www/model/indexModel.class.php):

<?php
class IndexModel extends Model{
/**
* 检测用户名
* @param string $username
* @param string $password
* @return multitype:
*/
function checkUser($username,$password){
$sql = "select uid,username,group_id from tb_user where username='$username' and password='$password'";
return $this->select($sql,1);
}
/**
* 更新用户登录信息
* @param int $uid
*/
function updateUser($uid,$arr = array()){
$data = array('last_login_time'=>time(),'last_login_ip'=>getIp());
$result = array_merge($data, $arr);
$this->update("tb_user", $result,"uid='$uid'");
}


}

  

五、如何使用钩子、助手函数和外围库?

phpk框架沿用了codeigniter的钩子思想,借鉴了thinkphp的行为体系,坚持易用简单的原则。配置钩子,首先需要在项目配置文件里加上:

$CONFIG['loader']['hooks'] = array(
'pre_controller' => 'auth'
);// 是否加载钩子

key值参考下面的说明:

* pre_system
* 系统执行的早期调用.仅仅在系统类和配置项加载完毕的时候. 没有执行路由或者其它的过程.
* pre_controller
* 在调用你的任何控制器之前调用.此时所用的基础类,路由选择和安全性检查都已完成.
* post_controller_constructor
* 在你的控制器实例化之后,任何方法调用之前调用,传入的参数为实例化的控制器。
* post_controller
* 在你的控制器完全运行之后调用,传入的参数为实例化的控制器。
* display_override
* output.tmpl_cache=0时截取调试模式下的模版, 用来在系统执行末尾向web浏览器发送最终页面,传入参数为解析后的模版内容。调用后记得exit。
* cache_override
* 截取cache模式下的模版,这可以让你使用自己的方法来显示缓存文件,传入参数为解析后的缓存文件。调用后记得exit。
* post_system
* 在最终着色页面发送到浏览器之后,浏览器接收完最终数据的系统执行末尾调用

  value值为需要加载的文件名,hook的文件放在projects/controllers/hooks/au

阅读更多内容

没有评论:

发表评论