手机浏览 RSS 2.0 订阅 膘叔的简单人生 , 腾讯云RDS购买 | 超便宜的Vultr , 注册 | 登陆
浏览模式: 标准 | 列表2010年12月的文章

Yii使用EClientScript遇到的一点小问题

eclientscript是hightman开发的一个yii插件,用来对于script和css文件进行合并、压缩
当然在自己的项目中,我也为它加了不少的功能和组件,只是因为这是并非公用的东西,拿出来分享意义也不大。
比如,我定义了一个变量path,定义了几个全局的assetUrl,assetPath,然后可以指定目录生成压缩文件,把项目中关于商城、资讯、用户中心等的JS就可以彻底分开了(JS是无所谓,关键是CSS,因为它是认相对目录的)

好了,开始说我遇到的问题吧,目前我有一个JS,二级联动的JS,它是这样写的。

JavaScript代码
  1. (function($){  
  2.    $.fn.xxx = function(){}  
  3. })(jQuery);  

是的,它没有什么问题,而且也挺不错,这样的写法可以防止项目中的$被污染,而使用$只在这一个包里被使用,单独引用的时候,一点问题没有。然而问题就发生在它被合并到一个文件后,上面的代码就无法执行了。。。后来直接改成

XML/HTML代码
  1. $.fn.xxx = function(){}    

好吧,我偷懒了,但,将就点吧,没时间扑在上面。。。招人啊招人啊。。。
本文纯属工作记录,谢谢

Tags: yii, clientscript, jquery

清除数据库的binlog

如果数据库中没有什么太过重要的数据,每隔一段时间还是清除一下binlog吧。这玩意,对于没重要数据的人来说,实在没有意义 。。。。
大多数用binlog的,往往都是在wordpress上。因为它默认是innodb(好象3.01安装的时候,默认是myisam了。。至少我装的某一个库就是myisam的,很意外)

怎么清除bin log呢?先进入数据库命令行
show master logs;
purge master logs to 'mysql-bin.000010';
一般情况看看到最后一个是啥就留到啥吧。。。
留着最近的,真要出啥事了,还能恢复一下。。(不过,有多少人在自己的机器上恢复数据的?公司的除外。。。。)

Tags: innodb, mysql, binlog

Yii 错误操作引起的问题

在YII项目实施过程中,遇到一个问题,即,只在某一个module里需要获取IP的来源,并判断具体来自于何处。

默认在yii里取得客户端IP只有一个简单的方法,来自于ChttpRequest类,只是这里只有一个判断,即Remote_addr,而这个,一般来说是不准的,因此,我直接COPY了康盛的IP来源判断。

然后通过那个比较出名的iplocation类读取wry.dat,来获取IP的定位(iplocation仿佛是几年前王总写的还是andot写的?用来分析纯真IP库的。说起这个wry.dat,事实上,它的来源还真是要从以前的一款软件:追捕说起,但那个年代远了,早就消失在历史的长河中了。)

好吧,上面就是我要说的背景,于是,我认为,既然要在module里获取,那么我就在module的init方法里直接实现了吧。

然后,我把具体的获取IP,并且分析IP来源,并到数据库查询以获取Area_id的代码扔在了module 的 init 方法里,然后运行一看,直接502 bad gateway出现了。折腾了好久,发现都一直是502。

但是测试了一下,把这些代码COPY到Controller的action里面,又十分正常(因为没空研究module的实现),于是就把代码COPY到module的beforeAction方法中了。

然后问题解决。(没仔细想为什么,只是纯粹一个记录,让自己知道,尽量不要在init里写上一大堆实现代码。。。)

Tags: yii

VirtualBox使用技巧集锦

记录这个集锦是为了告诉我自己,有些东西不是想当然就OK的。比如我在ubuntu下建的VB文件,不是把snapshots目录下的东西COPY出来就OK的。这才是我心头的痛。
当我从ubuntu回到win时代的时候,我把virtuabox里的虚拟机想拷贝出来。于是乎,选择了导出,但是。。。ovf里的路径指的是snapshots目录,所以我拷贝了所有的snapshot里所有的目录和文件,但是到win下面之后,就再也打开不了。问了N多人,都说UID不一样是不可以的,乔大妈直接告诉我,原始的那个VDI不存在,你就别想着恢复了。于是,我对着所谓备份出来的Sav文件和vdi文件,想哭但是哭不出来(4G多的vdi呀,你想想里面存了多少东西。。。。这个就不如vmware了。直接就一文件,想拷就拷,哎,不过vb这种镜像功能也有好处,只是我不懂而已)

