最近将lightcloud-python用c改写了一下,并且作为一个consistent hash的服务器,性能能够达到1w/s的set和get操作,下一步就是实现socket接口的问题了。
这样lightcloud可以和tokyotyrant+tokyocabinet,memcached,redis等等合起来一起用。。。
2009年10月28日 星期三
2009年8月31日 星期一
php for lightcloud
see it here:http://code.google.com/p/lightcloud-phpclient/
which is just rewriting the python client of lightcloud to php edition... and will add some more features later...
which is just rewriting the python client of lightcloud to php edition... and will add some more features later...
2009年4月16日 星期四
Cassandra安装、部署和简单评测
懒得一张张插入图片了。。。可以在这里看有图片的。
http://docs.google.com/Doc?id=ddxvh3dd_6gdnrs8f8&hl=zh_CN
Cassandra简单评测(2009/4/16)
1. 安装
a) 环境
i. Windows Vista Sp1(其实最好是在linux下面安装,不过本本只有Vista和OS X)
ii. Java JDK 1.7 b50(http://www.java.net/download/jdk7/binaries/jdk-7-ea-bin-b50-windows-i586-05_mar_2009.exe,请一定要安装这个版本,因为程序就是基于这个jdk进行开发的,而这个jdk和之前的有很大的差别,不用这个jdk会发生很多类找不到的问题。不过貌似听作者说会将这个限制去掉,到时候其他jdk也可以了)
iii. Eclipse 3.3(这个随便哪个版本了)
iv. Firefox 3.3(这个就是为了看一下cassandra提供的http接口的)
b) 配置
i. 首先从svn(http://svn.apache.org/repos/asf/incubator/cassandra/trunk)上面把cassandra给checkout出来,放在cassandra目录中。我checkout的版本是3月27号的最后那个版本,具体revision忘记了。
ii. 在eclipse新建一个project,选择“java project from existing ant buildfile)
iii. 在ant buildfile 里面选择cassandra中的build.xml,工程名填入cassandra20090327,然后导入。
iv. 因为eclipse设置的workspace是E:\Program\Java2,所以在E:\Program\Java2\cassandra20090327新建一个文件夹叫做“null”,然后将cassandra目录中conf下面的两个文件:storage-conf.xml和log4j.properties复制到cassandra20090327/null下面,打开storage-conf.xml,接下来说明一下相关的配置:
1. 填入主机名称,我有两台机器,所以写成(当然可以写ip地址):
a)lizhenyu-PC
b)lizhenyu-IBM
2. 里面写你需要新建或者读取的table的名称和columnfamily以及conlumntype,可以使用默认的。
3. 就是通过firefox访问时用的端口,可以使用默认的。
v. 配置完以后,我们在eclipse中运行service包中的CassandraServer.java文件,如果出现:
DEBUG - Submitting a major compaction task ...
DEBUG - Started compaction ...RecycleColumnFamily
DEBUG - Submitting a major compaction task ...
DEBUG - Finished compaction ...RecycleColumnFamily
DEBUG - Started compaction ...Super1
DEBUG - Finished compaction ...Super1
DEBUG - Done reading the block indexes, Index has been created
DEBUG - INDEX LOAD TIME: 13 ms.
DEBUG - Submitting a major compaction task ...
DEBUG - Started compaction ...Standard2
DEBUG - Finished compaction ...Standard2
DEBUG - Submitting a major compaction task ...
DEBUG - Started compaction ...Super2
DEBUG - Submitting a major compaction task ...
DEBUG - Finished compaction ...Super2
DEBUG - Submitting a major compaction task ...
DEBUG - Started compaction ...Standard1
DEBUG - Submitting a major compaction task ...
DEBUG - Finished compaction ...Standard1
DEBUG - Submitting a major compaction task ...
DEBUG - Started compaction ...LocationInfo
DEBUG - Submitting a major compaction task ...
DEBUG - Finished compaction ...LocationInfo
DEBUG - Started compaction ...StandardByTime1
DEBUG - Finished compaction ...StandardByTime1
DEBUG - Submitting a major compaction task ...
DEBUG - Started compaction ...TableMetadata
DEBUG - Finished compaction ...TableMetadata
DEBUG - Started compaction ...StandardByTime2
DEBUG - Finished compaction ...StandardByTime2
DEBUG - Started compaction ...HintsColumnFamily
DEBUG - Finished compaction ...HintsColumnFamily
DEBUG - Starting to listen on lizhenyu-IBM:7001
INFO - Running on stage GMFD
说明已经成功运行了,在两台机器上一次如此配置,我的笔记本名字是lizhenyu-IBM,台式机名称是lizhenyu-PC。如果两台机器都配置成功了,你会在eclipse的控制台上看到他们之间的交互信息。
2. 测试
a) 首先在lizhenyu-PC和lizhenyu-IBM上分别启动CassandraService.java
i. 在firefox中输入http://lizhenyu-ibm:7002/或者http://lizhenyu-pc:7002/都能够看到关于这个小小的cluster的信息
ii.
iii.
iv.
v. 我输入的是http://lizhenyu-ibm:7002/,所以写的sql语句也是影响ibm这台机器
vi. 点击SQL,进入数据插入和查询界面
vii. 输入如下图的信息
viii. 点击send,出现The insert was successful : columnfamily=Standard1 key=1 data=xyz
ix. 在查询框中输入
x. 点击send,得到的结果是
xi. 现在说明对于table的操作是没有问题的
b) 在org.apache.cassandra.test中有很多用来测试Cassandra的代码,我测试其中的SSTableTest.java(其他的可以按照这个例子自己尝试,但是StressTest.java里面还是有点问题,我还在和作者交流)。
i. 对于StressTest.java,默认是执行这段代码:
1. BloomFilter bf = new BloomFilter(1024*1024, 15);
2. for ( int i = 0; i < 1024*1024; ++i )
3. {
4. bf.fill(Integer.toString(i));
5. }
6.
7. DataOutputBuffer bufOut = new DataOutputBuffer();
8. BloomFilter.serializer().serialize(bf, bufOut);
9. FileOutputStream fos = new FileOutputStream("C:\\Engagements\\bf.dat", true);
10. fos.write(bufOut.getData(), 0, bufOut.getLength());
11. fos.close();
12.
13. FileInputStream fis = new FileInputStream("C:\\Engagements\\bf.dat");
14. byte[] bytes = new byte[fis.available()];
15. fis.read(bytes);
16. DataInputBuffer bufIn = new DataInputBuffer();
17. bufIn.reset(bytes, bytes.length );
18. BloomFilter bf2 = BloomFilter.serializer().deserialize(bufIn);
19.
20. int count = 0;
21. for ( int i = 0; i < 1024*1024; ++i )
22. {
23. if ( bf.isPresent(Integer.toString(i)) )
24. ++count;
25. }
26. System.out.println(count);
其实就是简单的对数据的序列化和反序列化,将序列化后的东西存储在硬盘上,当要读取数据的时候,对文件进行反序列化,就可以正常显示了。sstable的存储和获取就是一个序列化和反序列化的过程。
正确的结果是:1048576,如果和结果不一样,检查一下吧。
ii. 将这段代码注释掉,去掉LogUtil.init(),readSSTable()和rawSSTableWrite()的注释,变成:
1. LogUtil.init();
2. //DatabaseDescriptor.init();
3. //hashSSTableWrite();
4. rawSSTableWrite();
5. readSSTable();
将rawSSTableWrite()函数的代码改成:
private static void rawSSTableWrite() throws Throwable
{
SSTable ssTable = new SSTable("C:\\Engagements\\Cassandra", "Table-Test-2");
DataOutputBuffer bufOut = new DataOutputBuffer();
BloomFilter bf = new BloomFilter(1000, 8);
byte[] bytes = new byte[64*1024];
Random random = new Random();
for ( int i = 100; i < 1000; ++i )
{
String key = Integer.toString(i);
ColumnFamily cf = new ColumnFamily("Standard1", "Standard");
bufOut.reset();
// random.nextBytes(bytes);
cf.addColumn("C", "Avinash Lakshman is a good man".getBytes(), i);
ColumnFamily.serializerWithIndexes().serialize(cf, bufOut);
ssTable.append(key, bufOut);
bf.fill(key);
}
ssTable.close(bf);
}
结果会出现
KEY:100
Standard1
C
KEY:101
Standard1
C
KEY:102
Standard1
C
……
……
……
因为这个版本的代码有点问题,不知道为什么作者认为101比102小,那么101的md5值也会比102的md5值小,奇怪的论调,貌似没有这样的关系吧。如果你出现类似于这样的exception:key is not written by ascending.那么可以更改org.apache.cassandra.dht包中的decorateKey(String key)函数:
原来的代码:public String decorateKey(String key)
{
return hash(key).toString() + ":" + key;
}
改后的代码:public String decorateKey(String key)
{
//return hash(key).toString() + ":" + key;
return key + ":" + hash(key);
}
c) 其他几个测试文件可以自己回去尝试去运行一下,这里就懒得写了,其实就是分别测试了memtable,对Cassandra的简单压力测试,数据的导入导出等等。
3. 如何使用Cassandra或者说它的接口
a) 其实Cassandra的接口很简单,都放在了org.apache.cassandra.service中的Cassandra.java文件中,主要有以下几个接口:
get_slice,get_slice_by_names,get_column,get_column_count,insert,batch_insert,batch_insert_blocking,remove,get_columns_since,get_slice_super,get_slice_super_by_names,get_superColumn,batch_insert_superColumn,batch_insert_superColumn_blocking,touch,getStringProperty,getStringListProperty,describeTable,executeQuery, 关于怎么使用这些接口,可以看test包中的几个例子,都有介绍,而且看名称应该就能懂都是干嘛的了吧。
过两天我会写一个完整的程序,是关于使用这些interface,不过要做毕业设计,太忙了点这段时间^)^
4. 性能测试
a) 因为这些版本都是development版,所以有很多的println语句,导致我用一台机器让另一台机器插入10w条数据都用了100多秒,现在对于Cassandra的benchmark网上还找不到,Avinash Lakshman说他们facebook内部有对Cassandra和Mysql的benchmark,不过他说不知道能不能发出来,估计要问他的boss,等他的消息了。
5. 疑问
a) SStable的格式,因为源代码的注释中一下说index是放在所有的blocks之后的,在后面又说每隔128字节(一个block)就有一个index,晕死,回头再看看源代码
b) 消息序列化中还有点问题,Jonathan Ellis说源代码没有问题,但是我的程序一直都无法通过。
c) 对于Cassandra的failure detection机制我还没有看懂,Neophytos Demetriou建议我去看这篇论文The φ accrual failure detector (http://ddg.jaist.ac.jp/pub/HDY+04.pdf),感兴趣的可以看看,对读懂源代码为什么这样写有帮助。
6. 后续工作
a) 在Cassandra中设计一个庆祥上次给我的任务,看看效果怎么样(不过现在还不能看出性能是不是能比mysql优秀)。
b) 继续深入源代码,因为如果要使用Cassandra的话那么很多的参数变更都能影响整个服务器的性能的,例如对于SSTable中block大小的设定,默认是128bytes,而且没有对外提供更改的接口,如果想要部署Cassandra,还有很多工作要做,需要整理出自己的接口,需要对自己的用户量,业务进行分析,看看什么适合Cassandra
c) Thrift:因为我都是用java对Cassandra进行操作,所以直接跳过了thrift这一步,接下来需要了解一下thrift的详细内容,以后用其他语言操作Cassandra就方便了。
7. 对于是否能部署,我现在还不能下结论,一方面没有拿到facebook的benchmark,另外一方面facebook肯定还有其他的措施没有发出来的,我想Cassandra本身肯定是没有问题的,关键是了解他们内部工作机制,怎么去使用它,更改它使得它适合我们的条件,怎么去开发一些和Cassandra配合使用的东西,我想这才是我们需要关心的
http://docs.google.com/Doc?id=ddxvh3dd_6gdnrs8f8&hl=zh_CN
Cassandra简单评测(2009/4/16)
1. 安装
a) 环境
i. Windows Vista Sp1(其实最好是在linux下面安装,不过本本只有Vista和OS X)
ii. Java JDK 1.7 b50(http://www.java.net/download/jdk7/binaries/jdk-7-ea-bin-b50-windows-i586-05_mar_2009.exe,请一定要安装这个版本,因为程序就是基于这个jdk进行开发的,而这个jdk和之前的有很大的差别,不用这个jdk会发生很多类找不到的问题。不过貌似听作者说会将这个限制去掉,到时候其他jdk也可以了)
iii. Eclipse 3.3(这个随便哪个版本了)
iv. Firefox 3.3(这个就是为了看一下cassandra提供的http接口的)
b) 配置
i. 首先从svn(http://svn.apache.org/repos/asf/incubator/cassandra/trunk)上面把cassandra给checkout出来,放在cassandra目录中。我checkout的版本是3月27号的最后那个版本,具体revision忘记了。
ii. 在eclipse新建一个project,选择“java project from existing ant buildfile)
iii. 在ant buildfile 里面选择cassandra中的build.xml,工程名填入cassandra20090327,然后导入。
iv. 因为eclipse设置的workspace是E:\Program\Java2,所以在E:\Program\Java2\cassandra20090327新建一个文件夹叫做“null”,然后将cassandra目录中conf下面的两个文件:storage-conf.xml和log4j.properties复制到cassandra20090327/null下面,打开storage-conf.xml,接下来说明一下相关的配置:
1.
a)
b)
2.
3.
v. 配置完以后,我们在eclipse中运行service包中的CassandraServer.java文件,如果出现:
DEBUG - Submitting a major compaction task ...
DEBUG - Started compaction ...RecycleColumnFamily
DEBUG - Submitting a major compaction task ...
DEBUG - Finished compaction ...RecycleColumnFamily
DEBUG - Started compaction ...Super1
DEBUG - Finished compaction ...Super1
DEBUG - Done reading the block indexes, Index has been created
DEBUG - INDEX LOAD TIME: 13 ms.
DEBUG - Submitting a major compaction task ...
DEBUG - Started compaction ...Standard2
DEBUG - Finished compaction ...Standard2
DEBUG - Submitting a major compaction task ...
DEBUG - Started compaction ...Super2
DEBUG - Submitting a major compaction task ...
DEBUG - Finished compaction ...Super2
DEBUG - Submitting a major compaction task ...
DEBUG - Started compaction ...Standard1
DEBUG - Submitting a major compaction task ...
DEBUG - Finished compaction ...Standard1
DEBUG - Submitting a major compaction task ...
DEBUG - Started compaction ...LocationInfo
DEBUG - Submitting a major compaction task ...
DEBUG - Finished compaction ...LocationInfo
DEBUG - Started compaction ...StandardByTime1
DEBUG - Finished compaction ...StandardByTime1
DEBUG - Submitting a major compaction task ...
DEBUG - Started compaction ...TableMetadata
DEBUG - Finished compaction ...TableMetadata
DEBUG - Started compaction ...StandardByTime2
DEBUG - Finished compaction ...StandardByTime2
DEBUG - Started compaction ...HintsColumnFamily
DEBUG - Finished compaction ...HintsColumnFamily
DEBUG - Starting to listen on lizhenyu-IBM:7001
INFO - Running on stage GMFD
说明已经成功运行了,在两台机器上一次如此配置,我的笔记本名字是lizhenyu-IBM,台式机名称是lizhenyu-PC。如果两台机器都配置成功了,你会在eclipse的控制台上看到他们之间的交互信息。
2. 测试
a) 首先在lizhenyu-PC和lizhenyu-IBM上分别启动CassandraService.java
i. 在firefox中输入http://lizhenyu-ibm:7002/或者http://lizhenyu-pc:7002/都能够看到关于这个小小的cluster的信息
ii.
iii.
iv.
v. 我输入的是http://lizhenyu-ibm:7002/,所以写的sql语句也是影响ibm这台机器
vi. 点击SQL,进入数据插入和查询界面
vii. 输入如下图的信息
viii. 点击send,出现The insert was successful : columnfamily=Standard1 key=1 data=xyz
ix. 在查询框中输入
x. 点击send,得到的结果是
xi. 现在说明对于table的操作是没有问题的
b) 在org.apache.cassandra.test中有很多用来测试Cassandra的代码,我测试其中的SSTableTest.java(其他的可以按照这个例子自己尝试,但是StressTest.java里面还是有点问题,我还在和作者交流)。
i. 对于StressTest.java,默认是执行这段代码:
1. BloomFilter bf = new BloomFilter(1024*1024, 15);
2. for ( int i = 0; i < 1024*1024; ++i )
3. {
4. bf.fill(Integer.toString(i));
5. }
6.
7. DataOutputBuffer bufOut = new DataOutputBuffer();
8. BloomFilter.serializer().serialize(bf, bufOut);
9. FileOutputStream fos = new FileOutputStream("C:\\Engagements\\bf.dat", true);
10. fos.write(bufOut.getData(), 0, bufOut.getLength());
11. fos.close();
12.
13. FileInputStream fis = new FileInputStream("C:\\Engagements\\bf.dat");
14. byte[] bytes = new byte[fis.available()];
15. fis.read(bytes);
16. DataInputBuffer bufIn = new DataInputBuffer();
17. bufIn.reset(bytes, bytes.length );
18. BloomFilter bf2 = BloomFilter.serializer().deserialize(bufIn);
19.
20. int count = 0;
21. for ( int i = 0; i < 1024*1024; ++i )
22. {
23. if ( bf.isPresent(Integer.toString(i)) )
24. ++count;
25. }
26. System.out.println(count);
其实就是简单的对数据的序列化和反序列化,将序列化后的东西存储在硬盘上,当要读取数据的时候,对文件进行反序列化,就可以正常显示了。sstable的存储和获取就是一个序列化和反序列化的过程。
正确的结果是:1048576,如果和结果不一样,检查一下吧。
ii. 将这段代码注释掉,去掉LogUtil.init(),readSSTable()和rawSSTableWrite()的注释,变成:
1. LogUtil.init();
2. //DatabaseDescriptor.init();
3. //hashSSTableWrite();
4. rawSSTableWrite();
5. readSSTable();
将rawSSTableWrite()函数的代码改成:
private static void rawSSTableWrite() throws Throwable
{
SSTable ssTable = new SSTable("C:\\Engagements\\Cassandra", "Table-Test-2");
DataOutputBuffer bufOut = new DataOutputBuffer();
BloomFilter bf = new BloomFilter(1000, 8);
byte[] bytes = new byte[64*1024];
Random random = new Random();
for ( int i = 100; i < 1000; ++i )
{
String key = Integer.toString(i);
ColumnFamily cf = new ColumnFamily("Standard1", "Standard");
bufOut.reset();
// random.nextBytes(bytes);
cf.addColumn("C", "Avinash Lakshman is a good man".getBytes(), i);
ColumnFamily.serializerWithIndexes().serialize(cf, bufOut);
ssTable.append(key, bufOut);
bf.fill(key);
}
ssTable.close(bf);
}
结果会出现
KEY:100
Standard1
C
KEY:101
Standard1
C
KEY:102
Standard1
C
……
……
……
因为这个版本的代码有点问题,不知道为什么作者认为101比102小,那么101的md5值也会比102的md5值小,奇怪的论调,貌似没有这样的关系吧。如果你出现类似于这样的exception:key is not written by ascending.那么可以更改org.apache.cassandra.dht包中的decorateKey(String key)函数:
原来的代码:public String decorateKey(String key)
{
return hash(key).toString() + ":" + key;
}
改后的代码:public String decorateKey(String key)
{
//return hash(key).toString() + ":" + key;
return key + ":" + hash(key);
}
c) 其他几个测试文件可以自己回去尝试去运行一下,这里就懒得写了,其实就是分别测试了memtable,对Cassandra的简单压力测试,数据的导入导出等等。
3. 如何使用Cassandra或者说它的接口
a) 其实Cassandra的接口很简单,都放在了org.apache.cassandra.service中的Cassandra.java文件中,主要有以下几个接口:
get_slice,get_slice_by_names,get_column,get_column_count,insert,batch_insert,batch_insert_blocking,remove,get_columns_since,get_slice_super,get_slice_super_by_names,get_superColumn,batch_insert_superColumn,batch_insert_superColumn_blocking,touch,getStringProperty,getStringListProperty,describeTable,executeQuery, 关于怎么使用这些接口,可以看test包中的几个例子,都有介绍,而且看名称应该就能懂都是干嘛的了吧。
过两天我会写一个完整的程序,是关于使用这些interface,不过要做毕业设计,太忙了点这段时间^)^
4. 性能测试
a) 因为这些版本都是development版,所以有很多的println语句,导致我用一台机器让另一台机器插入10w条数据都用了100多秒,现在对于Cassandra的benchmark网上还找不到,Avinash Lakshman说他们facebook内部有对Cassandra和Mysql的benchmark,不过他说不知道能不能发出来,估计要问他的boss,等他的消息了。
5. 疑问
a) SStable的格式,因为源代码的注释中一下说index是放在所有的blocks之后的,在后面又说每隔128字节(一个block)就有一个index,晕死,回头再看看源代码
b) 消息序列化中还有点问题,Jonathan Ellis说源代码没有问题,但是我的程序一直都无法通过。
c) 对于Cassandra的failure detection机制我还没有看懂,Neophytos Demetriou建议我去看这篇论文The φ accrual failure detector (http://ddg.jaist.ac.jp/pub/HDY+04.pdf),感兴趣的可以看看,对读懂源代码为什么这样写有帮助。
6. 后续工作
a) 在Cassandra中设计一个庆祥上次给我的任务,看看效果怎么样(不过现在还不能看出性能是不是能比mysql优秀)。
b) 继续深入源代码,因为如果要使用Cassandra的话那么很多的参数变更都能影响整个服务器的性能的,例如对于SSTable中block大小的设定,默认是128bytes,而且没有对外提供更改的接口,如果想要部署Cassandra,还有很多工作要做,需要整理出自己的接口,需要对自己的用户量,业务进行分析,看看什么适合Cassandra
c) Thrift:因为我都是用java对Cassandra进行操作,所以直接跳过了thrift这一步,接下来需要了解一下thrift的详细内容,以后用其他语言操作Cassandra就方便了。
7. 对于是否能部署,我现在还不能下结论,一方面没有拿到facebook的benchmark,另外一方面facebook肯定还有其他的措施没有发出来的,我想Cassandra本身肯定是没有问题的,关键是了解他们内部工作机制,怎么去使用它,更改它使得它适合我们的条件,怎么去开发一些和Cassandra配合使用的东西,我想这才是我们需要关心的
2009年4月12日 星期日
10000块钱看来也没有多少啊。【转自校内】
下面我就为大家分析一下月薪一万在上海的普通生活:
(一)月到手收入计算(人民币)
收入:10000元
扣除社保:养老8% 医疗2% 失业1%
根据最新08年平均工资的三倍来算缴纳基数上限为9876元。
所以扣除额度为 9876*11%=1086.36
公积金: 扣除额度上限为607元
(根据7%推算缴纳基数上限为8671.5元,09年很快就会调整更高)
缴税工资:1000-1086.36-607=8306.64元
缴纳个税:886.328元
到手收入:8306.64 - 886.328=7420.312元
(二)月生活成本计算:对于一个无房无车,活的还凑合的水平来说。
1.住房:租房,在徐汇区这边,一室一厅全配,最少的1500元
(如果是买了房子个人还贷,根据情况,估计平均也要2000元)
2.水、电、煤气、宽带、有线电视、卫生管理费:
电费110元左右
(空调、冰箱、电视、热水器、洗衣机、抽油烟机、电脑、手机、
另外什么电热毯,饮水机,电饭锅等都是耗电大户)
水费:洗澡做饭很费水哈,50元
煤气:经常做饭的话也要20元
宽带:120元
有线电视:18元
卫生管理费:5元
合计:110+50+20+120+18+5=323元
3.交通费:大部分骑自行车
但是考虑到偶尔坐地铁、公交、打车,比如周末,或者赶上下雨,
加班很晚的情况,平均一下算200元。如果自己开车则更多。
4.饮食:
吃饭:对于22个工作日来说
早餐5元
午餐15元
晚餐做饭的话15元,否则出去吃要20-30元,折中算20元
对于四个周末来说,出去吃饭喝水看电影,
按照一天100元计算,算600元。
水果,超市零食:一周至少80块吧,看看现在水果酸奶的价格。。算300元。
小计 (5+15+20)*22+600+300=1780元
5.日常品费用:买书、日常用品,洗衣粉、牙膏、洗发水、卫生纸之类
的算100元。
6.服装鞋子:这个我按照每个月200元计算吧,很低了。
7.手机费:100元
8.交友费用:没有女朋友的,和同学同事,一个月至少也要200块吧
有女朋友的至少要500元吧。我取个折中的350元。
9.特殊日期:包括一些生日、情人节、圣诞节、结婚、生孩子等等礼物,
一个人至少要300元吧,要是领导至少500、800吧,
按照一年2000块左右来计算,月均摊为200元,够低了吧。
10.给父母:按照最低标准600元,也就意思一下吧。
11.看病:现在感冒都要200多,均摊月100元,希望没有。。
12.旅游:一年就算三次短途吧,一次住宿路费吃饭买东西至少500,算100元
以上总计:1500+323+200+1780+100+200+100+350+200+600+100+100=5403元
固定支出后,每个月剩余7420.312-5403=2017.312元
以上只要是在上海混过的朋友,应该知道并体会我的标准,中等偏下生活水平
因为没有涉及什么娱乐、学习费用。
如果你买了房子、买了车、有了孩子、有其他投资活动,
社交活动更多、旅游更多、家里负担更重、计划买电器贵重物品、
抽烟喝酒、女朋友花销厉害、有被骗被偷等情况,
那请酌情自己计算,多申请几张信用卡就很有必要了:-)
如果没有,那么恭喜你,每个月理论上可以剩余2000元了,呵呵,
但是一定要作为风险意外支出费用,千万别随便用,
万一这个月需要买点什么特殊的东西呢。
上海房价,在徐汇这边,二手房大概12000元,自己考虑吧。
每天下班就最好乖乖回家,
味千拉面和KFC都是奢侈,盖浇饭和兰州拉面是外出主打食品。。。
否则,你将发现这2000块在上海,花出去简直太容易了,平均一天70元,
还没注意,还没感觉,吃饭点菜的时候一冲动,没了!!
还没到月底呢,一看卡上。。余额不小心变成个位数了!!!!月光了,嚎!
(一)月到手收入计算(人民币)
收入:10000元
扣除社保:养老8% 医疗2% 失业1%
根据最新08年平均工资的三倍来算缴纳基数上限为9876元。
所以扣除额度为 9876*11%=1086.36
公积金: 扣除额度上限为607元
(根据7%推算缴纳基数上限为8671.5元,09年很快就会调整更高)
缴税工资:1000-1086.36-607=8306.64元
缴纳个税:886.328元
到手收入:8306.64 - 886.328=7420.312元
(二)月生活成本计算:对于一个无房无车,活的还凑合的水平来说。
1.住房:租房,在徐汇区这边,一室一厅全配,最少的1500元
(如果是买了房子个人还贷,根据情况,估计平均也要2000元)
2.水、电、煤气、宽带、有线电视、卫生管理费:
电费110元左右
(空调、冰箱、电视、热水器、洗衣机、抽油烟机、电脑、手机、
另外什么电热毯,饮水机,电饭锅等都是耗电大户)
水费:洗澡做饭很费水哈,50元
煤气:经常做饭的话也要20元
宽带:120元
有线电视:18元
卫生管理费:5元
合计:110+50+20+120+18+5=323元
3.交通费:大部分骑自行车
但是考虑到偶尔坐地铁、公交、打车,比如周末,或者赶上下雨,
加班很晚的情况,平均一下算200元。如果自己开车则更多。
4.饮食:
吃饭:对于22个工作日来说
早餐5元
午餐15元
晚餐做饭的话15元,否则出去吃要20-30元,折中算20元
对于四个周末来说,出去吃饭喝水看电影,
按照一天100元计算,算600元。
水果,超市零食:一周至少80块吧,看看现在水果酸奶的价格。。算300元。
小计 (5+15+20)*22+600+300=1780元
5.日常品费用:买书、日常用品,洗衣粉、牙膏、洗发水、卫生纸之类
的算100元。
6.服装鞋子:这个我按照每个月200元计算吧,很低了。
7.手机费:100元
8.交友费用:没有女朋友的,和同学同事,一个月至少也要200块吧
有女朋友的至少要500元吧。我取个折中的350元。
9.特殊日期:包括一些生日、情人节、圣诞节、结婚、生孩子等等礼物,
一个人至少要300元吧,要是领导至少500、800吧,
按照一年2000块左右来计算,月均摊为200元,够低了吧。
10.给父母:按照最低标准600元,也就意思一下吧。
11.看病:现在感冒都要200多,均摊月100元,希望没有。。
12.旅游:一年就算三次短途吧,一次住宿路费吃饭买东西至少500,算100元
以上总计:1500+323+200+1780+100+200+100+350+200+600+100+100=5403元
固定支出后,每个月剩余7420.312-5403=2017.312元
以上只要是在上海混过的朋友,应该知道并体会我的标准,中等偏下生活水平
因为没有涉及什么娱乐、学习费用。
如果你买了房子、买了车、有了孩子、有其他投资活动,
社交活动更多、旅游更多、家里负担更重、计划买电器贵重物品、
抽烟喝酒、女朋友花销厉害、有被骗被偷等情况,
那请酌情自己计算,多申请几张信用卡就很有必要了:-)
如果没有,那么恭喜你,每个月理论上可以剩余2000元了,呵呵,
但是一定要作为风险意外支出费用,千万别随便用,
万一这个月需要买点什么特殊的东西呢。
上海房价,在徐汇这边,二手房大概12000元,自己考虑吧。
每天下班就最好乖乖回家,
味千拉面和KFC都是奢侈,盖浇饭和兰州拉面是外出主打食品。。。
否则,你将发现这2000块在上海,花出去简直太容易了,平均一天70元,
还没注意,还没感觉,吃饭点菜的时候一冲动,没了!!
还没到月底呢,一看卡上。。余额不小心变成个位数了!!!!月光了,嚎!
2009年4月3日 星期五
VirtualBox实现host与guest文件共享(主机是Vista)
查看了很多网页,试了好多次才成功,很多网上写的都不对,要么就是没有空格,要么就是用单引号。
host的代码格式:
VBoxManage sharedfolder add “vmname” -name “sharename” -hostpath “sharefolderpath”
例如我的virtualbox安装在d盘的program files下面,那么首先进入d:\program files\sun\xvm virtualbox目录,输入:
vboxmanage.exe sharedfolder add "ubuntu" -name "cassandra" -hostpath "e\cassandra\cassandra20090403"
成功会显示all rights reserved...
guest用的是ubuntu,那么在terminal中输入:
mount -t vboxsf "sharename" "mountpoint"
其中mountpoint是指已经加载的盘符
我这里用了sudo mount -t vboxsf "cassandra" "cdrom"
直接加载到光驱上了。
host的代码格式:
VBoxManage sharedfolder add “vmname” -name “sharename” -hostpath “sharefolderpath”
例如我的virtualbox安装在d盘的program files下面,那么首先进入d:\program files\sun\xvm virtualbox目录,输入:
vboxmanage.exe sharedfolder add "ubuntu" -name "cassandra" -hostpath "e\cassandra\cassandra20090403"
成功会显示all rights reserved...
guest用的是ubuntu,那么在terminal中输入:
mount -t vboxsf "sharename" "mountpoint"
其中mountpoint是指已经加载的盘符
我这里用了sudo mount -t vboxsf "cassandra" "cdrom"
直接加载到光驱上了。
2009年3月25日 星期三
memcached性能测试
找了一台机器测试了一下memcached的效果,测试数据共30000条,大概是100m左右,设置的memcache内存为300m,在实际运行过程中占用了200m左右,也就是说每1m数据用memcached放在内存中后就会变成2m,这应该是包括建立索引等等需要的空间。
程序是随机访问数据库,对于non-memcache,循环100w次需要3000秒,而对于memcache,循环1000w次才需要3000秒,所以对于内存大于数据库两倍的情况下,这时候如果把所有数据都放在内存中而且设置成不失效的话,那么使用memcache的速度可以是non-memcache的速度的10倍,但是在实际情况下,因为硬盘数据远远大于内存数据,而且设置的失效时间可能会影响hit的成功率,特别是当访问量很小的时候,使用memcached反而会使程序整体速度变慢。
在使用windows下的memcached的时候,发现不管怎么设置memcached,给予memcached都是固定的64m(也就是memcached的默认值),很奇怪,不知道有什么解决办法,后来就放在Mac OS X 10.5.6上进行的测试(硬件是:AMD 3000+ ,2G DDR667内存,500G SATA2 7200硬盘)。
所以,对于小型网站,最好不要使用memcached, 特别是内存远小于频繁数据(这些数据都会被用户频繁读取)的时候。当然,对于日访问量上千万我觉得使用memcached确实可以达到很好的效果,而且加上采用分布式的话,这样共享的内存可以更大,效果会更好,还有一点,当内存小于硬盘数据的时候,CPU的占用率会突然变高,可能是因为要执行LRU算法(也就是替换原来内存中的数据)。很多东西都要在实际中才能知道,我也是通过了这次测试才发现原来memcached并不适合我先改进的一个小型网站(日访问量也就100w)。
程序是随机访问数据库,对于non-memcache,循环100w次需要3000秒,而对于memcache,循环1000w次才需要3000秒,所以对于内存大于数据库两倍的情况下,这时候如果把所有数据都放在内存中而且设置成不失效的话,那么使用memcache的速度可以是non-memcache的速度的10倍,但是在实际情况下,因为硬盘数据远远大于内存数据,而且设置的失效时间可能会影响hit的成功率,特别是当访问量很小的时候,使用memcached反而会使程序整体速度变慢。
在使用windows下的memcached的时候,发现不管怎么设置memcached,给予memcached都是固定的64m(也就是memcached的默认值),很奇怪,不知道有什么解决办法,后来就放在Mac OS X 10.5.6上进行的测试(硬件是:AMD 3000+ ,2G DDR667内存,500G SATA2 7200硬盘)。
所以,对于小型网站,最好不要使用memcached, 特别是内存远小于频繁数据(这些数据都会被用户频繁读取)的时候。当然,对于日访问量上千万我觉得使用memcached确实可以达到很好的效果,而且加上采用分布式的话,这样共享的内存可以更大,效果会更好,还有一点,当内存小于硬盘数据的时候,CPU的占用率会突然变高,可能是因为要执行LRU算法(也就是替换原来内存中的数据)。很多东西都要在实际中才能知道,我也是通过了这次测试才发现原来memcached并不适合我先改进的一个小型网站(日访问量也就100w)。
2009年3月16日 星期一
memcached介绍
今天翻译了一小段,接下来会慢慢翻译完的。。。
protocol
-----------
协议
Clients of memcached communicate with server through TCP connections.
(A UDP interface is also available; details are below under "UDP
protocol.") A given running memcached server listens on some
(configurable) port; clients connect to that port, send commands to
the server, read responses, and eventually close the connection.
Memcached的客户端通过TCP连接和服务端进行通信(UDP接口也是可用的,具体可以参考UDP协议)。已经运行memcached的server会 监听(配置的)端口;客户端连接那个端口,发送命令,读取回复,最终关闭连接。
There is no need to send any command to end the session. A client may
just close the connection at any moment it no longer needs it. Note,
however, that clients are encouraged to cache their connections rather
than reopen them every time they need to store or retrieve data. This
is because memcached is especially designed to work very efficiently
with a very large number (many hundreds, more than a thousand if
necessary) of open connections. Caching connections will eliminate the
overhead associated with establishing a TCP connection (the overhead
of preparing for a new connection on the server side is insignificant
compared to this).
要终结一个对话,并不需要客户端发送任何的命令。客户端可以在它不再需要通信的时候关闭这个连接。当然,我们鼓励客户端将他们的连接缓存起来而不是当他们每次需要存储或者取数据的时候都重新打开一个连接,因为memcached设计的初衷就是为了提供一个高效的、支持大量连接的东东^_^。连接缓存化(caching connections)可以使得因为建立TCP连接而出现的过载现象消失。
There are two kinds of data sent in the memcache protocol: text lines
and unstructured data. Text lines are used for commands from clients
and responses from servers. Unstructured data is sent when a client
wants to store or retrieve data. The server will transmit back
unstructured data in exactly the same way it received it, as a byte
stream. The server doesn't care about byte order issues in
unstructured data and isn't aware of them. There are no limitations on
characters that may appear in unstructured data; however, the reader
of such data (either a client or a server) will always know, from a
preceding text line, the exact length of the data block being
transmitted.
Memcache协议里面存在这两种可以被传输(发送)的数据:文本行(text lines)和未结构化数据(unstructure data)。文本行主要用于客户端向服务器发送命令和服务器返回信息给客户端。未结构化数据则是在客户端想要存取数据的时候才被使用(发送)。服务器会将未结构化数据以一种比特流的方式传输给客户端(这种方式和它从客户端接受数据的方式是一样的)。服务器并不关心比特流的所导致的未结构化数据,也不会意识到他未结构化的数据,未结构化数据中的字符也没有任何限制。当然,不管是客户端还是服务器来的数据,读者(reader)总是可以通过预先处理的文本行(可能例如client发送一个get_length(object)来获得这个数据块的长度,然后server处理以后直接返回长度,再传输数据)来得知被传输的数据块的长度。
Text lines are always terminated by \r\n. Unstructured data is _also_
terminated by \r\n, even though \r, \n or any other 8-bit characters
may also appear inside the data. Therefore, when a client retrieves
data from a server, it must use the length of the data block (which it
will be provided with) to determine where the data block ends, and not
the fact that \r\n follows the end of the data block, even though it
does.
文本行总是由\r\n作为结尾。未结构化数据也可以使用\r\n,即使是是\r,\n甚至是任何8bit长的字符都能出现在未结构化数据中。所以当客户端从服务器获得数据的同时,它必须使用服务器返回的数据块长度来确定什么时候数据块结束了,而不是用\r\n来决定数据块的完结,虽然事实上我们就使用\r\n来作为数据块的末尾的。
Keys
----
键值
Data stored by memcached is identified with the help of a key. A key
is a text string which should uniquely identify the data for clients
that are interested in storing and retrieving it. Currently the
length limit of a key is set at 250 characters (of course, normally
clients wouldn't need to use such long keys); the key must not include
control characters or whitespace.
存储在memcached中的数据是通过键值来识别的。所谓的键值就是唯一的文本字符串,这个字符串必须在用户存取数据的时候能唯一的确定数据。当前键值的长度被限制在250个字符,键值不能包括控制符和空格。
Commands
--------
命令行
There are three types of commands.
总共有三种命令
Storage commands (there are six: "set", "add", "replace", "append"
"prepend" and "cas") ask the server to store some data identified by a key. The client sends a command line, and then a data block; after that the client expects one line of response, which will indicate success or
faulure.
存储命令(总共有6个:set,add,replace,append,prepend和cas)是让服务器根据某个键值去存储数据。客户端首先发送一个命令,然后数据块;接着服务器会返回信息,告诉客户端时不时成功了。
Retrieval commands (there are two: "get" and "gets") ask the server to
retrieve data corresponding to a set of keys (one or more keys in one
request). The client sends a command line, which includes all the
requested keys; after that for each item the server finds it sends to
the client one response line with information about the item, and one
data block with the item's data; this continues until the server
finished with the "END" response line.
读取命令(总共有两个:get和gets)让服务器根据一系列的键值去获得数据。客户端首先发送一个包含键值(可以有多个)的命令,之后对于服务器所找个的每个item,服务器会返回给客户端这个item的信息,然后是item的数据库,知道服务器返回END这个命令,说明数据已经传输完毕。
All other commands don't involve unstructured data. In all of them,
the client sends one command line, and expects (depending on the
command) either one line of response, or several lines of response
ending with "END" on the last line.
其他所有的命令都不包括未结构化数据。客户端先发送命令,然后期望获得一个或者多个回应,这些回应会以END作为结尾。
A command line always starts with the name of the command, followed by
parameters (if any) delimited by whitespace. Command names are
lower-case and are case-sensitive.
命令行通常是以命令作为开头,后面跟着各种的参素。命令都是小写字母而且是大消息敏感的。
Expiration times
----------------
过期时间
Some commands involve a client sending some kind of expiration time
(relative to an item or to an operation requested by the client) to
the server. In all such cases, the actual value sent may either be
Unix time (number of seconds since January 1, 1970, as a 32-bit
value), or a number of seconds starting from current time. In the
latter case, this number of seconds may not exceed 60*60*24*30 (number
of seconds in 30 days); if the number sent by a client is larger than
that, the server will consider it to be real Unix time value rather
than an offset from current time.
Error strings
-------------
Each command sent by a client may be answered with an error string
from the server. These error strings come in three types:
- "ERROR\r\n"
means the client sent a nonexistent command name.
- "CLIENT_ERROR\r\n"
means some sort of client error in the input line, i.e. the input
doesn't conform to the protocol in some way. is a
human-readable error string.
意味着客户端在输入命令的时候出现了错误,例如输入没有在某些地方没有遵从协议。
- "SERVER_ERROR\r\n"
means some sort of server error prevents the server from carrying
out the command. is a human-readable error string. In cases
of severe server errors, which make it impossible to continue
serving the client (this shouldn't normally happen), the server will
close the connection after sending the error line. This is the only
case in which the server closes a connection to a client.
意味着服务器方面的错误使得这个命令没有被执行。对于一些非常严重的错误,这些错误使得服务器没法在为客户端提供服务了,这时候服务器就会先发送错误信息,然后关闭它和客户端的连接,这也是服务器唯一会主动关闭连接的情况
In the descriptions of individual commands below, these error lines
are not again specifically mentioned, but clients must allow for their
possibility.
在下面对每个单独命令的描述,这些错误提示不会再被详细的体积,但是客户端必须考虑到他们出现的可能。
Storage commands
----------------
存储命令
First, the client sends a command line which looks like this:
首先,客户端发送一个类似于下面的命令
[noreply]\r\n
cas [noreply]\r\n
- is "set", "add", "replace", "append" or "prepend"
命令名称可以使set,add,replace,append或者prepend
"set" means "store this data".
Set是存储数据
"add" means "store this data, but only if the server *doesn't* already
hold data for this key".
Add是如果是这个键值没有对应的数据,那么可以存储这个数据
"replace" means "store this data, but only if the server *does*
already hold data for this key".
Replace是如果这个键值有对应的数据,那么可以替换这个数据
"append" means "add this data to an existing key after existing data".
Append是指在原有的数据后面添加
"prepend" means "add this data to an existing key before existing data".
Prepend是指在原有的数据前面添加
The append and prepend commands do not accept flags or exptime.
They update existing data portions, and ignore new flag and exptime
settings.
Append和prepend这两个命令都不接受标记(flasg)和过期时间(exptime)。
他们会更新现存数据,同时忽略新的标记和过期时间。
"cas" is a check and set operation which means "store this data but
only if no one else has updated since I last fetched it."
Cas是一个检查和设置操作,这个命令仅仅在数据被我取出以后,没有人更新过这个数据的时候,才可以存储数据,也就是说如果A取了这个数据,B更新了,A就不能存储了。
- is the key under which the client asks to store the data
是客户端要求存储数据时用的键值
- is an arbitrary 16-bit unsigned integer (written out in
decimal) that the server stores along with the data and sends back
when the item is retrieved. Clients may use this as a bit field to
store data-specific information; this field is opaque to the server.
Note that in memcached 1.2.1 and higher, flags may be 32-bits, instead
of 16, but you might want to restrict yourself to 16 bits for
compatibility with older versions.
是一个任意的16位的无符号整数(用10进制表示),当客户端取数据的时候,服务器会将这个flag和数据一起传输给客户端。客户端也许会用这个作为1bit的字段来存储数据的特定信息,这个字段对服务器是不可见的。在1.2.1以后的版本,flags可能会是32位的,为了兼容,可能还是要使用16位的flags
- is expiration time. If it's 0, the item never expires
(although it may be deleted from the cache to make place for other
items). If it's non-zero (either Unix time or offset in seconds from
current time), it is guaranteed that clients will not be able to
retrieve this item after the expiration time arrives (measured by
server time).
就是过期时间。如果它的值是0,那么永不过期(当然可能因为内存没有空间导致这个item被删除)。如果不是0而且过期了,客户端就不能在获得这个数据了。
- is the number of bytes in the data block to follow, *not*
including the delimiting \r\n. may be zero (in which case
it's followed by an empty data block).
- is a unique 64-bit value of an existing entry.
Clients should use the value returned from the "gets" command
when issuing "cas" updates.
- "noreply" optional parameter instructs the server to not send the
reply. NOTE: if the request line is malformed, the server can't
parse "noreply" option reliably. In this case it may send the error
to the client, and not reading it on the client side will break
things. Client should construct only valid requests.
Noreply选项可以上服务器不返回任何消息。
After this line, the client sends the data block:
命令行过后,客户端就开始发送数据块了:
\r\n
- is a chunk of arbitrary 8-bit data of length
from the previous line.
数据块是长度为8bit的数据
After sending the command line and the data blockm the client awaits
the reply, which may be:
- "STORED\r\n", to indicate success.
- "NOT_STORED\r\n" to indicate the data was not stored, but not
because of an error. This normally means that either that the
condition for an "add" or a "replace" command wasn't met, or that the
item is in a delete queue (see the "delete" command below).
- "EXISTS\r\n" to indicate that the item you are trying to store with
a "cas" command has been modified since you last fetched it.
数据自从被你取出来以后被其他人修改过了,所以不能在更新了。
- "NOT_FOUND\r\n" to indicate that the item you are trying to store
with a "cas" command did not exist or has been deleted.
数据不存在了,可能被删掉了。
Retrieval command:
------------------
The retrieval commands "get" and "gets" operates like this:
get*\r\n
gets*\r\n
-* means one or more key strings separated by whitespace.
After this command, the client expects zero or more items, each of
which is received as a text line followed by a data block. After all
the items have been transmitted, the server sends the string
"END\r\n"
to indicate the end of response.
Each item sent by the server looks like this:
这个是item的表现形式:
VALUE []\r\n
\r\n
- is the key for the item being sent
- is the flags value set by the storage command
- is the length of the data block to follow, *not* including
its delimiting \r\n
- is a unique 64-bit integer that uniquely identifies
this specific item.
一个64位长度的整型来唯一标示item
- is the data for this item.
If some of the keys appearing in a retrieval request are not sent back
by the server in the item list this means that the server does not
hold items with such keys (because they were never stored, or stored
but deleted to make space for more items, or expired, or explicitly
deleted by a client).
Deletion
--------
The command "delete" allows for explicit deletion of items:
delete [
protocol
-----------
协议
Clients of memcached communicate with server through TCP connections.
(A UDP interface is also available; details are below under "UDP
protocol.") A given running memcached server listens on some
(configurable) port; clients connect to that port, send commands to
the server, read responses, and eventually close the connection.
Memcached的客户端通过TCP连接和服务端进行通信(UDP接口也是可用的,具体可以参考UDP协议)。已经运行memcached的server会 监听(配置的)端口;客户端连接那个端口,发送命令,读取回复,最终关闭连接。
There is no need to send any command to end the session. A client may
just close the connection at any moment it no longer needs it. Note,
however, that clients are encouraged to cache their connections rather
than reopen them every time they need to store or retrieve data. This
is because memcached is especially designed to work very efficiently
with a very large number (many hundreds, more than a thousand if
necessary) of open connections. Caching connections will eliminate the
overhead associated with establishing a TCP connection (the overhead
of preparing for a new connection on the server side is insignificant
compared to this).
要终结一个对话,并不需要客户端发送任何的命令。客户端可以在它不再需要通信的时候关闭这个连接。当然,我们鼓励客户端将他们的连接缓存起来而不是当他们每次需要存储或者取数据的时候都重新打开一个连接,因为memcached设计的初衷就是为了提供一个高效的、支持大量连接的东东^_^。连接缓存化(caching connections)可以使得因为建立TCP连接而出现的过载现象消失。
There are two kinds of data sent in the memcache protocol: text lines
and unstructured data. Text lines are used for commands from clients
and responses from servers. Unstructured data is sent when a client
wants to store or retrieve data. The server will transmit back
unstructured data in exactly the same way it received it, as a byte
stream. The server doesn't care about byte order issues in
unstructured data and isn't aware of them. There are no limitations on
characters that may appear in unstructured data; however, the reader
of such data (either a client or a server) will always know, from a
preceding text line, the exact length of the data block being
transmitted.
Memcache协议里面存在这两种可以被传输(发送)的数据:文本行(text lines)和未结构化数据(unstructure data)。文本行主要用于客户端向服务器发送命令和服务器返回信息给客户端。未结构化数据则是在客户端想要存取数据的时候才被使用(发送)。服务器会将未结构化数据以一种比特流的方式传输给客户端(这种方式和它从客户端接受数据的方式是一样的)。服务器并不关心比特流的所导致的未结构化数据,也不会意识到他未结构化的数据,未结构化数据中的字符也没有任何限制。当然,不管是客户端还是服务器来的数据,读者(reader)总是可以通过预先处理的文本行(可能例如client发送一个get_length(object)来获得这个数据块的长度,然后server处理以后直接返回长度,再传输数据)来得知被传输的数据块的长度。
Text lines are always terminated by \r\n. Unstructured data is _also_
terminated by \r\n, even though \r, \n or any other 8-bit characters
may also appear inside the data. Therefore, when a client retrieves
data from a server, it must use the length of the data block (which it
will be provided with) to determine where the data block ends, and not
the fact that \r\n follows the end of the data block, even though it
does.
文本行总是由\r\n作为结尾。未结构化数据也可以使用\r\n,即使是是\r,\n甚至是任何8bit长的字符都能出现在未结构化数据中。所以当客户端从服务器获得数据的同时,它必须使用服务器返回的数据块长度来确定什么时候数据块结束了,而不是用\r\n来决定数据块的完结,虽然事实上我们就使用\r\n来作为数据块的末尾的。
Keys
----
键值
Data stored by memcached is identified with the help of a key. A key
is a text string which should uniquely identify the data for clients
that are interested in storing and retrieving it. Currently the
length limit of a key is set at 250 characters (of course, normally
clients wouldn't need to use such long keys); the key must not include
control characters or whitespace.
存储在memcached中的数据是通过键值来识别的。所谓的键值就是唯一的文本字符串,这个字符串必须在用户存取数据的时候能唯一的确定数据。当前键值的长度被限制在250个字符,键值不能包括控制符和空格。
Commands
--------
命令行
There are three types of commands.
总共有三种命令
Storage commands (there are six: "set", "add", "replace", "append"
"prepend" and "cas") ask the server to store some data identified by a key. The client sends a command line, and then a data block; after that the client expects one line of response, which will indicate success or
faulure.
存储命令(总共有6个:set,add,replace,append,prepend和cas)是让服务器根据某个键值去存储数据。客户端首先发送一个命令,然后数据块;接着服务器会返回信息,告诉客户端时不时成功了。
Retrieval commands (there are two: "get" and "gets") ask the server to
retrieve data corresponding to a set of keys (one or more keys in one
request). The client sends a command line, which includes all the
requested keys; after that for each item the server finds it sends to
the client one response line with information about the item, and one
data block with the item's data; this continues until the server
finished with the "END" response line.
读取命令(总共有两个:get和gets)让服务器根据一系列的键值去获得数据。客户端首先发送一个包含键值(可以有多个)的命令,之后对于服务器所找个的每个item,服务器会返回给客户端这个item的信息,然后是item的数据库,知道服务器返回END这个命令,说明数据已经传输完毕。
All other commands don't involve unstructured data. In all of them,
the client sends one command line, and expects (depending on the
command) either one line of response, or several lines of response
ending with "END" on the last line.
其他所有的命令都不包括未结构化数据。客户端先发送命令,然后期望获得一个或者多个回应,这些回应会以END作为结尾。
A command line always starts with the name of the command, followed by
parameters (if any) delimited by whitespace. Command names are
lower-case and are case-sensitive.
命令行通常是以命令作为开头,后面跟着各种的参素。命令都是小写字母而且是大消息敏感的。
Expiration times
----------------
过期时间
Some commands involve a client sending some kind of expiration time
(relative to an item or to an operation requested by the client) to
the server. In all such cases, the actual value sent may either be
Unix time (number of seconds since January 1, 1970, as a 32-bit
value), or a number of seconds starting from current time. In the
latter case, this number of seconds may not exceed 60*60*24*30 (number
of seconds in 30 days); if the number sent by a client is larger than
that, the server will consider it to be real Unix time value rather
than an offset from current time.
Error strings
-------------
Each command sent by a client may be answered with an error string
from the server. These error strings come in three types:
- "ERROR\r\n"
means the client sent a nonexistent command name.
- "CLIENT_ERROR
means some sort of client error in the input line, i.e. the input
doesn't conform to the protocol in some way.
human-readable error string.
意味着客户端在输入命令的时候出现了错误,例如输入没有在某些地方没有遵从协议。
- "SERVER_ERROR
means some sort of server error prevents the server from carrying
out the command.
of severe server errors, which make it impossible to continue
serving the client (this shouldn't normally happen), the server will
close the connection after sending the error line. This is the only
case in which the server closes a connection to a client.
意味着服务器方面的错误使得这个命令没有被执行。对于一些非常严重的错误,这些错误使得服务器没法在为客户端提供服务了,这时候服务器就会先发送错误信息,然后关闭它和客户端的连接,这也是服务器唯一会主动关闭连接的情况
In the descriptions of individual commands below, these error lines
are not again specifically mentioned, but clients must allow for their
possibility.
在下面对每个单独命令的描述,这些错误提示不会再被详细的体积,但是客户端必须考虑到他们出现的可能。
Storage commands
----------------
存储命令
First, the client sends a command line which looks like this:
首先,客户端发送一个类似于下面的命令
cas
-
命令名称可以使set,add,replace,append或者prepend
"set" means "store this data".
Set是存储数据
"add" means "store this data, but only if the server *doesn't* already
hold data for this key".
Add是如果是这个键值没有对应的数据,那么可以存储这个数据
"replace" means "store this data, but only if the server *does*
already hold data for this key".
Replace是如果这个键值有对应的数据,那么可以替换这个数据
"append" means "add this data to an existing key after existing data".
Append是指在原有的数据后面添加
"prepend" means "add this data to an existing key before existing data".
Prepend是指在原有的数据前面添加
The append and prepend commands do not accept flags or exptime.
They update existing data portions, and ignore new flag and exptime
settings.
Append和prepend这两个命令都不接受标记(flasg)和过期时间(exptime)。
他们会更新现存数据,同时忽略新的标记和过期时间。
"cas" is a check and set operation which means "store this data but
only if no one else has updated since I last fetched it."
Cas是一个检查和设置操作,这个命令仅仅在数据被我取出以后,没有人更新过这个数据的时候,才可以存储数据,也就是说如果A取了这个数据,B更新了,A就不能存储了。
-
-
decimal) that the server stores along with the data and sends back
when the item is retrieved. Clients may use this as a bit field to
store data-specific information; this field is opaque to the server.
Note that in memcached 1.2.1 and higher, flags may be 32-bits, instead
of 16, but you might want to restrict yourself to 16 bits for
compatibility with older versions.
-
(although it may be deleted from the cache to make place for other
items). If it's non-zero (either Unix time or offset in seconds from
current time), it is guaranteed that clients will not be able to
retrieve this item after the expiration time arrives (measured by
server time).
-
including the delimiting \r\n.
it's followed by an empty data block).
-
Clients should use the value returned from the "gets" command
when issuing "cas" updates.
- "noreply" optional parameter instructs the server to not send the
reply. NOTE: if the request line is malformed, the server can't
parse "noreply" option reliably. In this case it may send the error
to the client, and not reading it on the client side will break
things. Client should construct only valid requests.
Noreply选项可以上服务器不返回任何消息。
After this line, the client sends the data block:
命令行过后,客户端就开始发送数据块了:
\r\n
- is a chunk of arbitrary 8-bit data of length
from the previous line.
数据块是长度为8bit的数据
After sending the command line and the data blockm the client awaits
the reply, which may be:
- "STORED\r\n", to indicate success.
- "NOT_STORED\r\n" to indicate the data was not stored, but not
because of an error. This normally means that either that the
condition for an "add" or a "replace" command wasn't met, or that the
item is in a delete queue (see the "delete" command below).
- "EXISTS\r\n" to indicate that the item you are trying to store with
a "cas" command has been modified since you last fetched it.
数据自从被你取出来以后被其他人修改过了,所以不能在更新了。
- "NOT_FOUND\r\n" to indicate that the item you are trying to store
with a "cas" command did not exist or has been deleted.
数据不存在了,可能被删掉了。
Retrieval command:
------------------
The retrieval commands "get" and "gets" operates like this:
get
gets
-
After this command, the client expects zero or more items, each of
which is received as a text line followed by a data block. After all
the items have been transmitted, the server sends the string
"END\r\n"
to indicate the end of response.
Each item sent by the server looks like this:
这个是item的表现形式:
VALUE
\r\n
-
-
-
its delimiting \r\n
-
this specific item.
一个64位长度的整型来唯一标示item
- is the data for this item.
If some of the keys appearing in a retrieval request are not sent back
by the server in the item list this means that the server does not
hold items with such keys (because they were never stored, or stored
but deleted to make space for more items, or expired, or explicitly
deleted by a client).
Deletion
--------
The command "delete" allows for explicit deletion of items:
delete
2009年3月15日 星期日
整体和部分,宏观和微观
很难想象我怎么会去考虑这么一个抽象的问题,其实这也是在最近,我越发的觉得自己的整体感太差。。。
很多事情,我太纠结于细节,例如给我一个item,我会研究怎么去安装怎么去使用,甚至研究它的源代码(如果是开源的话)。但很多时候我却很难理解他们为什么这样写,为什么要用RandomAcessRead而不用顺序读取,依据在哪,原理在哪?看一个东西却只懂一个东西,而不能触类旁通,无法从小事中知大意,不能把握问题的关键,应该是我现在亟需解决的"bug"了吧。
好好思考,不仅仅是人生的每一步,而是应该整体上知道我需要什么,然后才去关注怎么做。
很多事情,我太纠结于细节,例如给我一个item,我会研究怎么去安装怎么去使用,甚至研究它的源代码(如果是开源的话)。但很多时候我却很难理解他们为什么这样写,为什么要用RandomAcessRead而不用顺序读取,依据在哪,原理在哪?看一个东西却只懂一个东西,而不能触类旁通,无法从小事中知大意,不能把握问题的关键,应该是我现在亟需解决的"bug"了吧。
好好思考,不仅仅是人生的每一步,而是应该整体上知道我需要什么,然后才去关注怎么做。
2009年3月14日 星期六
cassandra配置的我很郁闷
弄了好久,和mailist上面的几个作者聊了一上午才配置完成,也不知道算不算已经搞定了,这是运行的日志。。。应该没有问题。。。需要两台电脑,一台作为master server,另一台作为seed,然后master向seed发packet,所以现在还需要用java在seed上面写一个程序来接包。。。先吃了午饭,回来在写程序。。。
DEBUG - Submitting a major compaction task ...
DEBUG - Started compaction ...RecycleColumnFamily
DEBUG - Submitting a major compaction task ...
DEBUG - Finished compaction ...RecycleColumnFamily
DEBUG - Submitting a major compaction task ...
DEBUG - Started compaction ...Test
DEBUG - Finished compaction ...Test
DEBUG - Started compaction ...Test2
DEBUG - Finished compaction ...Test2
DEBUG - Submitting a major compaction task ...
DEBUG - Started compaction ...LocationInfo
DEBUG - Finished compaction ...LocationInfo
DEBUG - Submitting a major compaction task ...
DEBUG - Started compaction ...TableMetadata
DEBUG - Finished compaction ...TableMetadata
DEBUG - Submitting a major compaction task ...
DEBUG - Started compaction ...HintsColumnFamily
DEBUG - Finished compaction ...HintsColumnFamily
DEBUG - Starting to listen on lizhenyu-PC:6001
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:2
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 62
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:3
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 62
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:4
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 62
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:5
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 62
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:6
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 62
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:7
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 62
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:8
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 62
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:9
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 62
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:10
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 62
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:11
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 63
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:12
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 63
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:13
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 63
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:14
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 63
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:15
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 63
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:16
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 63
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:17
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 63
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:18
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 63
DEBUG - Performing status check ...
DEBUG - Submitting a major compaction task ...
DEBUG - Started compaction ...RecycleColumnFamily
DEBUG - Submitting a major compaction task ...
DEBUG - Finished compaction ...RecycleColumnFamily
DEBUG - Submitting a major compaction task ...
DEBUG - Started compaction ...Test
DEBUG - Finished compaction ...Test
DEBUG - Started compaction ...Test2
DEBUG - Finished compaction ...Test2
DEBUG - Submitting a major compaction task ...
DEBUG - Started compaction ...LocationInfo
DEBUG - Finished compaction ...LocationInfo
DEBUG - Submitting a major compaction task ...
DEBUG - Started compaction ...TableMetadata
DEBUG - Finished compaction ...TableMetadata
DEBUG - Submitting a major compaction task ...
DEBUG - Started compaction ...HintsColumnFamily
DEBUG - Finished compaction ...HintsColumnFamily
DEBUG - Starting to listen on lizhenyu-PC:6001
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:2
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 62
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:3
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 62
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:4
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 62
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:5
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 62
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:6
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 62
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:7
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 62
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:8
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 62
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:9
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 62
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:10
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 62
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:11
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 63
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:12
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 63
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:13
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 63
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:14
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 63
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:15
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 63
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:16
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 63
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:17
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 63
DEBUG - Performing status check ...
DEBUG - Gossip Digests are : lizhenyu-PC:6001:4:18
INFO - Sending a GossipDigestSynMessage to 192.168.0.108:6001 ...
DEBUG - Size of Gossip packet 63
DEBUG - Performing status check ...
2009年3月12日 星期四
Cassandra的数据模型
1,每一row都由一个唯一的key标实,key是个string类型
2,每个Cassandra实例含有一个table,这个table由一个或者多个column families组成
3,column families的数量和名称在这个集群启动的时候必须是固定的了,虽然对于column families的数量没有限制,但是最好不要太多
4,每个column families可以包含supercolumns 和 columns这两个架构中的任何一个。它们都是动态建立的,并且对于每个column families中,他们的数量是没有限制的。
5,columns是由一个名字,一个值和一个用户自定义的timestamp,columns的数量可以很大
6,supercolumns是由一个名字和无数个columns组成的。
Distribution, Replication and Fault Tolerance
1,数据是分布放在集群上的,使用的是Consistent Hashing和Order Preserving Hashing Function。使用Order Preserving Hash function使得我们可以在今后对某个区域的数据进行扫描,从而进行分析
2,集群中的每个membership都说通过Gossip方式的membership算法来维护的。这个集群中的每个节点如果fail了,那么就会有一个叫做Accrual Style Failure Detector的东东监控它
3...
2,每个Cassandra实例含有一个table,这个table由一个或者多个column families组成
3,column families的数量和名称在这个集群启动的时候必须是固定的了,虽然对于column families的数量没有限制,但是最好不要太多
4,每个column families可以包含supercolumns 和 columns这两个架构中的任何一个。它们都是动态建立的,并且对于每个column families中,他们的数量是没有限制的。
5,columns是由一个名字,一个值和一个用户自定义的timestamp,columns的数量可以很大
6,supercolumns是由一个名字和无数个columns组成的。
Distribution, Replication and Fault Tolerance
1,数据是分布放在集群上的,使用的是Consistent Hashing和Order Preserving Hashing Function。使用Order Preserving Hash function使得我们可以在今后对某个区域的数据进行扫描,从而进行分析
2,集群中的每个membership都说通过Gossip方式的membership算法来维护的。这个集群中的每个节点如果fail了,那么就会有一个叫做Accrual Style Failure Detector的东东监控它
3...
2009年3月11日 星期三
公司不解决北京户口,比较麻烦...
转一篇相关的文章:
首先,要明确一下三方协议的用途,可是这么来形容,三方协议只是在你毕业前和公司达成工作意向的一种文书,注意,这只是一种意向,在法律意义上,三方协议的作用要远小于劳动合同。
它的作用主要是用来办理户口迁移和档案寄送的。
而三方协议在你到公司报到后会自行失效,此时你要同公司签订劳动合同来保障各自的权益。
下面说一下档案、户口和派遣证的关系:
1、档案代表的是人事关系,户口代表的是户籍关系,档案是随着户口走的,所以如果单位解决了户口就意味着同时给解决档案,但如果单位只接受档案不解决户口,户口就要挂靠或者打回原籍。
2、户口挂靠有两种方式,一种是挂靠在人才市场,一种是挂在本地的亲戚家里。这些都是针对户口不在天津市的外地人而言。户口在本市的无需再办理户口挂靠。
3、派遣证是一种证明文件。它的作用有三:一是证明你的毕业生身份,二是去单位报到的必须文件,三是落下户籍关系的必备文件。派遣证是与户籍关系紧密相连的,每人只有一张,就是说户籍落在哪派遣证就发到哪,如果单位给解决户后那派遣证上就署名单位,如果单位不解决户口户口挂靠在人才市场派遣证上就署名人才市场指定的单位,如户口打回原籍派遣证就署名原籍所在地的相关部门。
而派遣证是根据三方协议来定的。这也就是为什么三方协议的作用主要是用来办理落户和档案寄送的。
了解了上面三者的关系,你就应该清楚,如果单位不能为你解决户口,那就不要签三方协议。这一点就我所知北京的部分单位做的很好,他们公司没有进京指标的话,公司会提出不与你签三方而是签劳动合同。但是上海的有些公司却在这方面难为我们,对于本科生,公司明知道不能为你落户,但仍要求跟你签三方,可能这是上海市不成文的惯例,但不是说绝大部分上海公司都不通情达理。即使当时不得已签了三方,也还是有办法办理天津挂靠的。后面有说明。
如果已经与外地单位签了三方协议但不解决户口,那还能挂靠么?回答是:能。
如果是外地人想把户口留在天津就一定要挂靠,这需要去已签的外地单位开个证明,证明不能给你解决户口(也就是退函,具体格式附在下面),同意你另行择业。拿到证明,然后到就业指导中心再领一份三方协议,然后拿到人才市场办理挂靠,相当于跟人才市场再签一份协议,到时派遣证发放到人才市场而非原单位。再强调一下派遣证随户口走。
但此时牵涉到一个问题,公司给你出具退函后,你们所签的三方协议就失效了,在法律上你们就不再有关系。作为处于弱势的学生,就要提前跟单位协商好,如果此时可以先签一个劳动协议那最好,如果不能,也要确认好,毕业时去单位,单位仍然愿意接收你。虽然有一定风险,但协调好后,也没问题。我个人的经历是让单位出具退函时,同时再出具一份接收的证明,相当于录取通知书,将来去公司报到前劳动合同后再退给公司。但这个难度就更大了,这需要单位有很好的包容性和理解性。因为不是多数单位都愿意这么做的。此时就要看你的情商了。
退函
兹有天津大学07届毕业生***同学,已于*年*月与我单位签订就业三方协议。根据**市户籍政策有关规定,我单位不能为其申请办理上海落户,故已签三方协议失效,同意其另行择业。
签字盖章
2007年 月 日
接收函
兹有天津大学07届毕业生***同学,于*年*月与我单位签订就业三方协议,根据***市户籍政策有关规定,我单位不能为其申请办理**市落户,已同意其向学校领取新的三方协议办理天津挂靠落户时宜。
我单位同意接收***同学。
此函只做该同学毕业后来单位报到证明之用。
签字盖章
2007年月 日
这里我要强调一下,退函最好在学校上报就业计划到天津教委之前拿到,然后尽快办理挂靠。如果七月十号派遣后,再想通过学校改派手续到天津的单位,也无法再办理天津户口。
因为天津市规定,对已迁出天津的外地生源一律不准再迁回。这个要切记,是不是要办天津挂靠,提前想清楚。
学校截止签三方协议的时间:
5月20号是学校统计就业数据的期限,就业指导中心的老师虽然没有明确说明,但学校一般会给出一定的宽限,大概可以推迟到5月底6月初,然后学校根据统计数据和资料制作派遣证。所以只要在5月底6月初确定下自己的去向,想挂靠的挂靠不挂靠的就等着打回原籍。
但目前就业指导中心对外的截止日期是20号,而我们学院是15号。所以请同学们还是尽可能在这个期限前完成三方协议。
本科生的派遣证的发放今年大概是在7月10号毕业典礼后。
最后在具体说明一下,人才挂靠和落户亲友家的程序:
这两种挂靠的前提都是你手里要有空白的三方协议。
1.人才中心挂靠
我本人是挂靠在北方人才广开分部(做859,到南头窑下车,大概20分钟就到了)。
带新的三方协议,如果是挂靠户口和档案,500元,以后每年大概是500左右的管理费,这个各个人才中心收费标准大致相同。
但有一个问题需要告诉大家,挂靠人才后,户口和档案是不能分离的,因为此时你的户口为集体户口,依照天津市规定,两者不能分离。
如果你所签的外地公司,要求你把档案调到公司去,那此时你只能把该集体户口转成个人户口后,档案才可以跟户口分离。办理途径是,把此时你的集体户口转到亲友或同学家。或者本身买房,户口转到房产下,但是这个可能性很小。原因是我们多数买不起房。
2.落户亲友家
如果你所签的单位不是天津的,那么你就得跟人才中心签约,这样在名义上你也是在天津就业了。依照天津市规定,你可以要求亲友家所在地派出所给你落户,但是规定上可以,不代表你实际办理时就会一帆风顺,这需要多和派出所民警套套近乎。具体就不说了。
落户亲友家需要的手续如下
本人:身份证,报到证(原件以及复印件),就业协议(原件,以及第一页和第二页的复印件),单位接收证明,毕业证原件。
单位接收证明格式如下:
接收证明:
某某同志是我单位接收的2007届应届毕业生,现为我单位正式职工,因我单位无集体户口,故同意该同志投靠亲友户籍。
单位名称,公章
朋友:户口本、身份证、房本,同意接收的证明
同意接收的证明格式如下:
申请:
我叫某某,出生年月日,现住址,现同意同学或朋友某某(括弧内介绍某某情况,生日、住址、单位、学历)落户于现住址(详细写现住址)
本人签字盖章
最后,对于党组织关系,这个可以直接让学院开介绍信到你要去工作的单位,然后就可提组织档案到公司。不需要走人才中心转一圈。
首先,要明确一下三方协议的用途,可是这么来形容,三方协议只是在你毕业前和公司达成工作意向的一种文书,注意,这只是一种意向,在法律意义上,三方协议的作用要远小于劳动合同。
它的作用主要是用来办理户口迁移和档案寄送的。
而三方协议在你到公司报到后会自行失效,此时你要同公司签订劳动合同来保障各自的权益。
下面说一下档案、户口和派遣证的关系:
1、档案代表的是人事关系,户口代表的是户籍关系,档案是随着户口走的,所以如果单位解决了户口就意味着同时给解决档案,但如果单位只接受档案不解决户口,户口就要挂靠或者打回原籍。
2、户口挂靠有两种方式,一种是挂靠在人才市场,一种是挂在本地的亲戚家里。这些都是针对户口不在天津市的外地人而言。户口在本市的无需再办理户口挂靠。
3、派遣证是一种证明文件。它的作用有三:一是证明你的毕业生身份,二是去单位报到的必须文件,三是落下户籍关系的必备文件。派遣证是与户籍关系紧密相连的,每人只有一张,就是说户籍落在哪派遣证就发到哪,如果单位给解决户后那派遣证上就署名单位,如果单位不解决户口户口挂靠在人才市场派遣证上就署名人才市场指定的单位,如户口打回原籍派遣证就署名原籍所在地的相关部门。
而派遣证是根据三方协议来定的。这也就是为什么三方协议的作用主要是用来办理落户和档案寄送的。
了解了上面三者的关系,你就应该清楚,如果单位不能为你解决户口,那就不要签三方协议。这一点就我所知北京的部分单位做的很好,他们公司没有进京指标的话,公司会提出不与你签三方而是签劳动合同。但是上海的有些公司却在这方面难为我们,对于本科生,公司明知道不能为你落户,但仍要求跟你签三方,可能这是上海市不成文的惯例,但不是说绝大部分上海公司都不通情达理。即使当时不得已签了三方,也还是有办法办理天津挂靠的。后面有说明。
如果已经与外地单位签了三方协议但不解决户口,那还能挂靠么?回答是:能。
如果是外地人想把户口留在天津就一定要挂靠,这需要去已签的外地单位开个证明,证明不能给你解决户口(也就是退函,具体格式附在下面),同意你另行择业。拿到证明,然后到就业指导中心再领一份三方协议,然后拿到人才市场办理挂靠,相当于跟人才市场再签一份协议,到时派遣证发放到人才市场而非原单位。再强调一下派遣证随户口走。
但此时牵涉到一个问题,公司给你出具退函后,你们所签的三方协议就失效了,在法律上你们就不再有关系。作为处于弱势的学生,就要提前跟单位协商好,如果此时可以先签一个劳动协议那最好,如果不能,也要确认好,毕业时去单位,单位仍然愿意接收你。虽然有一定风险,但协调好后,也没问题。我个人的经历是让单位出具退函时,同时再出具一份接收的证明,相当于录取通知书,将来去公司报到前劳动合同后再退给公司。但这个难度就更大了,这需要单位有很好的包容性和理解性。因为不是多数单位都愿意这么做的。此时就要看你的情商了。
退函
兹有天津大学07届毕业生***同学,已于*年*月与我单位签订就业三方协议。根据**市户籍政策有关规定,我单位不能为其申请办理上海落户,故已签三方协议失效,同意其另行择业。
签字盖章
2007年 月 日
接收函
兹有天津大学07届毕业生***同学,于*年*月与我单位签订就业三方协议,根据***市户籍政策有关规定,我单位不能为其申请办理**市落户,已同意其向学校领取新的三方协议办理天津挂靠落户时宜。
我单位同意接收***同学。
此函只做该同学毕业后来单位报到证明之用。
签字盖章
2007年月 日
这里我要强调一下,退函最好在学校上报就业计划到天津教委之前拿到,然后尽快办理挂靠。如果七月十号派遣后,再想通过学校改派手续到天津的单位,也无法再办理天津户口。
因为天津市规定,对已迁出天津的外地生源一律不准再迁回。这个要切记,是不是要办天津挂靠,提前想清楚。
学校截止签三方协议的时间:
5月20号是学校统计就业数据的期限,就业指导中心的老师虽然没有明确说明,但学校一般会给出一定的宽限,大概可以推迟到5月底6月初,然后学校根据统计数据和资料制作派遣证。所以只要在5月底6月初确定下自己的去向,想挂靠的挂靠不挂靠的就等着打回原籍。
但目前就业指导中心对外的截止日期是20号,而我们学院是15号。所以请同学们还是尽可能在这个期限前完成三方协议。
本科生的派遣证的发放今年大概是在7月10号毕业典礼后。
最后在具体说明一下,人才挂靠和落户亲友家的程序:
这两种挂靠的前提都是你手里要有空白的三方协议。
1.人才中心挂靠
我本人是挂靠在北方人才广开分部(做859,到南头窑下车,大概20分钟就到了)。
带新的三方协议,如果是挂靠户口和档案,500元,以后每年大概是500左右的管理费,这个各个人才中心收费标准大致相同。
但有一个问题需要告诉大家,挂靠人才后,户口和档案是不能分离的,因为此时你的户口为集体户口,依照天津市规定,两者不能分离。
如果你所签的外地公司,要求你把档案调到公司去,那此时你只能把该集体户口转成个人户口后,档案才可以跟户口分离。办理途径是,把此时你的集体户口转到亲友或同学家。或者本身买房,户口转到房产下,但是这个可能性很小。原因是我们多数买不起房。
2.落户亲友家
如果你所签的单位不是天津的,那么你就得跟人才中心签约,这样在名义上你也是在天津就业了。依照天津市规定,你可以要求亲友家所在地派出所给你落户,但是规定上可以,不代表你实际办理时就会一帆风顺,这需要多和派出所民警套套近乎。具体就不说了。
落户亲友家需要的手续如下
本人:身份证,报到证(原件以及复印件),就业协议(原件,以及第一页和第二页的复印件),单位接收证明,毕业证原件。
单位接收证明格式如下:
接收证明:
某某同志是我单位接收的2007届应届毕业生,现为我单位正式职工,因我单位无集体户口,故同意该同志投靠亲友户籍。
单位名称,公章
朋友:户口本、身份证、房本,同意接收的证明
同意接收的证明格式如下:
申请:
我叫某某,出生年月日,现住址,现同意同学或朋友某某(括弧内介绍某某情况,生日、住址、单位、学历)落户于现住址(详细写现住址)
本人签字盖章
最后,对于党组织关系,这个可以直接让学院开介绍信到你要去工作的单位,然后就可提组织档案到公司。不需要走人才中心转一圈。
2009年3月10日 星期二
facebook和iphoto'09的完美结合
这两个东西真不错,在iphoto里面命名后的照片,直接可以在iphoto的facebook接口传到facebook上面去,而且两者是互通的,也就是说在iphoto修改的tags可以用在facebook上面,在facebook上面修改的tags也可以应用在iphoto中。在iphoto里面给人物命名以后,上传到facebook的照片也可以显示人名(当鼠标放在头像上),很强大呵呵。。。
facebook的这个iphoto插件是这个人开发的,看看他是怎么写的。
Behind the scenes with the new Facebook features in Apple’s iPhoto ’09
Srinivas Narayanan 的博文 2009年1月30日 9:43
Apple recently announced that the new Faces feature converts iPhoto '09 name tags to Facebook name tags. Then they and their friends can view those photos in Facebook, and if other friends are tagged in Facebook, those tags will sync back to iPhoto ’09. This integration makes it really easy for Mac users to share and connect with others, which is central to what Facebook is all about as well.
Engineers crave to work on things that are impactful and touch a lot of people. I joined Facebook three months ago knowing that I’d have such opportunities. Little did I know that my first project, helping bring Facebook features to Apple’s iPhoto ’09, would allow me to make an impact for Facebook so soon. To see my work at Macworld was a nice bonus!
Technically speaking, this feature is a part of Facebook Connect and the APIs it provides. An interesting aspect of this particular feature is that it is designed to be bi-directional. This means one can modify photos in iPhoto ’09 or on Facebook and the changes will be reflected in both places. To support this bi-directional integration, we enhanced the photos APIs to help iPhoto ’09 determine when name tags are added on Facebook, keep them in sync with the iPhoto ’09 application, and provide familiar Facebook privacy controls to allow users to share these photos with the appropriate set of people.
As a new engineer working on this project, I quickly experienced first-hand what many people told me about Facebook – it’s a place that has extremely smart and passionate people who are given the freedom to make the right decisions. The project had a great start thanks to Tracy Chou and the Connect team. It was an amazing experience to build on what they started and have my first project be something so substantive and prominent. It helped me realize the incredible opportunity one has at Facebook to help make the world more open and connected.
Srinivas, a new engineer at Facebook, can’t wait to have pictures of his New Year revelry be shared to Facebook using iPhoto ’09.
facebook里面的人都是天才阿,呵呵,好好向他们学习。。。
附一张facebook办公室的照片,都是Mac Book:
facebook的这个iphoto插件是这个人开发的,看看他是怎么写的。
Behind the scenes with the new Facebook features in Apple’s iPhoto ’09
Srinivas Narayanan 的博文 2009年1月30日 9:43
Apple recently announced that the new Faces feature converts iPhoto '09 name tags to Facebook name tags. Then they and their friends can view those photos in Facebook, and if other friends are tagged in Facebook, those tags will sync back to iPhoto ’09. This integration makes it really easy for Mac users to share and connect with others, which is central to what Facebook is all about as well.
Engineers crave to work on things that are impactful and touch a lot of people. I joined Facebook three months ago knowing that I’d have such opportunities. Little did I know that my first project, helping bring Facebook features to Apple’s iPhoto ’09, would allow me to make an impact for Facebook so soon. To see my work at Macworld was a nice bonus!
Technically speaking, this feature is a part of Facebook Connect and the APIs it provides. An interesting aspect of this particular feature is that it is designed to be bi-directional. This means one can modify photos in iPhoto ’09 or on Facebook and the changes will be reflected in both places. To support this bi-directional integration, we enhanced the photos APIs to help iPhoto ’09 determine when name tags are added on Facebook, keep them in sync with the iPhoto ’09 application, and provide familiar Facebook privacy controls to allow users to share these photos with the appropriate set of people.
As a new engineer working on this project, I quickly experienced first-hand what many people told me about Facebook – it’s a place that has extremely smart and passionate people who are given the freedom to make the right decisions. The project had a great start thanks to Tracy Chou and the Connect team. It was an amazing experience to build on what they started and have my first project be something so substantive and prominent. It helped me realize the incredible opportunity one has at Facebook to help make the world more open and connected.
Srinivas, a new engineer at Facebook, can’t wait to have pictures of his New Year revelry be shared to Facebook using iPhoto ’09.
facebook里面的人都是天才阿,呵呵,好好向他们学习。。。
附一张facebook办公室的照片,都是Mac Book:
什么是Thrift
Thrift是一个为了扩展跨语言服务的一个开源项目,它允许你在一个文件里面进行简单的定义,从而定义你自己的数据类型和服务接口。编译器用刚才的那个文件,产生的代码可以很容易的就构建一个RPC客户端或者服务器,用来使不同语言之间无缝得进行沟通。
Thrift支持的语言:C++,C#,Cocoa,Erlang,Haskell,Java,OCaml,Perl,PHP,Python,Ruby,Smalltalk。
Thrift支持和不支持的特性:
支持:namespaces,constants,enumerations,structs,container(set,map,list),asyn invocation,exception...
不支持:循环structs,struct继承,多态,继承,null return
Thrift支持的语言:C++,C#,Cocoa,Erlang,Haskell,Java,OCaml,Perl,PHP,Python,Ruby,Smalltalk。
Thrift支持和不支持的特性:
支持:namespaces,constants,enumerations,structs,container(set,map,list),asyn invocation,exception...
不支持:循环structs,struct继承,多态,继承,null return
最近的事情比较多~
工作前个星期终于定下来了,回头有空写写找工作的历程吧。解决了这块心病,发现接下来反而更忙了。。。
一方面每天都要去评测中心做毕业设计,貌似我做的是一个安全等级评测系统。。。每天早上7点起床,晚上7点回到寝室,经常在公车上睡着,发现自己的睡觉水平提高了不少。。。
庆祥给我布置了挺多任务了,也算是为我将来进公司后就能立马上手打好基础吧,列一下最紧要学习的一些东西:
1,Google BigTable...一种新的数据结构
2,Google MapReduce 分布式的东东
3,Facebook的Thrift和Cassandra,貌似现在已经是Apache的开源项目了。
4,python和perl,最近看了一下python的语法,很喜欢,有看一定要学学python,听说美国用的比较多,对python最直观的感觉就是一个开源项目,叫做Chandler,大家可以搜搜,而且还出了一本书,专门讲这个软件的。。。
还有就是对Cacoa相当的感兴趣,弄了一本《Cocoa 入门-使用Objective-c》在学呢。开始的时候挺不习惯objective-c的语法习惯,相信以后会慢慢熟练起来,然后就可以在可爱的苹果下面写有趣的程序了~
最近在看几本书:《国富论》、《龙行天下》、《纸变钱的游戏》、《我们相信变革》、《唐骏正传》、《挑战百万年薪》~挺有意思的几本书,大家有时间可以看看。。。
有个朋友找我去学车,不知道有没有时间,回头和导师商量一下。还有公司现在正在做的项目网址www.iqwer.com,还在开发中,有兴趣测试和使用的和我说一声,我会发邀请~,挺好的一个项目,不过还需要好好完善~
一方面每天都要去评测中心做毕业设计,貌似我做的是一个安全等级评测系统。。。每天早上7点起床,晚上7点回到寝室,经常在公车上睡着,发现自己的睡觉水平提高了不少。。。
庆祥给我布置了挺多任务了,也算是为我将来进公司后就能立马上手打好基础吧,列一下最紧要学习的一些东西:
1,Google BigTable...一种新的数据结构
2,Google MapReduce 分布式的东东
3,Facebook的Thrift和Cassandra,貌似现在已经是Apache的开源项目了。
4,python和perl,最近看了一下python的语法,很喜欢,有看一定要学学python,听说美国用的比较多,对python最直观的感觉就是一个开源项目,叫做Chandler,大家可以搜搜,而且还出了一本书,专门讲这个软件的。。。
还有就是对Cacoa相当的感兴趣,弄了一本《Cocoa 入门-使用Objective-c》在学呢。开始的时候挺不习惯objective-c的语法习惯,相信以后会慢慢熟练起来,然后就可以在可爱的苹果下面写有趣的程序了~
最近在看几本书:《国富论》、《龙行天下》、《纸变钱的游戏》、《我们相信变革》、《唐骏正传》、《挑战百万年薪》~挺有意思的几本书,大家有时间可以看看。。。
有个朋友找我去学车,不知道有没有时间,回头和导师商量一下。还有公司现在正在做的项目网址www.iqwer.com,还在开发中,有兴趣测试和使用的和我说一声,我会发邀请~,挺好的一个项目,不过还需要好好完善~
2009年3月9日 星期一
机器中毒了。。。
今天在食堂吃完午饭回公司,发现刚刚还好好的机器突然慢的要死,查看了一下进程,发现多了SafeSys这样的莫名进程,直接杀掉,不过机器还是很慢,重启,无果。。。
用浏览器搜索,只要搜索关键字时卡巴斯基或者SafeSys,浏览器直接被关掉,shit。。。
然后只好进入安全模式,把每个盘符下面的SafeSys.exe和AutoRun.inf删掉,然后新建同名的文件夹,设置成隐藏,重启,然后就可以用浏览器搜索杀毒软件了,下了个“微点”,重查杀了一遍,搞定。。
估计是U盘中毒了,哎。。。我已经很注意了专门弄了一个不外借的U盘了,没想到就借出去了一次,结果就栽了。。。以后大家要注意,装杀毒软件还是比较保险的。。。
还有就是对那些写病毒的人,丫的不要以为自己能编个病毒很强,有空多做做正事。。。
用浏览器搜索,只要搜索关键字时卡巴斯基或者SafeSys,浏览器直接被关掉,shit。。。
然后只好进入安全模式,把每个盘符下面的SafeSys.exe和AutoRun.inf删掉,然后新建同名的文件夹,设置成隐藏,重启,然后就可以用浏览器搜索杀毒软件了,下了个“微点”,重查杀了一遍,搞定。。
估计是U盘中毒了,哎。。。我已经很注意了专门弄了一个不外借的U盘了,没想到就借出去了一次,结果就栽了。。。以后大家要注意,装杀毒软件还是比较保险的。。。
还有就是对那些写病毒的人,丫的不要以为自己能编个病毒很强,有空多做做正事。。。
2009年3月7日 星期六
訂閱:
文章 (Atom)