If you want to create one negative DateInterval, you may use the following ways
Get dateTime object two months ago.
$dateTime = (new DateTime());
var_dump($dateTime);
$month = -2;
$dateInterval = new DateInterval('P' . abs($month) . 'M');
if ($month < 0) {
$dateInterval->invert = 1;
}
$dateTime->add($dateInterval);
it will shows:
object(DateTime)[94]
public 'date' => string '2013-11-26 11:10:23' (length=19)
public 'timezone_type' => int 3
public 'timezone' => string 'Asia/Tokyo' (length=10)
object(DateTime)[94]
public 'date' => string '2013-09-26 11:10:23' (length=19)
public 'timezone_type' => int 3
public 'timezone' => string 'Asia/Tokyo' (length=10)
11/26/2013
11/21/2013
count the appearance times of string in file
When you want to count the appearance lines of one special string in a file, you may use
grep -o will-fined-string /path/to/file | wc -l
grep -o will-fined-string /path/to/file | wc -l
PHP goto keywords
goto has a bad reputation among programmers.
But sometime it is also very useful.
Here are one example
for($i=0,$j=50; $i<100 br="" i=""> while($j--) {
if($j==17) goto end;
}
}
echo "i = $i";
end:
echo 'j hit 17';100>
Paper
But sometime it is also very useful.
Here are one example
for($i=0,$j=50; $i<100 br="" i=""> while($j--) {
if($j==17) goto end;
}
}
echo "i = $i";
end:
echo 'j hit 17';100>
Paper
10/29/2013
Create multiple subdirectories in one command by mkdir
Usually, you may want to create more subdirectories by one command, e.g.
mkdir /var/www/aa/bbb/ccc/dddd
if directory aa does not exist, you can not create.
So you should use
mkdir /var/www/aa
mkdir /var/www/bbb
....
It is terrible by these commands. Of course, you may use one command to complete it
mkdir -p /var/www/aa/bbb/ccc/dddd
It is simple. Another, if you want to create new directories
/var/www/aa/bbb/ccc/dddd
/var/www/aaa/bbb/ccc/dddd
/var/www/aaaa/bbb/ccc/dddd
You may use these command to complete. But there is one another command to complete based on regular form {}.
mkdir - p /var/www/{aa,aaa,aaaa}/bbb/ccc/dddd
It is nice. Good luck to you.
mkdir /var/www/aa/bbb/ccc/dddd
if directory aa does not exist, you can not create.
So you should use
mkdir /var/www/aa
mkdir /var/www/bbb
....
It is terrible by these commands. Of course, you may use one command to complete it
mkdir -p /var/www/aa/bbb/ccc/dddd
It is simple. Another, if you want to create new directories
/var/www/aa/bbb/ccc/dddd
/var/www/aaa/bbb/ccc/dddd
/var/www/aaaa/bbb/ccc/dddd
You may use these command to complete. But there is one another command to complete based on regular form {}.
mkdir - p /var/www/{aa,aaa,aaaa}/bbb/ccc/dddd
It is nice. Good luck to you.
10/16/2013
8/08/2013
Install javac on your centos server
The centos will install java automatically. But not for javac. So you have to install javac by yourself when you want to develop java program.
Now I give the step for install javac on Centos Server
1. get java version installed on your machine
java -version
you will get
java version "1.7.0_25"
OpenJDK Runtime Environment (rhel-2.3.10.4.el6_4-x86_64)
OpenJDK 64-Bit Server VM (build 23.7-b01, mixed mode)
2. install javac
yum install java-1.7.0-openjdk-devel
3. check javac
javac -version
javac 1.7.0_25
I hope it may assist you when you install java development package on your PC.
Now I give the step for install javac on Centos Server
1. get java version installed on your machine
java -version
you will get
java version "1.7.0_25"
OpenJDK Runtime Environment (rhel-2.3.10.4.el6_4-x86_64)
OpenJDK 64-Bit Server VM (build 23.7-b01, mixed mode)
2. install javac
yum install java-1.7.0-openjdk-devel
3. check javac
javac -version
javac 1.7.0_25
I hope it may assist you when you install java development package on your PC.
7/10/2013
yum install xdebug + xdebug test example for php 5.4
Xdebug is a nice tool for PHP development. The following is taken from official site:
Xdebug's basic functions include the display of stack traces on error conditions, maximum nesting level protection and time tracking.
There are many ways to install xdebug. Now I give one way to use yum for xdebug installment.
sudo yum install php-xdebug
or with enable remi repo
sudo yum --enablerepo=remi install php-xdebug
------------------------------------------------------example---------------------------------------------------------------
now let us test one example for xdebug
vi test.php
<?php
echo $a;
$a++;
echo $a;
?>
>> php test.php
PHP Notice: Undefined variable: a in /var/www/a.php on line 3
PHP Stack trace:
PHP 1. {main}() /var/www/a.php:0
PHP Notice: Undefined variable: a in /var/www/a.php on line 5
PHP Stack trace:
PHP 1. {main}() /var/www/a.php:0
Xdebug's basic functions include the display of stack traces on error conditions, maximum nesting level protection and time tracking.
There are many ways to install xdebug. Now I give one way to use yum for xdebug installment.
sudo yum install php-xdebug
or with enable remi repo
sudo yum --enablerepo=remi install php-xdebug
------------------------------------------------------example---------------------------------------------------------------
now let us test one example for xdebug
vi test.php
<?php
echo $a;
$a++;
echo $a;
?>
>> php test.php
PHP Notice: Undefined variable: a in /var/www/a.php on line 3
PHP Stack trace:
PHP 1. {main}() /var/www/a.php:0
PHP Notice: Undefined variable: a in /var/www/a.php on line 5
PHP Stack trace:
PHP 1. {main}() /var/www/a.php:0
7/05/2013
PHP5.4+MySQL5.5+HTTPD+CentOS6.4
0. Download and install VirtualBox 4.2.6
https://www.virtualbox.org/wiki/Downloads
http://ftp.jaist.ac.jp/pub/Linux/CentOS/
2. Install + configure Network
3. Update yum
yum update
yum install gcc kernel-devel kernel-headers
Restart your centos system
4. Install Virtual LinuxAddtions
If you meet error with[Building the OpenGL support module [FAILED]] , please use the following command
export MAKE='/usr/bin/gmake -i'
./VBoxLinuxAdditions.run
if you still have errors, please try
/etc/init.d/vboxadd setup
5. Start your httpd
service httpd start
#auto start
chkconfig httpd on
6. install repos for php-5.4
rpm -Uvh http://rpms.famillecollet.com/enterprise/6.4/remi/x86_64/remi-release-6-2.el6.remi.noarch.rpm
rpm -Uvh http://ftp.riken.jp/Linux/fedora/epel/6/x86_64/epel-release-6-8.noarch.rpm
rpm -Uvh http://ftp.riken.jp/Linux/fedora/epel/6/x86_64/epel-release-6-8.noarch.rpm
#check yum repo for remi.repo epel.repo
ls /etc/yum.repos.d/
7. install php 5.4
yum --enablerepo=remi install php php-string
8. Install mysql 5.5
yum --enablerepo=remi install mysql mysql-server
#auto start when PC start
chkconfig mysqld on
5/29/2013
performance of array_map vs foreach loop
The following is one example for two ways:
$arrayOfNumbers = array();
for($i=1; $i<= 10000; ++$i) {
$arrayOfNumbers[] = rand(1, 99999);
}
$maxHeap = new
SplMaxHeap ();
#first way
# Avg Time: 0.92856907844543s
array_map(array($maxHeap, 'insert'), $arrayOfNumbers);
#second way
# Avg Time: 1.3148670101166
foreach($arrayOfNumbers as $number) {
$maxHeap->insert($number);
}
It is due to the difference between Callback functions and normal functions.
In the second one, iteration of array using foreach, each iteration calls "insert" function and wait for the execution (function return control) and proceed to next iteration.
But in the array_map function, "insert" happens as callback function, it calls "insert" and don't wait for the result and call insert with next item in the array. So it is faster.
http://www.myresearch.biz/download/IJITCC2012.pdf
5/20/2013
PHP header Redirect for 301 Redirect permanently vs 302 Redirect Temporarily
1. PHP Redirect Code (permanent redirects)
Code 1.
<?php
header("HTTP/1.1 301 Moved Permanently");
header("Location: http://www.researchbib.com");
?>
header("HTTP/1.1 302 Moved Temporarily");
header("Location: http://www.researchbib.com");
?>
Please be careful.
If you set A page with code 1 or code 2, it is different for google index result.
Code 1: Google will index http://www.researchbib.com and url is http://www.researchbib.com, which means google will throw away A url. The google will dispaly www.researchbib.com link when usr search this page.
Code 2: Goodle will inex the contents from http://www.researchbib.com and url is A. The google will dispaly A link when usr search this page.
2014 1st International Conference on Non Conventional Energy
Code 1.
<?php
header("HTTP/1.1 301 Moved Permanently");
header("Location: http://www.researchbib.com");
?>
2. it is not same with (temporarily redirects)
Code 2.
<?php
<?php
header("Location: http://www.researchbib.com");
?>
====
<?php
header("Location: http://www.researchbib.com");
?>
Please be careful.
If you set A page with code 1 or code 2, it is different for google index result.
Code 1: Google will index http://www.researchbib.com and url is http://www.researchbib.com, which means google will throw away A url. The google will dispaly www.researchbib.com link when usr search this page.
Code 2: Goodle will inex the contents from http://www.researchbib.com and url is A. The google will dispaly A link when usr search this page.
2014 1st International Conference on Non Conventional Energy
3/19/2013
揭秘谷歌招聘机制:冗长而挑剔的5轮面试
谷歌已经连续四年被《财富》杂志评选为最适合工作的公司,但要获得这份“最适合工作”的工作却并非易事。先来看看以下题目:
1、你被缩小到一枚硬币大小,扔进搅拌机。你的质量减少,密度不变。搅拌机片60秒内就会开始搅拌。你会怎么办?
2、有6个数字:10,9,60,90,70,66,接下来该出现什么数字?
3、请代拟一份合同,内容是“把谷歌联合创始人谢尔盖·布林的灵魂卖给魔鬼”,合同必须在30分钟内发到布林的邮箱。
4、刽子手让100名囚犯排成一列,并让每名囚犯戴上一顶红色或蓝色的帽子。每名囚犯都可以看到自己前面人头上戴的帽子,但它看不见自己的,也看不见身后其他人的。刽子手从队列最末尾的地方开始,询问最后一名囚犯他所戴帽子的颜色。他只能回答“红”或“蓝”。如果回答正确,他就能活下来。如果他给了错误的答案,那就立刻被无声无息地杀掉。(人人都听得到身后人的回答,但没人知道答案是对是错。)列队行刑的前一天晚上,囚犯们要琢磨出一套能够自救的策略来。他们应该怎么做?
这些看似无厘头的题目就是为想进入谷歌的面试者准备的,而这也仅仅是冗长面试中的一个环节而已。
《谁是谷歌想要的人才?》一书揭开谷歌招聘机制的一角,我们得以一窥这个庞大的互联网巨头是如何挑选它的“船员”。
以下节选自《谁是谷歌想要的人才?》一书第4章
2004年,亚马逊招聘经理史蒂夫·耶奇(Steve Yegge)在一篇广为流传、阅读者众多的博客帖子里写道:
大家都知道谷歌很擅长招聘聪明人。它绝非传说,数字自己会说话。我们很多最优秀的人选都流失到了他们那儿……我想,谷歌的技术招聘做得太好了,它和其他公司已经不是量的不同,而是质的飞跃了。他们现在做的事,恐怕也很难单纯称之为“招聘”。“招聘”这个词,意味着走出去找人,努力说服他们过来为你工作。但谷歌颠覆了这个过程。如今,聪明的人竞相到谷歌去朝圣,谷歌甚至要用大量时间来拒绝这些了不起的人才。
这些了不起的人才要寻找什么呢?并不是钱,尽管谷歌的员工有不少百万富翁。到2008年,谷歌最初入职的前30名员工,得到了价值5亿美元的股票。是的,每人5亿!
谷歌带给员工的东西,更像精英大学或者智囊团。但大学强调理论,而谷歌却满是各种活生生的实践。它提供了令人兴奋的挑战:创造全新的数字宇宙。按耶奇的分析:“聪明人喜欢去聪明人扎堆儿的地方,他们拿出很酷的东西,吸引更多的关注。突然之间,反馈循环就出现了。”
寻找天生爱好合作的聪明人
谷歌把人力资源称为“人力运营”(People Operations)。长发披肩的年轻工业心理学家托德·卡莱尔,2004年就开始为谷歌的人力运营部门工作。他解释说:“他们有大量数据,而且,不给任何人查看、分析,更别说阐释数据的含义了。”
卡莱尔的工作是进行统计分析,确定招聘中哪些因素会产生重要作用。他说:“谷歌的创始人都是工程师,他们习惯了在大量的噪声中锁定信号。”不过,当事情关系到人类,统计方法就遇到了很大的阻力。“这就像是电脑告诉你,你该跟这个人结婚。面试的时候,人人都觉得自己知道要找什么样的人。我问他们:‘你要找的是哪些东西?’几乎每个人的回答都不一样。所以我认为,‘总不可能人人都说得对吧。’”
卡莱尔在谷歌考察了履历数据。他说:“我开始钻研的事情,类似‘你是什么时候拥有自己第一台电脑的?’”卡莱尔发现,按季度绩效总结和其他标准来看,求职者接触电脑的时间越早,在谷歌的工作绩效越好。另一个预测性提问,类似前文中丘尔顿那个和飞机模型有关的问题:“你自己组装过电脑吗?”和做飞机模型一样,自己组装电脑显得有些极客味。但曾这么做的人,一般对电脑都有终身的激情。要在一个人人都为数字玩意儿着迷的紧张环境里生存下来,有激情是个好兆头。
2006年,卡莱尔设计了“谷歌求职者调查”测试(Google Candidate Survey)。这是谷歌自制的个性测试,旨在衡量潜在应聘者的文化吻合度,即“谷歌范儿”。一开始,公司要每名员工每隔5个月就填写一份足有300道问题的问卷调查。填好后,会跟他们在谷歌的绩效统计情况进行对比。不出卡莱尔所料,很多东西对绩效都没有什么影响,但有几件事却很关键。于是,公司一步步完善并打磨了这套问卷,到2007年,每一名求职者都要完成该问卷。
谷歌人强调头脑和雄心,他们也相信,开放合作的环境并不符合人们对工程师“孤僻怪人”的刻板印象。谷歌总部就是个群居的场合。格子间当中只拦着低矮的墙板,没有人是真正离群的。局外人或许会发现,没有人有隐私。在公司成立之后的大部分时间,佩奇和布林都共用办公室。好玩的地方是,要是有哪个谷歌人临时需要些安静的空间,他们会躲到没有人的会议室去。
因此,受聘人员能够在感觉像是鱼缸的环境里蓬勃发展,是至关重要的。卡莱尔解释说:“我们喜欢合作性强的人,我们希望他们了解:他们开发的每一样东西,都是团队的结晶。你不能只顾着自己写好一段代码就完了,还必须跟其他人写的代码一起运行。”
要怎么才能找到外向型软件工程师呢?最简单的方法是问应聘者是否喜欢合作。但这会碰到履历数据的老大难问题:人们总会揣摩雇主的心思来说话。解决办法之一,是设计不管怎么瞎编也无关紧要的问题。在求职者调查问卷上曾这样问道:
请按1~5级表明你的工作风格偏好。
1=单独工作:只要在我的桌上摆一台私人特浓咖啡机外加一盒巧克力,我就可以卯足了劲儿开始干!
5=团队合作:每次总能听到十来种不同的声音,还有自我在碰撞……啊,嘴皮子上见功夫!
这个问题的措辞对谷歌想要的答案做了加权。它提醒求职者,团队可能生产效率低下,而把独自工作和高档咖啡、巧克力联系起来。用1-5级的评价体系,目的是提高回答者的坦承度。不会有太多人给出1或5的极端回答。人人都明白,中间的答案更“安全”。不过,独行侠类工程师往往会选2或3,群居类工程师一般则选3或4。人格类型之间存在明显的统计性差异,尽管也有不少差异掩盖了真相。
卡莱尔说:“我还测试过一件事,如果赢过编程大赛,到谷歌工作的表现会怎么样?我已经检验了好几种赛事。”谷歌为最著名的一项编程赛事提供了赞助,即“谷歌编程挑战赛”(Google Code Jam)。渴望到谷歌工作的程序员大有人在。“但事实上,我发现,参加过编程大赛的程序员真正到了谷歌之后,干得还不如从未参加过此类比赛的人出色。”
为什么竞争力在全世界数一数二的程序员来到谷歌后,反而干得并不是特别棒呢?统计数据无法解答这个疑问。显然,这有点像寻找美女的模特经纪公司。选美比赛的冠军不一定总能变成最优秀的模特。卡莱尔认为,编程竞赛的本质——一个人对抗整个世界,从头到尾独立完成一个定义清晰严密的项目,跟谷歌的合作工作环境不怎么相关。参加比赛的人或许想要在很短的时限内战胜对手,可到了谷歌,他们恐怕会感到很无聊。
现在,谷歌基本上已经淘汰了“求职者调查”问卷,因为它发现,几乎没有任何因素总能准确预测候选人在公司的事业发展状况。适合广告销售人员的题目,并不适合软件工程师和公关职员,但某些部门有时仍会在面试里抽选“求职者调查”问卷里的题目。此外,调查工作风格和个性的问题保留了下来。谷歌,仍然极为擅长寻找天生爱好合作的聪明人。
人人都有“卷宗”
在大多数公司,有关求职者的信息都放得零零散散。雇主总是高估他们最初碰到的少量数据,此后,却往往会忽视与最初印象不吻合的信息。这是一个典型的决策谬误。为了避免这种情况,谷歌认为,要把求职者的所有相关信息都收集完备,再呈交给决策者。出于这个原因,它的招聘流程高度集中化。孟买或弗罗茨瓦夫办事处,会把有意延揽的候选人信息直接传回山景城总部,总部会派人与国外求职者进行远程视频面试。
最能体现这一理念的做法是“卷宗”(package)。谷歌人力分析和薪资部主管普拉萨德? 赛迪(Prasad Setty)解释说,谷歌的每名求职者都有四五十页的卷宗。卷宗里包含了谷歌所能收集到的有关申请人的所有信息,不管是从字面上看,还是从隐喻意义上看,谷歌总能有效“用谷歌搜索”人。卷宗里一般会有求职者的高考分数(SAT )和排名;简历;工作样品(发表的论文、媒体文章,甚至交货的产品);推荐书;网络信息,如博客文章,甚至社交网络上的帖子。
卷宗衍生出了有关谷歌招聘标准的各种传说。据说,除非符合如下标准,否则,谷歌绝不会聘你:
● 成绩平均分(GPA )在3.7 以上,非技术岗位3.0;
● 读过斯坦福大学、加州理工学院、麻省理工学院或常春藤盟校;
● 高考三门成绩(SAT)①都得了满分800 分;
● 拥有博士头衔。
其实这些都不是必选标准,但你必须跟符合上述大部分甚至全部要求的申请人同台竞技。
一个从前在谷歌工作过的职员回忆说:“谷歌是我大学毕业后的第一份工作。我毕业于一所名校的英语专业,应聘进了人事部。就是从这个时候开始对谷歌有点纠结的——真的有必要找常春藤盟校的毕业生来处理例行文书工作吗?我的工作内容包括阅读人事研究文献,处理员工交来的带薪休假状态变更申请表。”
谷歌对学校和分数的重视激怒了很多求职者。《纽约客》记者肯? 奥莱塔(Ken Auletta )称之为“荒唐”。取得医疗信息学高等学历的罗尼? 齐格勒(Roni Zeigler)博士还记得,谷歌在筛选时竟然要求他提供高中成绩,让他大吃一惊。(他被录用了。)技术博客的博主们说,如果求职者的简历上没有常青藤盟校的身影,谷歌根本不看。
谷歌的招聘员坚称,这些全是误解。由于谷歌要求看成绩,其他一些公司却不然,因此,外面的人就得出结论说,谷歌对成绩有一种过于天真的信仰。事实上,谷歌的目标是给成绩应有的权重,不多也不少。
2007年,人力运营部主管拉兹洛? 博克夸口道:“上个星期,我们聘用了6名GPA低于3.0的员工。”卡莱尔,在非常春藤盟校得克萨斯州A&M大学拿到博士学位,他说,谷歌把在常春藤盟校就读的背景视为一个信号。
有人帮我们做了筛选,但我们也并不因此排斥其他人。我们经常观察那些克服了某种逆境达到现状的人。你是整个家族第一个上大学的人吗?前些日子,我曾招聘过一个人,她不仅是家族里第一个上大学的,而且,大学期间还全职工作,好让妹妹也能上大学。我们要定了这个人,她读的学校,跟常春藤盟校的档次差得远呢。
或许这么说更准确,谷歌就像是一所评估申请人的常春藤盟校,它的政策可以说成:对超级聪明人采取积极行动。
拉里·佩奇曾说:“我们真的会主动出击,招聘略有不同的人。”因此,卡莱尔认为,自己的任务就是“寻找我们通常会忽视的人。比如,印度农村有些孩子,12岁就能修好所有的电话线,因为那儿没有别的人能做这件事,而他却有这方面的技术才能。底特律城区有些姑娘也拥有这种技术天分,我们怎么才能在她们年纪还小的时候就找到她们,并确保她们以后来这儿工作呢?”
据说,如今谷歌的女性员工比例接近50%。在一个始终对女科学家、女工程师有着浓厚误解的社会,这一点让人印象深刻。谷歌在全球范围内进行招聘,大量外国人来到山景城,让谷歌总部显得就像是国际大都会一般。
冗长而挑剔的5轮面试
和其他高科技公司一样,谷歌的招聘面试由同侪进行。人力运营部员工会对面试官提供方方面面的建议,如公平就业法,以及“拒绝的艺术”。卡莱尔说:“其实,他们要完成培训课程,了解如何温柔地拒绝候选求职者。”谷歌面试最重要的环节是工作抽样,工程师要编写程序代码,公关员则要写出新闻稿。
相较于其他因素,谷歌费了很多工夫来权衡面试的权重。而另一个重要问题是,特定候选人要安排多少轮面试。越多越好,但要有个限度。卡莱尔说:“我们不想浪费别人的时间。”他的统计分析发现,5轮面试效果最好,再多,收益就递减了。
2003年,公司执行委员会(Corporate Executive Board)做了一次范围更加广泛的类似研究,询问全美国范围内28000名新晋员工,他们面试了多少轮才得到工作,并将答案与后续的绩效评估进行对比。结果与卡莱尔的非常类似:最优秀的员工,一般是经过四轮或五轮面试后招聘的。
面试过5轮以上的员工,大多是因为传递了混乱信号。有些面试进展顺利,有些却不然,公司只好再安排更多的面试来解决这些冲突。调查结果暗示,这些疑虑有其道理。公司执行委员会所得结果还有另一种解释:最优秀的人才厌倦了太多的面试,大喝一声:“我受够了!”坚持要面试8-10轮的公司,往往只找到些蹩脚的货色。
谷歌的候选人会在同一天内连续接受5轮现场面试,每一次都由不同的面试官主持。其中一轮是午餐面试,本来经历了棘手的提问后,候选人理应享受美食的宽慰。面试官会给候选人以下4档“分数”。卡莱尔说,这4档分别是:“我认为我们不应该聘用这位候选人”;“我认为我们不应该聘用他,但如果其他人另有看法,我也愿意接受”;“我认为我们应该聘用他,但如果其他人另有看法,我也愿意接受”;“强烈主张聘用他。”
谷歌的面试官并不直接做出聘用决定。他们的任务是展开出色、强硬的面试,并报告结果。报告中要解释问了什么问题,得到了怎样的回答,面试官对答案有怎样的看法。每名评审可以独立形成个人意见,但“集体智慧”的效果最好——这是谷歌招聘的一条原则。因为意见的平均值,很可能接近真实情况。谷歌要求,在提交各自的报告之前,面试官之间不能讨论候选人。
碰到明显不合适的候选人时,为避免浪费所有人的时间,传纸条也行。谷歌会让面试官直接跟候选人的招聘官进行简要报告,招聘官有权终止面试,当然,这种情况很少见。
面试官的报告会收入候选人的卷宗,分发给招聘委员会。如果该委员会批准聘用候选人,会有另一个委员会来审核卷宗,接着还有另一个。最后,所有招聘决策都要提交给拉里? 佩奇批准。谷歌的招聘流程,比算法还要繁复多样。
这恐怕完全出乎大多数人的预料。赛迪说:“归根结底,我们这么做是想让招聘流程尽量公平,尽可能消除偏见。”谷歌很重视“偏见”问题,这里,它不光是指种族或性别偏见,也指的是更广义上的决策怪癖。举例来说,有的面试官或许习惯性地认为,“聘用斯坦福大学的博士准没错”。如果他在这个因素上放的权重太大,那么这个想法就属于偏见。如果雇主坚持学历和学校没有关系,并对之完全不做考虑,这同样是一种偏见。谷歌的目标,是给予一切因素最佳权重。也许,这是一个遥不可及的目标,但它指导着谷歌人力运营部员工的思想。
面试官所分配到的候选人,是根据不同的背景、个性、性别、年龄和种族挑选出来的。这种做法,承认了人在本性上更容易与来自相同学校、有着相同生活经历、有着相同服装或说话风格的人结交。
赛迪说:“我们并不想完全消除人的因素。”我们的目标是“理解这些模式到底是什么,怎样将它们呈交给决策人,而不是替他们做决策”。“在大多数公司,如果你是经理,需要人手,就直接到财务部去问,‘我有招聘人手的预算吗?’如果对方做出肯定的答复,你就安心了,你有自己的一套系统,你跟你认识的人聊了聊,出去找到人就招进来。但我们这里完全相反,我们说,‘你不能拿主意,因为我们认为,人人都有偏见,我们不相信单个人能做出正确的决定。’所以,我们就确立了这套看似非常复杂又耗时的过程。但我们的最终目的,是为了减少‘假阳性误报’(false positives)。”
谷歌会主动出击,招聘略有不同的人。他们相信,人人都有偏见,要学会给予一切因素最佳权重。
警惕“假阳性误报”和“假阴性漏报”
假阳性指的是,候选人通过了审批流程并得到聘请,结果却是个差劲的员工。与此相反的是假阴性(false negative),即本来会是优秀员工的候选人被拒绝了。误报和漏报似乎同样糟糕。不过,不管是在谷歌,还是在其他任何地方,它们并不是一个意思。
求职者担心假阴性漏报,因为它们意味着好人碰上了坏事——强硬的面试官或者乱来的问题妨碍了你得到本可以有出色表现的工作。从申请人的角度来看,这是极度不公平的。但对用人单位来说,假阴性漏报没有什么大不了的。赛迪承认:“我们不知道在筛选过程中,我们的系统有没有漏报。之所以不知道,是因为我们没有聘用他们。”
反过来说,聘人不当,却是人人都看得见的。减少误报是人力运营部的核心指令,“从组织成立之日起,就是佩奇、布林和埃里克的信念”。赛迪说,这就是为什么谷歌的招聘流程会冗长得令人抓狂。
这不只是谷歌的事情。南加州大学高效组织中心(California’s Center for Effective Organizations )的亚力克·利文森(Alec Levenson)说:“在上升的市场,比如20世纪90年代末,做出糟糕聘用决策的代价不大,公司可以漫不经心地对待招聘,因为要是员工不合适,他很快就会跳槽走掉。”
但现在可不是这样了。员工像贴在石头上的苔藓一样,死守着自己的岗位。越是表现不佳的员工,附着力越强。摆脱可疑聘入员工的唯一办法就是解雇他,可这是一个令人心焦的流程。利文森解释说:“随着越来越多的人受到就业保障法的保护,过去30年随心所欲招聘的做法越来越行不通了。越来越多的公司,在招聘和解雇上畏首畏尾。哪怕在100个有资格起诉的人里,只有一两个人真的上了法庭,都让公司难以承受。”如今的聘用就像是过去的婚姻:要持久。尽管误报并不招人喜欢,但“就算你彻底搞砸了一轮面试,也并不意味着失去了机会”。谷歌意识到面试本身就是信号。
在一轮面试中表现糟糕,没什么大不了的。事实证明:得到了一名面试官强烈支持的候选人,表现好于从所有面试官那里得到及格分的候选人。因为他们就像是一部影片,能激发起少数人的热情,而不是一味取悦所有人。
用“奥巴马问题”,鼓励互动
谷歌不鼓励面试官提一些类似其他公司的传统谜题,比如“为什么下水井井盖是圆的”,面试官也不应该用以下琐碎问题来检测求职者的知识。如,解释“dead beef”的意思。他们最好也别用以下这类神秘的术语,让求职者犯迷糊。如,南非出现了延迟问题(latency problem)。试做诊断。
这些问题的缺点在于,它们的答案信息量不够丰富,太容易记住。但谷歌的工程师,也和其他地方的工程师一样,对人力运营部职员的话从来都只听一半,还是照样会问这种问题。以免你错过好机会,下水井井盖问题的答案是:“圆形的井盖不会掉进洞口,正方形的井盖却会掉下去。”
谷歌的一位前面试官说:“你应该问开放式问题,测试问题解决能力和一般性知识,然后再深入细节。”谷歌最有特色、最多人效仿的面试题,都是能激发对话的简短问题。
2008年1月26日,参议员兼总统候选人巴拉克? 奥巴马,努力为自己塑造支持新经济的形象。他访问了谷歌总部,并当众和埃里克? 施密特谈了话。埃里克评论说,获得总统这份工作很难,获得谷歌的工作也很难。为检验奥巴马的资格,埃里克问:“为100万个32位整数排序,最有效的办法是什么?”
奥巴马的答复是:“总之,冒泡排序(bubble sort)是错的。”
这当然是个预先编好剧本的笑料,它引来一阵大笑。你可以到YouTube去看这段视频。
谷歌会向应聘软件工程师的求职者严肃地提出“奥巴马问题”。这类人都知道,冒泡排序慢得可怕,所以奥巴马所说的笑话才好笑。用冒泡排序法对100万个数排序,就跟用一根针管灌满游泳池差不多。
这个问题的最佳答案或许可以如此开头:“一切要看情况。”它取决于整数的构成,以及时间和内存的限制。求职者应该料到会问这些东西。这个问题的目的是,让求职者谈一谈各种算法的相对优点,如何着手选择最适合工作的工具。或许这是最难传授,也最难学习的地方。
赛迪解释说:“一般而言,我们并不会为了填补一个具体的工作岗位而招聘。谷歌一直在蜕变和成长,我们发现,人们可能会因为特定的任务而加入进来,但5年之后,却做着完全相反的事情。不能只为了具体的工作招人,要为整个谷歌招人。”
问一些不依赖特定技能的问题是有益的。谷歌常用更宽泛、更好玩的问题(比如“扔进搅拌机”那个),鼓励候选人和面试官互动,设计出条理分明的解决方案。
谷歌的面试官有点像是优秀的记者,他们会不停跟进问题,排除候选人拿手的套路。他们的核心主题是:你可以深入改进这个答案吗?
在社交网络上搜索有趣的“猛料”
谷歌所从事的大部分项目,正在重新定义隐私的概念。它成了都市传奇里的组成部分。你听说过把出轨的丈夫逮个正着的故事吗?她从谷歌地图的“街景”模式里发现,丈夫的越野车停在情妇的门口,于是马上用谷歌搜索找到了一位优秀的离婚律师。2009 年,一份英国小报对此进行了报道,自那以后它就穿帮了。另一个离奇的传说是,谷歌会根据候选人电脑上的IP 地址,检查其搜索的历史记录。它会告诉谷歌你最近访问了哪些公司的招聘网站,呃,当然还有其他许多有趣的“猛料”。
虽说这只是一个谣言,但谷歌以及全世界的其他公司,都正为社交网络站点在招聘中所扮演的角色而纠结。雇主做招聘决定时,使用Facebook、YouTube 或Twitter上的信息合法吗?这是一桩有趣的伦理难题,但老实说,这是一艘出得了远航的好船。
2007年,LinkedIn创始人里德? 霍夫曼(Reid Hoffman )着手为公司寻找新的CEO。他对筛选高管采用传统引荐的方式有些怀疑。霍夫曼观察后发现:“有人给你推荐了两三个候选人,再替他们说说好话,这不是顺水推舟的事嘛。”于是,他利用LinkedIn网络,整理了一份名单,上面的23个人全是头号候选人的业务关系人。只不过,候选人并没有把他们作为自己的引荐者。霍夫曼删掉了一些两度分隔的名字,并和这些“额外引荐人”做了接触。因为在这件事上没有直接的利害关系,后者的评判更加坦率。霍夫曼说:“我们的做法带了一点侦探的性质,需要拼凑出完整的故事来,但很快就能觉察一个人究竟是好还是坏。”
2007年的前卫做法,现在已成为主流。CareerBuilder网站做了一次调查,发现雇主通过社交网络核查候选人的比例,从2008年的22%飙升到了2009年的45%。不出意料的话,当你读到这段文字时,这个数字会变得更高。
谷歌的托德? 卡莱尔说:“人们乐意在Facebook和LinkedIn上告诉你各种自己的事。”以谷歌的企业文化来看,对潜在员工的信息视而不见是罪过。“我们要平衡的是,他们并没有把这些信息发给谷歌,也不曾向我们提出求职申请。我希望我们在此事上保持谨慎态度。”
然而,不是所有人都这么谨慎。2009年,有人对2667名经理和人力资源职员做了调查,35%的受访者表示,基于他们从Facebook、Myspace或其他网站上所得的信息,他们曾拒绝过求职者。根据雇主的说法,最大的红灯是“挑衅、不雅的照片或信息”,占53%,以及“跟……酗酒和使用毒品有关的内容”,占43%。换言之:都是你在Facebook上有可能看到的东西。
申请人同样也会用谷歌搜索自己的面试官。在既是求职者也做过面试官的拉克什? 阿格拉沃尔说:“我总会试着提前拿到面试官的名单,然后用谷歌搜索,看看他们有没有Twitter 或者博客。任何人投入了额外的努力,总该得到一些额外的分数。”到了他做面试官时,阿格拉沃尔会根据从网上了解到的信息提出问题。“这里的窍门是光明正大,别做得过了头。你并不是要跟踪这个人,一张张翻看他们上传到Flickr 的照片,找出他们十多年前的模糊身影。”
卡莱尔说,除了隐私考虑,申请人还有可能用社交网络作弊。要是候选人相信潜在雇主会暗自偷看他的Facebook页面,他或许会在上面添加些假的成就,或是让朋友帮忙这么做。在简历上动手脚,是不可饶恕的罪过,雇主可以毫不考虑地拒绝。但在社交页面上作假,却是个愿者上钩的游戏。
到目前为止,互相曝光尚是缺失环节。雇主必须承认,他们正在社交网站上搜索观察,而求职者则必须为这些网站上与职业生涯相关的信息担保。
随着网络上个人信息量的成倍增长,卡莱尔说:“挖出与某人相关的所有信息越来越难了。所以,在我看来,要是能以一种简单的方式,把求职者放在LinkedIn、Facebook、YouTube视频和求职申请里的内容整合到一起,一定极具吸引力。”眼下这还是个白日梦,但梦想成真的日子恐怕很快就会到来。
在此期间,求职者最好还是遵照标准建议。在求职之前,把社交网络页面设置为“私人/不公开”,或者把它们整理干净。CareerBuilder 网站的一项调查结果,令人头脑为之惊醒。
“糟糕的沟通技巧”是个很重要的拦路虎。29%的受访雇主认为,它是求职者被拒绝的主要原因,包括各种言语上的过失和冒犯。16%的受访者会因为求职者在电子邮件中使用“短信式语言”而拒绝考虑此人。如“GR8”,“great ”的非正式缩写,有点类似中文世界里的“脑残体”。如果用在商务信件往来中,是非常不正式、不得体的。
有人评论道:“因为某人在Facebook上沟通技巧糟糕就不雇用他,其实有点傻。这就好像是在说,我不想雇用你,因为你上个星期在餐馆用糟糕的语法讲了个笑话,而我正好在你背后的亭子间里窥视你。”
说得很好!但不管怎么说,还是先注意一下拼写和语法吧。
本文部分来自湛庐文化《谁是谷歌想要的人才?》(Are You Smart Enough to Work at Google?),作者威廉·庞德斯通(William Poundstone),闾佳翻译,浙江人民出版社出版。
3/06/2013
URL shortening algorithm (php source code) mysql
URL shortening is a technique on the World Wide Web in which a Uniform Resource Locator (URL) may be made substantially shorter in length and still direct to the required page. This is achieved by using an HTTP Redirect on a domain name that is short, which links to the web page that has a long URL.
Now I give one source code based on PHP. This class may
1. produce one random string based on the input asscii
2. encode id to one short string.
3. decode one short string to id
4. add checker for short string, e.g. abcd, ab is checker, cd is real short url.
5. use database to store id and url, e.g. mysql sqlite, etc,
6. use file to store id and url,
7. not need to save the short url, the algorithm auto-reverse the short url to id
Download the source from
https://code.google.com/p/shortening-url/
Now suppose you have some place to store id and url, e.g in table
- id, url
Where id is an sequence and the url is indexed. This way each url is unique.
Now you may use
shortURL = f(id);
id = f(shortURL)
Finally, you just change the .htaccess file on your server. That is all. Now you may create one short url service for you or your client freely.
#####################Example##########################:
$string = rand(0, 10000);
echo "ID: " . $string . PHP_EOL;
$test = new XCube_BijectionCode();
$string = $test->BijectionEncode($string);
echo "Short String: " . $string . PHP_EOL;
$string = $test->BijectionDecode($string);
echo "Reverse Short String to ID: " . $string . PHP_EOL;
######################################################
###############URL Shortening Class######################
/* ------------------------------------------------------------------------------
* * File: XCube_BijectionCode.class.php
* * Class: Short URL encode and decode
* * Description: This class may create short url based on alphabet or other asscii
* * Version: 1.0
* * Updated: 5-March-2013
* * Author: Zhao Sam
* * Homepage: http://www.researchbib.com
* *------------------------------------------------------------------------------
* * COPYRIGHT (c) 2012 - 2013 BENNETT STONE
* *
* * The source code included in this package is free software; you can
* * redistribute it and/or modify it under the terms of the GNU General Public
* * License as published by the Free Software Foundation. This license can be
* * read at:
* *
* * http://www.opensource.org/licenses/gpl-license.php
* *
* * This program is distributed in the hope that it will be useful, but WITHOUT
* * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
* * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
* *------------------------------------------------------------------------------ */
class XCube_BijectionCode {
var $mChecker = array(50, 51,);
//abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789
var $mAlphabet = 'OetMl3cbTrwzEis7RXH5gKUkNqafdSFIQ0jDWYhuLyP2JGvZ9p6m1AV4oB8nxC';
var $mBase = 0;
var $mLength = 0;
function __construct($mLength = 0) {
$this->mAlphabet = str_split($this->mAlphabet);
$this->mBase = count($this->mAlphabet);
$this->mLength = $mLength;
}
/**
* cryptAlphabet may produce a random Alphabet string.
*
* @param int $loop
* @return string
*/
function cryptAlphabet($loop = 60) {
$mAlphabet = $this->mAlphabet;
for ($i = 0; $i < $loop; $i++) {
$mNewAlpha = array();
do {
$i = rand(0, $this->mBase) % $this->mBase;
if (!in_array($mAlphabet[$i], $mNewAlpha)) {
$mNewAlpha[] = $mAlphabet[$i];
}
if (count($mNewAlpha) == $this->mBase)
break;
} while (TRUE);
$mAlphabet = $mNewAlpha;
}
return implode('', $mAlphabet);
}
/**
* BijectionEncode may produce one short string based on the input id.
* It is not necessarty to store the short string into DB.
* It can reverse it into id when the clients access.
*
* If you want to add checker on short url, please set mChecker=TRUE.
* The checker length is based on the $this->mChecker length.
*
* @param int $id
* @param bool $mChecker
* @return string
*/
function BijectionEncode($id = 0, $mChecker = TRUE) {
$mShortURL = '';
$id = (int) $id; // to interger
if ($id > 0) {
if ($mChecker) {
$mChecker = '';
foreach ($this->mChecker as $value) {
$mChecker .=$this->mAlphabet[$id % $value];
}
} else {
$mChecker = '';
}
while ($id > 0) {
$mShortURL = $this->mAlphabet[$id % $this->mBase] . $mShortURL;
$id = (int) ($id / $this->mBase);
}
$mShortURL = $mChecker . $mShortURL;
}
return $mShortURL;
}
/**
*
* @param string $mShortURL
* @param bool $mChecker
* @return mixed
*/
function BijectionDecode($mShortURL = '', $mChecker = TRUE) {
if ($mChecker) {
$mChekcerLength = count($this->mChecker);
} else {
$mChekcerLength = 0;
}
if (strlen($mShortURL) <= $mChekcerLength) {
return FALSE;
}
$id = 0;
if ($mChekcerLength) {
$mChecker = substr($mShortURL, 0, $mChekcerLength);
} else {
$mChecker = FALSE;
}
//string to integer
foreach (str_split(substr($mShortURL, $mChekcerLength)) as $value) {
$id = $id * $this->mBase + array_search($value, $this->mAlphabet);
}
if ($mChecker) {
$mNewChecker = '';
foreach ($this->mChecker as $value) {
$mNewChecker .=$this->mAlphabet[$id % $value];
}
//wrong URL
if ($mNewChecker !== $mChecker) {
$id = FALSE;
}
}
return $id;
}
}
###################################################################
######################htaccess###################################
RewriteEngine on
RewriteRule ^([a-zA-Z0-9]+)[/]*$ index.php?url=$1
3/04/2013
Copy text into text box via Javascript when button clicked
it is very convenient for user to copy text from a text box via javascript when click mouse. But now this function is just supported by IE, not by Firfox, Chrome.
Now I give the example for you to support the click and select, copy to clippad.
javascript code
function select_all(obj)
{
obj.focus();
obj.select();
var r = obj.createTextRange();
r.execCommand("Copy");
}
html code
<input onclick="select_all(this);" size="50" type="text" value="text value" />
Now I give the example for you to support the click and select, copy to clippad.
javascript code
function select_all(obj)
{
obj.focus();
obj.select();
var r = obj.createTextRange();
r.execCommand("Copy");
}
html code
<input onclick="select_all(this);" size="50" type="text" value="text value" />
2/26/2013
Hide php version and apache version
Most of hacker may find the bug based on apache version and hack the server.
So you had better hide the apache version.
By default, the apache will send apache version to client in every http header.
Another, the php will send the php version to client.
Now I give the way how to hide the apache version and php version
1. Hide apache version
ServerTokens controls whether Server response header field, which is sent back to clients, includes a descriptions of the generic OS-type of the server.
open httpd.conf and change
ServerSignature On => ServerSignature Off
ServerTokens os=>ProductOnly
2. Hide php version
expose_php = On =>expose_php = Off
2/22/2013
MySQL index performance and example
The aims for index in MySQL is to find row quickly. For example, there is a table like
CREATE TABLE test (
id INT NOT NULL,
last_name CHAR(30) NOT NULL,
first_name CHAR(30) NOT NULL,
PRIMARY KEY (id),
);
If we execute
select * from test where last_name = 'Obama';
the MySQL will check all records in table test. It will be the O(n) questions.
If we use index for this table, it is not necessary to check each row from 0 to n. How to improve the performance to search one or more special rows in table?
For example, when we want to find a keyword in a book, we find it in the index list and then get the page no from it. We can find it quickly based on the book index. MySQL may also use this method to get it by index.
Now we use command
alter table test add index(last_name);
We have added one index on table test for last_name. if we execute
select * from test where last_name = 'Obama';
MySQL will find it from its index files, not from record 1 to last one. Of course, we should use more disk space to store the index files.
There are three ways to create index
Index for one column
alter table test add index(last_name);
Parts index for one column
alter table test add index(last_name(4));
it will save space.
Index for multiple columns
alter table test add index(last_name, first_name);
In fact, the MySQL will one execute one index for last_name or first_name. MySQL will determine which one is used dynamically. E.g. If first_name is less, first_name will be used.
invalid command
SELECT * FROM test WHERE first_name='Michael';
SELECT * FROM test WHERE last_name='Widenius' OR first_name='Michael';
valid command
SELECT * FROM test WHERE last_name='Widenius';
SELECT * FROM test WHERE last_name='Widenius' AND first_name='Michael';
SELECT * FROM test WHERE last_name='Widenius' AND (first_name='Michael' OR first_name='Monty');
SELECT * FROM test WHERE last_name='Widenius' AND first_name >='M' AND first_name < 'N';
Unique Index for one column
alter table test add unique (last_name);
It will check the unique attribute before insert a new record
Data structure
Index will use B-Tree to create a index file.
Get all index columns
show indexes from test;
When will you should use index
1. find a fixed string, e.g. where last_name='obama';
2. join two table, e.g. on table_a.last_name =b_table.last_name
3. find a range e.g. where id > 100
4. Min(), Max()
5. order by , group by
CREATE TABLE test (
id INT NOT NULL,
last_name CHAR(30) NOT NULL,
first_name CHAR(30) NOT NULL,
PRIMARY KEY (id),
);
If we execute
select * from test where last_name = 'Obama';
the MySQL will check all records in table test. It will be the O(n) questions.
If we use index for this table, it is not necessary to check each row from 0 to n. How to improve the performance to search one or more special rows in table?
For example, when we want to find a keyword in a book, we find it in the index list and then get the page no from it. We can find it quickly based on the book index. MySQL may also use this method to get it by index.
Now we use command
alter table test add index(last_name);
We have added one index on table test for last_name. if we execute
select * from test where last_name = 'Obama';
MySQL will find it from its index files, not from record 1 to last one. Of course, we should use more disk space to store the index files.
There are three ways to create index
Index for one column
alter table test add index(last_name);
Parts index for one column
alter table test add index(last_name(4));
it will save space.
Index for multiple columns
alter table test add index(last_name, first_name);
In fact, the MySQL will one execute one index for last_name or first_name. MySQL will determine which one is used dynamically. E.g. If first_name is less, first_name will be used.
invalid command
SELECT * FROM test WHERE first_name='Michael';
SELECT * FROM test WHERE last_name='Widenius' OR first_name='Michael';
valid command
SELECT * FROM test WHERE last_name='Widenius';
SELECT * FROM test WHERE last_name='Widenius' AND first_name='Michael';
SELECT * FROM test WHERE last_name='Widenius' AND (first_name='Michael' OR first_name='Monty');
SELECT * FROM test WHERE last_name='Widenius' AND first_name >='M' AND first_name < 'N';
Unique Index for one column
alter table test add unique (last_name);
It will check the unique attribute before insert a new record
Data structure
Index will use B-Tree to create a index file.
Get all index columns
show indexes from test;
When will you should use index
1. find a fixed string, e.g. where last_name='obama';
2. join two table, e.g. on table_a.last_name =b_table.last_name
3. find a range e.g. where id > 100
4. Min(), Max()
5. order by , group by
2/13/2013
use select, show databases, show tables, external sql file of mysql by shell script utility
usually we use shell to backup, update the database. Now I give one example for you to use mysql based on shell script.
Four Shell Example for:
select
show databases;
show tables;
sql.sql file
Execute one select command
> ./bash.sh host user dbnam
-------------------------bash.sh-------------------------------------
#!/bin/sh
HOST=localhost
if [ $1 ]
then
HOST=$1
fi
user=root
if [ $2 ]
then
user=$2
fi
db=dbname
if [ $3 ]
then
db=$3
fi
mysql="$(which mysql)"
read -s -p "Please input the db pass: " pass
if [ $pass ]
then
DBS="$($mysql -h$HOST -u$user -p$pass -D$db -e 'select uid from dd0a05_users limit 0, 10')"
for db in $DBS
do
echo $db
done
else
echo 'No db pass'
fi
------------------------------end bash.sh-------------------------------------------
Execute 'show databases' command
> ./bash.sh host user dbnam
-------------------------bash.sh-------------------------------------
#!/bin/sh
HOST=localhost
if [ $1 ]
then
HOST=$1
fi
user=root
if [ $2 ]
then
user=$2
fi
db=dbname
if [ $3 ]
then
db=$3
fi
mysql="$(which mysql)"
read -s -p "Please input the db pass: " pass
if [ $pass ]
then
DBS="$($mysql -h$HOST -u$user -p$pass -e 'show databases')"
for db in $DBS
do
echo $db
done
else
echo 'No db pass'
fi
------------------------------end bash.sh-------------------------------------------
Execute 'show tables' command
> ./bash.sh host user dbnam
-------------------------bash.sh-------------------------------------
#!/bin/sh
HOST=localhost
if [ $1 ]
then
HOST=$1
fi
user=root
if [ $2 ]
then
user=$2
fi
db=dbname
if [ $3 ]
then
db=$3
fi
mysql="$(which mysql)"
read -s -p "Please input the db pass: " pass
if [ $pass ]
then
DBS="$($mysql -h$HOST -u$user -p$pass -D$db -e 'show tables')"
for db in $DBS
do
echo $db
done
else
echo 'No db pass'
fi
------------------------------end bash.sh-------------------------------------------
Execute external files 'sql.sql' command
> ./bash.sh host user dbnam
-------------------------bash.sh-------------------------------------
#!/bin/sh
HOST=localhost
if [ $1 ]
then
HOST=$1
fi
user=root
if [ $2 ]
then
user=$2
fi
db=dbname
if [ $3 ]
then
db=$3
fi
mysql="$(which mysql)"
read -s -p "Please input the db pass: " pass
if [ $pass ]
then
DBS="$($mysql -h$HOST -u$user -p$pass -D$db < sql.sql)"
for db in $DBS
do
echo $db
done
else
echo 'No db pass'
fi
------------------------------end bash.sh-------------------------------------------
Four Shell Example for:
select
show databases;
show tables;
sql.sql file
Execute one select command
> ./bash.sh host user dbnam
-------------------------bash.sh-------------------------------------
#!/bin/sh
HOST=localhost
if [ $1 ]
then
HOST=$1
fi
user=root
if [ $2 ]
then
user=$2
fi
db=dbname
if [ $3 ]
then
db=$3
fi
mysql="$(which mysql)"
read -s -p "Please input the db pass: " pass
if [ $pass ]
then
DBS="$($mysql -h$HOST -u$user -p$pass -D$db -e 'select uid from dd0a05_users limit 0, 10')"
for db in $DBS
do
echo $db
done
else
echo 'No db pass'
fi
------------------------------end bash.sh-------------------------------------------
Execute 'show databases' command
> ./bash.sh host user dbnam
-------------------------bash.sh-------------------------------------
#!/bin/sh
HOST=localhost
if [ $1 ]
then
HOST=$1
fi
user=root
if [ $2 ]
then
user=$2
fi
db=dbname
if [ $3 ]
then
db=$3
fi
mysql="$(which mysql)"
read -s -p "Please input the db pass: " pass
if [ $pass ]
then
DBS="$($mysql -h$HOST -u$user -p$pass -e 'show databases')"
for db in $DBS
do
echo $db
done
else
echo 'No db pass'
fi
------------------------------end bash.sh-------------------------------------------
Execute 'show tables' command
> ./bash.sh host user dbnam
-------------------------bash.sh-------------------------------------
#!/bin/sh
HOST=localhost
if [ $1 ]
then
HOST=$1
fi
user=root
if [ $2 ]
then
user=$2
fi
db=dbname
if [ $3 ]
then
db=$3
fi
mysql="$(which mysql)"
read -s -p "Please input the db pass: " pass
if [ $pass ]
then
DBS="$($mysql -h$HOST -u$user -p$pass -D$db -e 'show tables')"
for db in $DBS
do
echo $db
done
else
echo 'No db pass'
fi
------------------------------end bash.sh-------------------------------------------
Execute external files 'sql.sql' command
> ./bash.sh host user dbnam
-------------------------bash.sh-------------------------------------
#!/bin/sh
HOST=localhost
if [ $1 ]
then
HOST=$1
fi
user=root
if [ $2 ]
then
user=$2
fi
db=dbname
if [ $3 ]
then
db=$3
fi
mysql="$(which mysql)"
read -s -p "Please input the db pass: " pass
if [ $pass ]
then
DBS="$($mysql -h$HOST -u$user -p$pass -D$db < sql.sql)"
for db in $DBS
do
echo $db
done
else
echo 'No db pass'
fi
------------------------------end bash.sh-------------------------------------------
What is difference PHP date vs gmdate
When we use date and gmdate, they may get different date based on your time zone. For example,
php code:
echo date_default_timezone_get ().PHP_EOL;
echo 'Result with date("M d Y H:i:s"):'.PHP_EOL;
echo date("M d Y H:i:s").PHP_EOL;
echo 'Result with gmdate("M d Y H:i:s"):'.PHP_EOL;
echo gmdate("M d Y H:i:s").PHP_EOL;
Result:
Asia/Tokyo
Result with date("M d Y H:i:s"):
Feb 13 2013 09:00:05
Result with gmdate("M d Y H:i:s"):
Feb 13 2013 00:00:05
Reason:
1. date is that the time returned is your time zone. Usually you may change it by using date_default_timezone_set('your timezone');
2. gmdate is that the time returned is Greenwich Mean Time (GMT).
php code:
echo date_default_timezone_get ().PHP_EOL;
echo 'Result with date("M d Y H:i:s"):'.PHP_EOL;
echo date("M d Y H:i:s").PHP_EOL;
echo 'Result with gmdate("M d Y H:i:s"):'.PHP_EOL;
echo gmdate("M d Y H:i:s").PHP_EOL;
Result:
Asia/Tokyo
Result with date("M d Y H:i:s"):
Feb 13 2013 09:00:05
Result with gmdate("M d Y H:i:s"):
Feb 13 2013 00:00:05
Reason:
1. date is that the time returned is your time zone. Usually you may change it by using date_default_timezone_set('your timezone');
2. gmdate is that the time returned is Greenwich Mean Time (GMT).
2/08/2013
Running Hadoop on Ubuntu Linux (Single-Node Cluster) for Hadoop installation
Hadoop is a framework written in Java for running applications on large clusters of commodity hardware and incorporates features similar to those of the Google File System (GFS) and of the MapReducecomputing paradigm. Hadoop’s HDFS is a highly fault-tolerant distributed file system and, like Hadoop in general, designed to be deployed on low-cost hardware. It provides high throughput access to application data and is suitable for applications that have large data sets.
The main goal of this tutorial is to get a simple Hadoop installation up and running so that you can play around with the software and learn more about it.
More please go to
http://www.michael-noll.com/tutorials/running-hadoop-on-ubuntu-linux-single-node-cluster/
add user, group, show list all user or group on Centos 6
On Centos 6, you may freely create user, group. Now I give some example for these.
1. Create a group hadoop (it will be saved into /etc/group )
Usage: groupadd [options] GROUP
Options:
-f, --force exit successfully if the group already exists,
and cancel -g if the GID is already used
-g, --gid GID use GID for the new group
-h, --help display this help message and exit
-K, --key KEY=VALUE override /etc/login.defs defaults
-o, --non-unique allow to create groups with duplicate
(non-unique) GID
-p, --password PASSWORD use this encrypted password for the new group
-r, --system create a system account
e.g.
sudo groupadd hadoop
2. Create one user hduser (it will be save into /etc/passwd)
sage: useradd [options] LOGIN
Options:
-b, --base-dir BASE_DIR base directory for the home directory of the
new account
-c, --comment COMMENT GECOS field of the new account
-d, --home-dir HOME_DIR home directory of the new account
-D, --defaults print or change default useradd configuration
-e, --expiredate EXPIRE_DATE expiration date of the new account
-f, --inactive INACTIVE password inactivity period of the new account
-g, --gid GROUP name or ID of the primary group of the new
account
-G, --groups GROUPS list of supplementary groups of the new
account
-h, --help display this help message and exit
-k, --skel SKEL_DIR use this alternative skeleton directory
-K, --key KEY=VALUE override /etc/login.defs defaults
-l, --no-log-init do not add the user to the lastlog and
faillog databases
-m, --create-home create the user's home directory
-M, --no-create-home do not create the user's home directory
-N, --no-user-group do not create a group with the same name as
the user
-o, --non-unique allow to create users with duplicate
(non-unique) UID
-p, --password PASSWORD encrypted password of the new account
-r, --system create a system account
-s, --shell SHELL login shell of the new account
-u, --uid UID user ID of the new account
-U, --user-group create a group with the same name as the user
-Z, --selinux-user SEUSER use a specific SEUSER for the SELinux user mapping
e.g.
useradd -g hadoop hduser
3. show list all users
cat /etc/passwd | cut -d ":" -f 1
4: show list all groups
cat /etc/group |cut -d ":" -f 1
For cat and cut, please refer the following help
5. cat
Usage: cat [OPTION]... [FILE]...
Concatenate FILE(s), or standard input, to standard output.
-A, --show-all equivalent to -vET
-b, --number-nonblank number nonempty output lines
-e equivalent to -vE
-E, --show-ends display $ at end of each line
-n, --number number all output lines
-s, --squeeze-blank suppress repeated empty output lines
-t equivalent to -vT
-T, --show-tabs display TAB characters as ^I
-u (ignored)
-v, --show-nonprinting use ^ and M- notation, except for LFD and TAB
--help display this help and exit
--version output version information and exit
With no FILE, or when FILE is -, read standard input.
Examples:
cat f - g Output f's contents, then standard input, then g's contents.
cat Copy standard input to standard output.
1. Create a group hadoop (it will be saved into /etc/group )
Usage: groupadd [options] GROUP
Options:
-f, --force exit successfully if the group already exists,
and cancel -g if the GID is already used
-g, --gid GID use GID for the new group
-h, --help display this help message and exit
-K, --key KEY=VALUE override /etc/login.defs defaults
-o, --non-unique allow to create groups with duplicate
(non-unique) GID
-p, --password PASSWORD use this encrypted password for the new group
-r, --system create a system account
e.g.
sudo groupadd hadoop
2. Create one user hduser (it will be save into /etc/passwd)
sage: useradd [options] LOGIN
Options:
-b, --base-dir BASE_DIR base directory for the home directory of the
new account
-c, --comment COMMENT GECOS field of the new account
-d, --home-dir HOME_DIR home directory of the new account
-D, --defaults print or change default useradd configuration
-e, --expiredate EXPIRE_DATE expiration date of the new account
-f, --inactive INACTIVE password inactivity period of the new account
-g, --gid GROUP name or ID of the primary group of the new
account
-G, --groups GROUPS list of supplementary groups of the new
account
-h, --help display this help message and exit
-k, --skel SKEL_DIR use this alternative skeleton directory
-K, --key KEY=VALUE override /etc/login.defs defaults
-l, --no-log-init do not add the user to the lastlog and
faillog databases
-m, --create-home create the user's home directory
-M, --no-create-home do not create the user's home directory
-N, --no-user-group do not create a group with the same name as
the user
-o, --non-unique allow to create users with duplicate
(non-unique) UID
-p, --password PASSWORD encrypted password of the new account
-r, --system create a system account
-s, --shell SHELL login shell of the new account
-u, --uid UID user ID of the new account
-U, --user-group create a group with the same name as the user
-Z, --selinux-user SEUSER use a specific SEUSER for the SELinux user mapping
e.g.
useradd -g hadoop hduser
3. show list all users
cat /etc/passwd | cut -d ":" -f 1
4: show list all groups
cat /etc/group |cut -d ":" -f 1
For cat and cut, please refer the following help
5. cat
Usage: cat [OPTION]... [FILE]...
Concatenate FILE(s), or standard input, to standard output.
-A, --show-all equivalent to -vET
-b, --number-nonblank number nonempty output lines
-e equivalent to -vE
-E, --show-ends display $ at end of each line
-n, --number number all output lines
-s, --squeeze-blank suppress repeated empty output lines
-t equivalent to -vT
-T, --show-tabs display TAB characters as ^I
-u (ignored)
-v, --show-nonprinting use ^ and M- notation, except for LFD and TAB
--help display this help and exit
--version output version information and exit
With no FILE, or when FILE is -, read standard input.
Examples:
cat f - g Output f's contents, then standard input, then g's contents.
cat Copy standard input to standard output.
6. cut
Usage: cut OPTION... [FILE]...
Print selected parts of lines from each FILE to standard output.
Mandatory arguments to long options are mandatory for short options too.
-b, --bytes=LIST select only these bytes
-c, --characters=LIST select only these characters
-d, --delimiter=DELIM use DELIM instead of TAB for field delimiter
-f, --fields=LIST select only these fields; also print any line
that contains no delimiter character, unless
the -s option is specified
-n with -b: don't split multibyte characters
--complement complement the set of selected bytes, characters
or fields
-s, --only-delimited do not print lines not containing delimiters
--output-delimiter=STRING use STRING as the output delimiter
the default is to use the input delimiter
--help display this help and exit
--version output version information and exit
Use one, and only one of -b, -c or -f. Each LIST is made up of one
range, or many ranges separated by commas. Selected input is written
in the same order that it is read, and is written exactly once.
Each range is one of:
N N'th byte, character or field, counted from 1
N- from N'th byte, character or field, to end of line
N-M from N'th to M'th (included) byte, character or field
-M from first to M'th (included) byte, character or field
With no FILE, or when FILE is -, read standard input.
2/04/2013
Can not download csv file based on php header
It works on firefox and chrome, but IE (Normally on IE 8) fails to recognize it as a csv file (thinking it is a html fle) and when I click save I get the error, "Unable to download {name of file} from {name of site}. Unable to open this internet site. ..."
Methods:
header("Pragma: public");
header("Cache-Control: must-revalidate, post-check=0, pre-check=0");
header("Cache-Control: public");
header("Content-Disposition: attachment; filename=\"my-data.csv\"");
header("Content-type: application/octet-stream; name=\"my-data.csv\"");
header("Content-Transfer-Encoding: binary");
?>
Methods:
header("Pragma: public");
header("Cache-Control: must-revalidate, post-check=0, pre-check=0");
header("Cache-Control: public");
header("Content-Disposition: attachment; filename=\"my-data.csv\"");
header("Content-type: application/octet-stream; name=\"my-data.csv\"");
header("Content-Transfer-Encoding: binary");
?>
1/30/2013
International Standard Serial Number (ISSN) checker algorithm based on PHP
An International Standard Serial Number (ISSN) is a unique eight-digit number used to identify a print or electronic periodical publication.
Algorithm
1. Calculate the sum of the first seven digits of the ISSN multiplied by its position in the number, counting from the right — that is, 8, 7, 6, 5, 4, 3, and 2, respectively.
2. The modulus 11 of this sum is then calculated: divide the sum by 11 and determine the remainder.
3. If there is no remainder the check digit is 0, otherwise the remainder value is subtracted from 11 to give the check digit: 11 -remainder
4. An upper case X in the check digit position indicates a check digit of 10.
5. To confirm the check digit, calculate the sum of all eight digits of the ISSN multiplied by its position in the number, counting from the right (if the check digit is X, then add 10 to the sum). The modulus 11 of the sum must be 0.
PHP Source Code
$issn = '03785955';
if($issn == checker($issn)){
echo 'good';
}else{
echo 'wrong';
}
function checker($issn=0,$chechsum = 0) {
$issn = substr($issn, 0, 7);
foreach (str_split($issn) as $key => $value) {
$chechsum += (8 - $key) * $value;
}
$chechsum = $chechsum % 11;
if ($chechsum) {
$chechsum = 11 - $chechsum;
if ($chechsum == 10) {
$chechsum = 'X';
}
}
return $issn.$chechsum;
}
or One improved performance algorithms
function checker($issn = 0, $chechsum = 0) {
$issn = substr(preg_replace('/[^0-9]+/', '', $issn), 0, 7);
if (strlen($issn) == 7) {
foreach (array_reverse(str_split((int) $issn)) as $key => $value) {
if ($value) {
$key = $key + 2;
$chechsum = $key * $value + $chechsum;
}
}
$chechsum %=11;
if ($chechsum) {
$chechsum = 11 - $chechsum;
if ($chechsum == 10) {
$chechsum = 'X';
}
}
return $issn . $chechsum;
} else {
return '';
}
}
Algorithm
1. Calculate the sum of the first seven digits of the ISSN multiplied by its position in the number, counting from the right — that is, 8, 7, 6, 5, 4, 3, and 2, respectively.
2. The modulus 11 of this sum is then calculated: divide the sum by 11 and determine the remainder.
3. If there is no remainder the check digit is 0, otherwise the remainder value is subtracted from 11 to give the check digit: 11 -remainder
4. An upper case X in the check digit position indicates a check digit of 10.
5. To confirm the check digit, calculate the sum of all eight digits of the ISSN multiplied by its position in the number, counting from the right (if the check digit is X, then add 10 to the sum). The modulus 11 of the sum must be 0.
PHP Source Code
$issn = '03785955';
if($issn == checker($issn)){
echo 'good';
}else{
echo 'wrong';
}
function checker($issn=0,$chechsum = 0) {
$issn = substr($issn, 0, 7);
foreach (str_split($issn) as $key => $value) {
$chechsum += (8 - $key) * $value;
}
$chechsum = $chechsum % 11;
if ($chechsum) {
$chechsum = 11 - $chechsum;
if ($chechsum == 10) {
$chechsum = 'X';
}
}
return $issn.$chechsum;
}
or One improved performance algorithms
function checker($issn = 0, $chechsum = 0) {
$issn = substr(preg_replace('/[^0-9]+/', '', $issn), 0, 7);
if (strlen($issn) == 7) {
foreach (array_reverse(str_split((int) $issn)) as $key => $value) {
if ($value) {
$key = $key + 2;
$chechsum = $key * $value + $chechsum;
}
}
$chechsum %=11;
if ($chechsum) {
$chechsum = 11 - $chechsum;
if ($chechsum == 10) {
$chechsum = 'X';
}
}
return $issn . $chechsum;
} else {
return '';
}
}
1/21/2013
Undefined class constant 'MYSQL_ATTR_INIT_COMMAND'
$db = new PDO('mysql:dbname=xnews;host=localhost;port=' . $LOCAL_DB_PORT,
$LOCAL_DB_USER,
$LOCAL_DB_PASS,
array(PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES 'UTF8'")
);
Fatal error: Undefined class constant 'MYSQL_ATTR_INIT_COMMAND'
In fact, the MYSQL_ATTR_INIT_COMMAND is 1002. But at some times the php can not recognize it. The one reason is that you have not installed php-mysql for php_module.
If you use yum to install php and mysql, then you may use
sudo yum install php-mysql
sudo service httpd restart
or you may compile your php with the
--with-pdo-mysql
optionThat is OK. Now you may access the constant MYSQL_ATTR_INIT_COMMAND. Good luck to you.
1/20/2013
centos install mysql5.5 by yum
When you want to use yum to use mysql5.5, you should let yum know the repos. Now I give one way for you to install mysql5.5 on your centos 5 or centos 6.
1. On centos 6
//on 64 computer
rpm -Uvh http://ftp.riken.jp/Linux/fedora/epel//6/x86_64/epel-release-6-8.noarch.rpm
rpm -Uvh http://dl.iuscommunity.org/pub/ius/stable/Redhat/6/x86_64/ius-release-1.0-10.ius.el6.noarch.rpm
// on 86 computer
rpm -Uvh http://ftp.riken.jp/Linux/fedora/epel//6/i386/epel-release-6-8.noarch.rpm
rpm -Uvh http://dl.iuscommunity.org/pub/ius/stable/Redhat/6/i386/ius-release-1.0-10.ius.el6.noarch.rpm
// if the file does not exist, please go to http://ftp.riken.jp/Linux/fedora/epel//6/ to find the suitable version for epel-release-6-XXX.noarch.rpm
2. On centos 5
//on 64 computer
rpm -Uvh http://ftp.riken.jp/Linux/fedora/epel//5/x86_64/epel-release-6-8.noarch.rpm
rpm -Uvh http://dl.iuscommunity.org/pub/ius/stable/Redhat/5/x86_64/ius-release-1.0-10.ius.el6.noarch.rpm
// on 86 computer
rpm -Uvh http://ftp.riken.jp/Linux/fedora/epel//5/i386/epel-release-6-8.noarch.rpm
rpm -Uvh http://dl.iuscommunity.org/pub/ius/stable/Redhat/6/i386/ius-release-1.0-10.ius.el6.noarch.rpm
// if the file does not exist, please go to http://ftp.riken.jp/Linux/fedora/epel//5/ to find the suitable version for epel-release-5-XXX.noarch.rpm
Last please use
yum remove mysql*
yum install mysql55
1. On centos 6
//on 64 computer
rpm -Uvh http://ftp.riken.jp/Linux/fedora/epel//6/x86_64/epel-release-6-8.noarch.rpm
rpm -Uvh http://dl.iuscommunity.org/pub/ius/stable/Redhat/6/x86_64/ius-release-1.0-10.ius.el6.noarch.rpm
// on 86 computer
rpm -Uvh http://ftp.riken.jp/Linux/fedora/epel//6/i386/epel-release-6-8.noarch.rpm
rpm -Uvh http://dl.iuscommunity.org/pub/ius/stable/Redhat/6/i386/ius-release-1.0-10.ius.el6.noarch.rpm
// if the file does not exist, please go to http://ftp.riken.jp/Linux/fedora/epel//6/ to find the suitable version for epel-release-6-XXX.noarch.rpm
2. On centos 5
//on 64 computer
rpm -Uvh http://ftp.riken.jp/Linux/fedora/epel//5/x86_64/epel-release-6-8.noarch.rpm
rpm -Uvh http://dl.iuscommunity.org/pub/ius/stable/Redhat/5/x86_64/ius-release-1.0-10.ius.el6.noarch.rpm
// on 86 computer
rpm -Uvh http://ftp.riken.jp/Linux/fedora/epel//5/i386/epel-release-6-8.noarch.rpm
rpm -Uvh http://dl.iuscommunity.org/pub/ius/stable/Redhat/6/i386/ius-release-1.0-10.ius.el6.noarch.rpm
// if the file does not exist, please go to http://ftp.riken.jp/Linux/fedora/epel//5/ to find the suitable version for epel-release-5-XXX.noarch.rpm
Last please use
yum remove mysql*
yum install mysql55
1/19/2013
install php5.4 on centos 6
When you want to use yum to use php5.4, you should let yum know the repos. Now I give one way for you to install php5.4 on your centos 5 or centos 6.
1. On centos 6
//on 64 computer
rpm -Uvh http://ftp.riken.jp/Linux/fedora/epel//6/x86_64/epel-release-6-8.noarch.rpm
rpm -Uvh http://dl.iuscommunity.org/pub/ius/stable/Redhat/6/x86_64/ius-release-1.0-10.ius.el6.noarch.rpm
// on 86 computer
rpm -Uvh http://ftp.riken.jp/Linux/fedora/epel//6/i386/epel-release-6-8.noarch.rpm
rpm -Uvh http://dl.iuscommunity.org/pub/ius/stable/Redhat/6/i386/ius-release-1.0-10.ius.el6.noarch.rpm
// if the file does not exist, please go to http://ftp.riken.jp/Linux/fedora/epel//6/ to find the suitable version for epel-release-6-XXX.noarch.rpm
2. On centos 5
//on 64 computer
rpm -Uvh http://ftp.riken.jp/Linux/fedora/epel//5/x86_64/epel-release-6-8.noarch.rpm
rpm -Uvh http://dl.iuscommunity.org/pub/ius/stable/Redhat/5/x86_64/ius-release-1.0-10.ius.el5.noarch.rpm
// on 86 computer
rpm -Uvh http://ftp.riken.jp/Linux/fedora/epel//5/i386/epel-release-6-8.noarch.rpm
rpm -Uvh http://dl.iuscommunity.org/pub/ius/stable/Redhat/5/i386/ius-release-1.0-10.ius.el5.noarch.rpm
// if the file does not exist, please go to http://ftp.riken.jp/Linux/fedora/epel//5/ to find the suitable version for epel-release-5-XXX.noarch.rpm
Last please use
yum install php54
1. On centos 6
//on 64 computer
rpm -Uvh http://ftp.riken.jp/Linux/fedora/epel//6/x86_64/epel-release-6-8.noarch.rpm
rpm -Uvh http://dl.iuscommunity.org/pub/ius/stable/Redhat/6/x86_64/ius-release-1.0-10.ius.el6.noarch.rpm
// on 86 computer
rpm -Uvh http://ftp.riken.jp/Linux/fedora/epel//6/i386/epel-release-6-8.noarch.rpm
rpm -Uvh http://dl.iuscommunity.org/pub/ius/stable/Redhat/6/i386/ius-release-1.0-10.ius.el6.noarch.rpm
// if the file does not exist, please go to http://ftp.riken.jp/Linux/fedora/epel//6/ to find the suitable version for epel-release-6-XXX.noarch.rpm
2. On centos 5
//on 64 computer
rpm -Uvh http://ftp.riken.jp/Linux/fedora/epel//5/x86_64/epel-release-6-8.noarch.rpm
rpm -Uvh http://dl.iuscommunity.org/pub/ius/stable/Redhat/5/x86_64/ius-release-1.0-10.ius.el5.noarch.rpm
// on 86 computer
rpm -Uvh http://ftp.riken.jp/Linux/fedora/epel//5/i386/epel-release-6-8.noarch.rpm
rpm -Uvh http://dl.iuscommunity.org/pub/ius/stable/Redhat/5/i386/ius-release-1.0-10.ius.el5.noarch.rpm
// if the file does not exist, please go to http://ftp.riken.jp/Linux/fedora/epel//5/ to find the suitable version for epel-release-5-XXX.noarch.rpm
Last please use
yum install php54
1/15/2013
Three methods for switching between multiple databases by PDO
In general, when you create one PDO object, you have chosen one database based on your connection. E.g.
$con = new PDO($DSN,$user, $passwd);
But when you want to switch between multiple databases, what should you do? Now I give 3 methods for switching databases based on PDO objects.
All databases should be from or have same
1. server
2. db engine
3. user account
4. password.
Or you only use the third method.
Example:
Databases
first_db and second_db
tables:
f_name in first_db;
+------+-------+
| id | name |
+------+-------+
| 100 | China |
| 200 | japan |
| 300 | USA |
+------+-------+
s_name in second_db;
+------+-----------+
| id | name |
+------+-----------+
| 100 | Noda |
| 200 | Matsumoto |
| 300 | Okamoto |
+------+-----------+
initiate the pdo connection
$conn = new PDO('mysql:dbname=first_db;host=127.0.0.1;port=3306','user','passwd');
$sql = 'select * from s_name ';
$conn->query($sql);
Methods for switching first_db to second_db,
1. use 'use db';
$conn->exec('use second_db');
$sql = 'select * from s_name ';
$conn->query($sql);
2. use database name
$sql = 'select * from second_db.s_name ';
$conn->query($sql);
3. Create new connection
$conn = new PDO('mysql:dbname=second_db;host=127.0.0.1;port=3306','user','passwd');
$sql = 'select * from s_name ';
$conn->query($sql);
$con = new PDO($DSN,$user, $passwd);
But when you want to switch between multiple databases, what should you do? Now I give 3 methods for switching databases based on PDO objects.
All databases should be from or have same
1. server
2. db engine
3. user account
4. password.
Or you only use the third method.
Example:
Databases
first_db and second_db
tables:
f_name in first_db;
+------+-------+
| id | name |
+------+-------+
| 100 | China |
| 200 | japan |
| 300 | USA |
+------+-------+
s_name in second_db;
+------+-----------+
| id | name |
+------+-----------+
| 100 | Noda |
| 200 | Matsumoto |
| 300 | Okamoto |
+------+-----------+
initiate the pdo connection
$conn = new PDO('mysql:dbname=first_db;host=127.0.0.1;port=3306','user','passwd');
$sql = 'select * from s_name ';
$conn->query($sql);
Methods for switching first_db to second_db,
1. use 'use db';
$conn->exec('use second_db');
$sql = 'select * from s_name ';
$conn->query($sql);
2. use database name
$sql = 'select * from second_db.s_name ';
$conn->query($sql);
3. Create new connection
$conn = new PDO('mysql:dbname=second_db;host=127.0.0.1;port=3306','user','passwd');
$sql = 'select * from s_name ';
$conn->query($sql);
phpMyAdmin Wrong permissions on configuration file
Today I met one error when I configure multiple host for phpMyAdmin on centos 6.3. The error message was
Wrong permissions on configuration file, should not be world writable!
Then I changed the permission of file [ config.inc.php] from 777 to 705. The problem was resolved. Nice, the login page comes out.
sudo chmod 705 ./phpMyAdmin/config.inc.php
Wrong permissions on configuration file, should not be world writable!
Then I changed the permission of file [ config.inc.php] from 777 to 705. The problem was resolved. Nice, the login page comes out.
sudo chmod 705 ./phpMyAdmin/config.inc.php
1/14/2013
职场分为三个层次
我把职场分为三个层次,以次对应基本的三个楼层。
1、管事
就是做事,把自己的本质工作做好,做到尽可能好,做到比比人好,做到别人做不到。
2、管人
就是除了做好自己的事,还好把自己的人管好。只管人不做事不容易让人信服,只做事不管人是没有尽责,实质是退步。管人是很大的学问,让人信服,让人愿意听你的,让人高高兴兴的把事儿做了,这是你的本事。
3、管钱
到了三楼基本就是公司的高层了,那就不是简单管事管人了。比如一个项目来了,你第一考虑的这个项目需要多少资金,有多大风险,回款如何,会不会影响到公司的资金链。然后再去考虑这个项目如何实现,需要多少人,多长时间。最后考虑实现的细节。
也就是要站在公司层面和角度上,系统化的解析项目,综合考虑,准确执行。
http://forum.eet-cn.com/BLOG_ARTICLE_15847.HTM?click_from=8800100458,9009455666,2013-01-14,EECOL,FORUM_ALERT&jumpto=view_welcomead_forum_1358133914650
1/09/2013
MySQL master+slave configure
For reference from MySQL, please go to http://dev.mysql.com/doc/refman/5.1/en/mysql-cluster-replication.html
1. install mysql on master and slave host
master host: 192.168.10.98
slave host: 192.168.10.96
-- create same database and table on master host and slave host.
create database test_db;
use test_db;
create table test_table (id int(10), account char(10), passwd char(10));
2. configure master host
-- edit my.cnf
## Replication
server-id = 1001
log-bin = mysql-bin
You may set server-id from 1 to 2^23 -1 freely
-- grant slave host
grant replication slave on *.* to 'slave96'@'192.168.10.96' identified by 'slave9696';
--flush database
FLUSH TABLES WITH READ lOCK;
-- show master status
sudo mysql> show master status;
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000001 | 1837 | | |
+------------------+----------+--------------+------------------+
Please remember the file and position value
-- unlock
UNLOCK TABLES;
3. configure slave host
-- edit my.cnf
## Replication
server-id = 1002
log-bin = mysql-bin
-- change the master
change master to
master_host=’192.168.10.98’,
master_user=’slave96’,
master_password=’slave9696’,
master_log_file=’mysql-bin.000001’,
master_log_pos=1837;
--start slave
start slave
--check slave statuss
show slave status;
*************************** 1. row ***************************
Slave_IO_State: Waiting for master to send event
Master_Host: 192.168.10.98
Master_User: slave96
Master_Port: 3306
Connect_Retry: 60
Master_Log_File: mysql-bin.000001
Read_Master_Log_Pos: 2167
Relay_Log_File: mysqld-relay-bin.000002
Relay_Log_Pos: 2144
Relay_Master_Log_File: mysql-bin.000001
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
Replicate_Do_DB:
Replicate_Ignore_DB:
Replicate_Do_Table:
Replicate_Ignore_Table:
1. install mysql on master and slave host
master host: 192.168.10.98
slave host: 192.168.10.96
-- create same database and table on master host and slave host.
create database test_db;
use test_db;
create table test_table (id int(10), account char(10), passwd char(10));
2. configure master host
-- edit my.cnf
## Replication
server-id = 1001
log-bin = mysql-bin
You may set server-id from 1 to 2^23 -1 freely
-- grant slave host
grant replication slave on *.* to 'slave96'@'192.168.10.96' identified by 'slave9696';
--flush database
FLUSH TABLES WITH READ lOCK;
-- show master status
sudo mysql> show master status;
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000001 | 1837 | | |
+------------------+----------+--------------+------------------+
Please remember the file and position value
-- unlock
UNLOCK TABLES;
3. configure slave host
-- edit my.cnf
## Replication
server-id = 1002
log-bin = mysql-bin
-- change the master
change master to
master_host=’192.168.10.98’,
master_user=’slave96’,
master_password=’slave9696’,
master_log_file=’mysql-bin.000001’,
master_log_pos=1837;
--start slave
start slave
--check slave statuss
show slave status;
*************************** 1. row ***************************
Slave_IO_State: Waiting for master to send event
Master_Host: 192.168.10.98
Master_User: slave96
Master_Port: 3306
Connect_Retry: 60
Master_Log_File: mysql-bin.000001
Read_Master_Log_Pos: 2167
Relay_Log_File: mysqld-relay-bin.000002
Relay_Log_Pos: 2144
Relay_Master_Log_File: mysql-bin.000001
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
Replicate_Do_DB:
Replicate_Ignore_DB:
Replicate_Do_Table:
Replicate_Ignore_Table:
----------
In the show above, the Slave_IO_Running and Slave_SQL_Running must be YES.
Till now, you have completed the configure for master-slave. Please try this functionality.
Insert one record on master host
INSERT INTO test_table VALUES(100,'Jone', 'Jone100');
You may check the slave host. There must be one same record on slave host.
Subscribe to:
Posts (Atom)