好吧,上菜吧。。。。VirtualBox使用技巧集锦

以前用过VMware也用过微软的VPC,VMware太大了,而MS自己的VPC性能确实不是很好,可能MS重点放在Hyper-V上了吧.前些 天安装了VirtualBox,才用了一天就发现确实很好用。特别是起特有的无缝模式窗口确实很棒。下面讲些我总结的一些virtualbox使用技巧。

用了几天也看了下VirtualBox自带的说明文挡加上到网上查到地一些资料。汇下总吧

VirtualBox历史

Sun xVM VirtualBox 是由德國InnoTek(已被Sun併購) 這家軟體公司出品的軟體,它提供使用者在32或64位元的 Windows、Solaris 及 Linux 作業系統上虛擬另外的機器執行其它x86的作業系統,使用者可以在 VirtualBox 上安裝並且執行 Solaris、Windows、Linux、OS/2 Warp、OpenBSD 及 FreeBSD 等系統作為客戶機操作系統[1]。在2007年1月,InnoTek以GNU通用公共许可证 (GPL)釋出VirtualBox,並提供二進位版本及開放源碼版本的程式碼。

和同性質的VMware及Virtual PC比較下,VirtualBox獨到之處包括Remote Desktop Protocol(RDP)、iSCSI及USB的支援,VirtualBox在客戶機操作系統上已可以支援USB 2.0的硬體裝置。

在VirtualBox里复制VDI文件

在VirtualBox的快速修复界面里,可以随时生成当前状态的备份。当生成了备份之后,会在Snapshots目录下创建一个新的VDI文件,之后对当前状态所做的一切操作都将针对最新的VDI文件,而VDI目录下的初始VDI文件就不会再改变了。
我一般在装好Guest OS并做完打补丁、安装常用软件等操作后就创建一个备份,如果Guest OS发生了问题可以随时恢复到干净的系统。但是有时需要在不同的软件环境下做不同的事情,开始时我希望能用一个VDI文件生成两个不同的备份并分别配置成 不同的环境,但是发现VirtualBox的备份是线性的,也就是说只能针对当前状态做一个备份,而恢复备份时也只能恢复到上一个备份的状态,不能同时存 在两个不同的当前状态。
没有办法,只能把初始的VDI文件复制出来一份用于另外的环境。但是很快发现,复制出来的VDI文件无法在虚拟介质管理器中注册,因为每个VDI文件都有一个唯一的uuid,而VirtualBox不允许注册重复的uuid。
看了帮助文件后,发现VBoxManage有一个clonevdi方法可以克隆VDI文件,并赋予它一个新的uuid。具体用法是在命令行里执行:

VBoxManage clonevdi 原始VDI文件名 新的VDI文件名

直接写VDI文件名即可,不用指明VDI文件所在路径,新的文件会在全局设定中指定的VDI目录下创建。如果VDI文件名里带有空格,应该在两端加 上双引号。VBoxManage命令位于VirtualBox安装目录下,缺省路径是C:\Program Files\Sun\xVM VirtualBox。
用这个方法创建了新的VDI文件后,就可以正常注册并在另一个虚拟机中使用了。

收缩虚拟机磁盘文件大小

由于经常要测试一些软件,我在VirtualBox虚拟机中安装了一套Windows。使用过虚拟机的朋友都知道,为了节省硬盘空间,一般都使用动 态扩展映像。它不会在一开始就占用指定大小的硬盘空间,而是随着实际使用的需要动态扩展。但是在虚拟系统里删除了文件,使用过的空间并不会自动收回。虚拟 系统使用久了以后,磁盘映像文件会变得越来越大。

我以前使用过VMware,在VMware Tools里有一个很方便的Shrink功能可以收回未使用的硬盘空间,但是在VirtualBox里没有看到这样的选项。经过上网查找资料,终于找到了 在VirtualBox(我用的是2.0.0版)里Shrink的方法,只需要三个步骤:

第一步:在Guest OS中整理磁盘碎片。可以使用Windows自带的碎片整理工具,不过更推荐使用Defraggler。这是一款免费的磁盘碎片整理工具,使用简单,整理速度很快。
第二步:将Guest OS的磁盘剩余空间清零,也就是把0值写入磁盘未使用空间的每一个字节。这一步是关键,因为在下一步里,所有只包含0值的磁盘空间将被收回。可以用 Sysinternals出品的一个命令行工具SDelete来完成这一步。在Guest OS的命令行里执行:

