Skip to content

Linux中cp总是提示覆盖文件的解决办法

25-Jan-10

把a目录下的文件复制到b目录
cp –r a/* b
执行上面的命令时,b存在的每个文件都会提示是否覆盖;
cp –r –f a/* b
执行上面的命令时,b存在的每个文件都不再会提示;
这是我们希望的理想状态,但是有时加了-f了,怎么还会有提示呢?原来一些服务器会默认增加别名 alias cp=’cp -i’,当你执行cp时,其实执行的是cp –i。
在终端执行alias就可以看出来了。
[root@devdb ~]# alias
alias cp=’cp -i’
可以这样解决
[root@devdb ~]# vi ~/.bashrc
在alias cp=’cp -i’前加上”#”注释掉这行,:wq!保存退出!

然后重新登陆就可以了。

linux 覆盖文件(1)linux 覆盖文件 ?(1)linux下cp提示是否覆盖(1)cp 覆盖(2)cp 覆盖存在的文件(1)linux cp 覆蓋(1)

Google退出中国的另外一个主要原因

17-Jan-10

Google退出中国的另外一个原因是:GOOGLE公司将在2010年开始推行全球卫星无线上网。当然主要原因还是审查制度破坏了其企业准则。下面是报道:

继推出“Google Chrome”浏览器后,搜寻引擎巨擘Google又再向网路上中下游整合之路迈进一步,9日与汇丰银行、国际有线电视集团“Liberty Global”合作,推出“O3b Networks”计划,锁定非洲及其他新兴市场的网路用户,提供卫星上网服务,进一步扩大网路使用者的数量。

“Ob Networks”意即“other3 billion (people )”(另外三十亿人口的网路 ),初步涵盖范围为赤道南北纬度各五度的区域。未来还将扩大到非洲、南美洲其他地区,以及亚洲和中东。

三家企业目前已各自出资两千万美金,加上媒体顾问公司“Allen & Company”的五百万美金,合计六千五百万美金;未来三家公司还可能继续投资一亿五千万美金到一亿八千万美金,最终投资金额可能高达七亿五千万美金。

“O3b Networks”初期将向卫星制造商“Thales Alenia Space”购买十六颗低轨道卫星,为区域内地面手机基地台提供连网服务。Google替代性连网部门经理阿德勒表示,这项计划在2010年启用后,将可使区域内的宽频上网费用降低九十五%。

有了卫星上网,谁还要中国的电信网络啊,都是垃圾,全部都会被淘汰!有了卫星上网,墙自然就不存在了,难道到时候ZF要在全中国的上空建立一个屏蔽墙么?

中国几千年内创造了四大发明,21世纪又创造了第5大发明 – GFW,其威力真是让世人瞩目啊!



http://www.pkphp.com/(2)php(14)google 中国(1)google推出中国(2)o3b 计划(1)O3b Networks google(2)o3b 卫星(1)谷歌推出中国 原因(4)Google、汇丰银行、国际有线电视集团(1)卫星上网费用(1)Google衛星上網(1)有线电视 上网(1)google 退出 进一步消息(1)谷歌推出中国的真正原因(1)google 推出中国的yuanyin(1)

[转]详细介绍php Zend Framework中的render使用方法

09-Jan-10

通常在我们利用ZF实现php的mvc时,最关键的地方当然是Controller类的各种action方法,在action方法中,我们确定及输出内容. 在类 abstract class Zend_Controller_Action 中的dispatch方法你可以发现这一行 $this->$action();

那么如何确定及输出内容呢,就是进行render了,不过这个render却是有好几个的,下面列出这几个情形
1<?php
2class IndexController extends Zend_Controller_Action
3{
4 public function contactAction()
5 {
6 //$this->render(“index”);
7 //$this->render();
8 //$this->renderScript(“sidebar.phtml”);
9
10
11 //$this->_helper->viewRenderer(“sidebar”);
12
13 //$this->view->render(“sidebar.phtml”);
14 //$this->view(“sidebar”);
15
16 }
17}
18?>

总结下来,似乎就是这三中render了(欢迎补充)

1.自身render

先看第一种
//$this->render(“index”);
//$this->render();
//$this->renderScript(“sidebar.phtml”);
这是直接使用Zend_Controller_Action类的render方法
第一句是render了另一个action所对应的视图(看清了 是render那个action对应的视图 而不是执行那个action!)
第二句式render本action对应的视图,这个有什么意义呢(因为很多情形你看不到这个写法的),这个下面再说.
第三句是render特定的视图文件,这里你可能认为前两个方法实际是调用了这个renderScript,其实不是如此.
下面就阐述一下.顺便解释第二句的原因.
Zend_Controller_Action类的render方法中其实是有两个分支的 如下render函数代码
1 public function render($action = null, $name = null, $noController = false)
2 {
3 if (!$this->getInvokeArg(noViewRenderer) && $this->_helper->hasHelper(viewRenderer)) {
4 return $this->_helper->viewRenderer->render($action, $name, $noController);
5 }
6
7 $view = $this->initView();
8 $script = $this->getViewScript($action, $noController);
9
10 $this->getResponse()->appendBody(
11 $view->render($script),
12 $name
13 );
14 }
可以看到一种情形是利用(代理)了视图助手类(viewRenderer)的render方法
另一种是禁用助手时的情形 就得亲自上阵了,这也就是render()出现的原因,你禁用了视图助手后要输出本action对应视图内容可以使用render()来完成

2.通过视图助手viewRenderer

上面说起了视图助手,那我们来看action中的第二个片段,正是借助视图助手来进行
//$this->_helper->viewRenderer(“sidebar”);
实际上这里这句话并不是render内容,而是指定了要render哪个视图,参考Zend_Controller_Action_Helper_ViewRenderer类的这个函数
1 public function direct($action = null, $name = null, $noController = null)
2 {
3 $this->setRender($action, $name, $noController);
4 }
那么输出呢 是怎么输出的?
可以在$this->_helper->viewRenderer(“sidebar”); 后直接调用$this->render();即可.
但是实际上你完全不用调用,只写那一句就行.
你不写render的时候,视图助手会来替你完成.在Zend_Controller_Action类中的dispatch方法中有这么一句
$this->_helper->notifyPostDispatch();
_helper是什么? 是一个Zend_Controller_Action_HelperBroker类 ,其中有这个方法
1 public function notifyPostDispatch()
2 {
3 foreach (self::getStack() as $helper) {
4 $helper->postDispatch();
5 }
6 }

可以看到调用了其中各个助手的postDispatch();
而viewRenderer正是其中的一个助手,其postDispatch方法如下
1 public function postDispatch()
2 {
3 if ($this->_shouldRender()) {
4 $this->render();
5 }
6 }
正是在这里视图助手帮你进行了render,如果你自己render了,聪明的视图助手会知晓的,可以查看下在_shouldRender()中的这个 $this->getRequest()->isDispatched(),及Zend_Controller_Front 类中dispatch方法的这句话:$this->_request->setDispatched(true);

3.终极render 关于Zend_View->render()

好了现在我们来看看Zend_View的render().
在上面的两个中我们都说到了render(),比如action的render和视图助手的render
那么你该问个问题:就这样了?后面呢?
后面的才是关键的.
在action的render中,你可能注意到这句话了
10 $this->getResponse()->appendBody(
11 $view->render($script),
12 $name
13 );
而我们再看看viewRenderer的render(),viewRenderer的render方法其实是调用了renderScript方法,代码如下
1 public function renderScript($script, $name = null)
2 {
3 if (null === $name) {
4 $name = $this->getResponseSegment();
5 }
6
7 $this->getResponse()->appendBody(
8 $this->view->render($script),
9 $name
10 );
11
12 $this->setNoRender();
13 }
可以看到这里跟action的render有点类似,也有同样的那句话.
就是说action的render和viewRenderer的render其实都是调用Zend_View的render,拿到内容而后置放到response中

Zend_View的render:
1 public function render($name)
2 {
3 // find the script file name using the parent private method
4 $this->_file = $this->_script($name);
5 unset($name); // remove $name from local scope
6
7 ob_start();
8 $this->_run($this->_file);
9
10 return $this->_filter(ob_get_clean()); // filter output
11 }

至于run:
1 protected function _run()
2 {
3 if ($this->_useViewStream && $this->useStreamWrapper()) {
4 include zend.view:// . func_get_arg(0);
5 } else {
6 include func_get_arg(0);
7 }
8 }

那么你就明白了最开始代码中的第13行
13 //$this->view->render(“sidebar.phtml”);
其实是个幌子,哈.这句话只是得到了内容,但是呢 没做处理!
所以我们应该这样
13 echo $this->view->render(“sidebar.phtml”);
再然后呢?参看Zend_Controller_Front类dispatch
$this->_response->sendResponse();
及Zend_Controller_Response_Abstract类
1 public function outputBody()
2 {
3 foreach ($this->_body as $content) {
4 echo $content;
5 }
6 }

而至于第14行
14 //$this->view(“sidebar”);
貌似合理,瞪一眼就知道了:这句话地地道道的错误
action 中没有这个方法,__call中也没有相应处理,不象_helper->viewRenderer(“sidebar”);在 _helper针对该情况在__call中有相应处理
1 public function __call($method, $args)
2 {
3 $helper = $this->getHelper($method);
4 if (!method_exists($helper, direct)) {
5 require_once Zend/Controller/Action/Exception.php;
6 throw new Zend_Controller_Action_Exception(Helper ” . $method .“ does not support overloading via direct());
7 }
8 return call_user_func_array(array($helper, direct), $args);
9 }
没有viewRenderer这个方法,于是去寻找名为viewRenderer并且有direct方法的助手,找到了即执行这个direct方法(上面第二部分贴过代码了)
至于viewRenderer这个助手存放时,要注意到他的名字是死的 就是”viewRenderer”,具体看Zend_Controller_Action_Helper_Abstract类的getName方法
1 public function getName()
2 {
3 $full_class_name = get_class($this);
4
5 if (strpos($full_class_name, _) !== false) {
6 $helper_name = strrchr($full_class_name, _);
7 return ltrim($helper_name, _);
8 } else {
9 return $full_class_name;
10 }
11 }
之所以提到这点是因为在Zend_Controller_Action_Helper_ViewRenderer注释中你能看到这句话
// In your action controller methods:
$viewHelper = $this->_helper->getHelper(‘view’);
而实际上你复制这句话到your action controller methods中去 只会出错
Exception information:

Message: Action Helper by name View not found

个人感觉php Zend Framework还是很不错,虽然一直没搞好调试器
但是非常满意于可以随处置放var_dump

php framework(1)php zend framework(5)zend framework render(4)zend framework 禁用视图(1)php 类 render(1)zend render 传递参数(1)php {}(1)zend framework action render(1)php ?:(1)zend frameworks 两个视图(1)$this->render()(1)zend framework view(1)zend framework foreach的用法(1)php controller action render(1)Zend Framework 指定视图文件(1)

CentOS 防火墙打开80,22,3306端口操作

02-Jan-10

#/sbin/iptables -I INPUT -p tcp –dport 80 -j ACCEPT
#/sbin/iptables -I INPUT -p tcp –dport 22 -j ACCEPT
#/sbin/iptables -I INPUT -p tcp –dport 3306 -j ACCEPT
然后保存:
#/etc/rc.d/init.d/iptables save

查看打开的端口:
# /etc/init.d/iptables status

centos 防火墙 80(4)iptable 打开80(1)3306端口 防火墙(1)CentOS 开放端口(3)linux 3306端口(1)centeros IPTABLES 操作(2)linux打开3306端口(1)centos 打开端口(4)centos 防火墙 添加端口(1)linux 防火墙 打开3306端口(1)centos 防火墙 端口开放(1)centos 端口打开(1)centos防火墙(1)centos 添加打开端口(1)cent os 开 端口(2)

便宜、方便、速度快的国外linux vps主机商Linode.com介绍

01-Jan-10

上一篇我介绍了在centos下如何快速安装web服务的方法步骤,希望对你有所帮助,如果你的网站想搬家到国外,我推荐一家服务稳定,操作简单,利用国内的信用卡即可购买的linux vps主机给你,这家是https://www.linode.com,是一家优秀的老牌的美国空间服务商。

linode.com的优点是:有四个机房供你挑选,分别是:Fremont, CA、Dallas, TX、Atlanta, GA、Newark, NJ。对国内访问来说,速度较快的当属Fremont, CA机房了,其次是Newark, NJ机房。

当你在linode购买vps时,填写完注册表单,如果付款成功,下来的第一步就是选择机房,面向国内用户的网站最好选择Fremont, CA机房。第二步是选择操作系统,linode的VPS几乎可以安装所有类型的unix和linux的系统,但是作为web服务器来使用,我建议采用Centos,在Centos下可以非常简单的按照我介绍的步骤安装完web服务组件,这个组件相比较apache+mysql来说,能够承受的响应更多,负载承受能力更强。

另外在linode购买了vps后,如果ip被GWF,可以选择单独增加ip,一个月才1$,便宜的跟白菜一样,所以你几乎可以不用怕自己的网站因为ip被封而无法访问。另外,如果你购买了一个VPS的,用了一段时间发现需要扩容,很简单,直接可以在线操作增加RAM和硬盘以及流量等,当然你也可以直接一键操作升级VPS套餐。

另外一个好处,如果你发现当前选择的机房在国内访问速度不够快,没关系,给客服说一声,转移机房,人家会很快帮你完成机房转移,对你来说,等待一会儿就行了,更换完毕后,把域名解析更改一下就可以了,就这个简单。

用了linode才知道什么叫方便,国内的空间都是垃圾!唉!别给我扔砖头!

http://www.pkphp.com/(2)linux(5)速度最快 vps(1)linode vps windows(1)linode 機房(1)什么是linode(1)国外 linux vps(1)linode(18)linode 主机(3)linode 是(1)国外便宜vps(1)linode 速度(3)VPS(1)linode 中国 访问 速度(1)vps linux 选择(1)