sdelete -c c:\

其中c:\是要清零的磁盘分区,应依次对所有虚拟磁盘分区执行这一步,如d:\、e:\等等。
第三步:使用VirtualBox提供的VBoxManage工具收缩磁盘映像文件。在Host OS的命令行中进入VirtualBox的安装目录(缺省为C:\Program Files\Sun\xVM VirtualBox),执行:

VBoxManage modifyvdi "Windows XP.vdi" compact

其中Windows XP.vdi是要收缩的磁盘映像文件名,请根据实际名称修改,不用指定路径。
经过这三个步骤以后,我的vdi文件从2.5G收缩到了1.2G,效果非常明显。以上介绍的前两个步骤所使用的工具是针对Windows的,如果Guest OS是Linux或其它系统,可以找一找相同功能的工具软件,原理都是一样的。

---EOF---

贴完此贴后,看着那4G多的vdi文件,不知道怎么办好,网上的所谓的UID恢复、重建,都是无效的(也就是本文中的克隆UID)。我该怎么办?如果有达人看到,请解救我于水火之中啊。()

Tags: virtualbox

INI配置文件的解析

我不知道怎么说才好,因为我在读INI文件的时候,往往都是用现成的函数:parse_ini_file或者是parse_ini_string,但怎么写入,就是另外的方法了(自己实现。。。。)

所以看到这篇文章的时候,我也才刚刚知道,原来,还有一个dba的函数可以用,嗯,仔细看了一下dba这个函数的installtion,发现支持inifile也是从PHP5才开始实现的。好吧,相应的dba相关的可以看看这里:http://www.php.net/manual/en/dba.installation.php,详细的还是看这里吧:http://www.php.net/manual/en/book.dba.php

OK,上原文,它来自于:http://www.cardii.net/php-spl-parse-ini-file/。

曾经介绍过SPL的各类型接口和迭代器。今天,在浏览PHP源码目录时,发现有个解析INI文件的例子,觉得不错,于是整理了一个实例,拿来分享下。

在PHP应用程序中,配置文件不可或缺,特别是商城,CMS之类的产品,不同的客户需求不同,当然,不会每个客户开发一套程序,好办法的是每个客户 有一套不同的配置文件。适合做配置文件的我曾经也说过,主要有四类:PHP数组(几乎其他的配置方法最终都是解析成为PHP数组),XML,YAML和 INI。今天只讲INI文件。ZendFramework使用此配置。

下看个DbaReader类。文件名为 DbaReader.php:

PHP代码
  1. <?php  
  2. class DbaReader implements Iterator  
  3. {  
  4.   
  5.     protected $db = NULL;  
  6.     private $key = false;  
  7.     private $val = false;  
  8.   
  9.     /** 
  10.      * Open database $file with $handler in read only mode. 
  11.      * 
  12.      * @param file    Database file to open. 
  13.      * @param handler Handler to use for database access. 
  14.      */  
  15.     function __construct($file$handler) {  
  16.         if (!$this->db = dba_open($file'r'$handler)) {  
  17.             throw new exception('Could not open file ' . $file);  
  18.         }  
  19.     }  
  20.   
  21.     /** 
  22.      * Close database. 
  23.      */  
  24.     function __destruct() {  
  25.         dba_close($this->db);  
  26.     }  
  27.   
  28.     /** 
  29.      * Rewind to first element. 
  30.      */  
  31.     function rewind() {  
  32.         $this->key = dba_firstkey($this->db);  
  33.         $this->fetch_data();  
  34.     }  
  35.   
  36.     /** 
  37.      * Move to next element. 
  38.      * 
  39.      * @return void 
  40.      */  
  41.     function next() {  
  42.         $this->key = dba_nextkey($this->db);  
  43.         $this->fetch_data();  
  44.     }  
  45.   
  46.     /** 
  47.      * Fetches the current data if $key is valid 
  48.      */  
  49.     private function fetch_data() {  
  50.         if ($this->key !== false) {  
  51.             $this->val = dba_fetch($this->key, $this->db);  
  52.         }  
  53.     }  
  54.   
  55.     /** 
  56.      * @return Current data. 
  57.      */  
  58.     function current() {  
  59.         return $this->val;  
  60.     }  
  61.   
  62.     /** 
  63.      * @return Whether more elements are available. 
  64.      */  
  65.     function valid() {  
  66.         if ($this->db && $this->key !== false) {  
  67.             return true;  
  68.         } else {  
  69.             return false;  
  70.         }  
  71.     }  
  72.   
  73.     /** 
  74.      * @return Current key. 
  75.      */  
  76.     function key() {  
  77.         return $this->key;  
  78.     }  
  79. }  
  80. ?>  

DbaReader使用Iterator接口,当然要实现里面的5个迭代方法。迭代方法对handlerhandlerINI文件的解析,用到了dba扩展。

说点题外话,什么是Dba?为什么使用Dba?
Dba是一款数据库,确切点说,是一款索引化的文件存储系统。适合相对比较静态的索引化的数据存储。所有版本的Linux都会带此数据库。
既然使用文件来存储数据,为什么还有使用Dba呢?原因有二:
1数据记录的存储长度可以不是固定的;
2使用索引存储和检索数据。

DbaReader提供一个访问INI文件数据的迭代方法,如果需要存储删除数据呢?所以DbaArray在继承DbaReader的基础上,实现了此功能。

PHP代码
  1. <?php  
  2. class DbaArray extends DbaReader implements ArrayAccess  
  3. {  
  4.   
  5.     /** 
  6.      * Open database $file with $handler in read only mode. 
  7.      * 
  8.      * @param file    Database file to open. 
  9.      * @param handler Handler to use for database access.取值http://www.php.net/manual/en/dba.requirements.php 
  10.      */  
  11.     function __construct($file$handler)  
  12.     {  
  13.         $this->db = dba_popen($file"c"$handler);  
  14.         if (!$this->db) {  
  15.             throw new exception("Databse could not be opened");  
  16.         }  
  17.     }  
  18.   
  19.     /** 
  20.      * Close database. 
  21.      */  
  22.     function __destruct()  
  23.     {  
  24.         parent::__destruct();  
  25.     }  
  26.   
  27.     /** 
  28.      * Read an entry. 
  29.      * 
  30.      * @param $name key to read from 
  31.      * @return value associated with $name 
  32.      */  
  33.     function offsetGet($name)  
  34.     {  
  35.         $data = dba_fetch($name$this->db);  
  36.             if($data) {  
  37.             if (ini_get('magic_quotes_runtime')) {  
  38.                 $data = stripslashes($data);  
  39.             }  
  40.             //return unserialize($data);  
  41.             return $data;  
  42.         }  
  43.         else  
  44.         {  
  45.             return NULL;  
  46.         }  
  47.     }  
  48.   
  49.     /** 
  50.      * Set an entry. 
  51.      * 
  52.      * @param $name key to write to 
  53.      * @param $value value to write 
  54.      */  
  55.     function offsetSet($name$value)  
  56.     {  
  57.         //dba_replace($name, serialize($value), $this->db);  
  58.         dba_replace($name$value$this->db);  
  59.         return $value;  
  60.     }  
  61.   
  62.     /** 
  63.      * @return whether key $name exists. 
  64.      */  
  65.     function offsetExists($name)  
  66.     {  
  67.         return dba_exists($name$this->db);  
  68.     }  
  69.   
  70.     /** 
  71.      * Delete a key/value pair. 
  72.      * 
  73.      * @param $name key to delete. 
  74.      */  
  75.     function offsetUnset($name)  
  76.     {  
  77.         return dba_delete($name$this->db);  
  78.     }  
  79. }  
  80. ?>  
使用范例
构建文件text.ini,内容如下:
XML/HTML代码
  1. host = localhost  
  2. password = password  
  3. database = data  

 

文件index.php.代码如下:

PHP代码
  1. <?php  
  2. function loadClass($class)  
  3. {  
  4.     require_once __DIR__.DIRECTORY_SEPARATOR.$class.'.php';  
  5. }  
  6. spl_autoload_register('loadClass',false);  
  7.   
  8. $iniFile = __DIR__.DIRECTORY_SEPARATOR.'test.ini';  
  9.   
  10. $ini = new DbaArray($iniFile,'iniFile');  
  11. echo $ini['database'];  
  12. var_dump($ini);  
  13. ?>  
--EOF--

看完上面这一段,是不是有什么想法?原来ini的操作也是这么的方便?不过,如果是纯读取的话,我还是比较推荐于parse_ini_file之类的(突然间忘了,如果编码不一样怎么办?ansi/utf-8,这真是一个永恒的痛。)

Records:3912345678