标签归档:hash

Redis学习

从网上下了个redis命令参数中文版。照着敲了一遍命令。让后找php的api敲了一遍。 1.string setbit 对key所储存的字符串值,设置或清除指定偏移量上的位(bit)。 setnx setex 2.hash HSET key field value 将哈希表key中的域field的值设为value。 hgetall 结果列表为: key1 val1 key2 val2 ……. hkeys hvals 3.list lpush xx yy 向队列key值 插入值yy lpushx 需要队列存在才能插入成功 lpop blpop rpoplpush brpoplpush ltrim lrange $r->lRem($key,’find’,-2); //从右边删除2个value为find的元素 linsert hot after … 继续阅读

发表在 Nosql | 标签为 , , | 留下评论

php hash漏洞

php 5.3.8以及之前版本,均存在致命的内核漏洞。利用此漏洞,仅使用一台PC机,即可在短时间内击垮数十、数百台PHP服务器。目前互联网上很多网站均存在此问题。 相关参考文章http://www.lvtao.net/html/1790.html?p=4   为测试某个php网站是否存在此漏洞,可使用以下命令(windows和linux均可)wget -O -  -S   –post-file=post.txt http://xxxx.com post.txt下载地址:http://blog.iterse.com/download/post.txt wget for windows : http://downloads.sourceforge.net/gnuwin32/wget-1.11.4-1-bin.zip 如果响应很慢(超过15s)说明此网站存在漏洞,可发送多个请求(只要连续的请求数超过网站服务器cpu个数)将其击垮为502

发表在 默认分类 | 标签为 , , | 4 条评论

Tokyo Tyrant

网上的一些资料的整理:   TTserver参数设置详解:http://blog.163.com/chenxiaodong_2009/blog/static/129082330201022481421504/ 利用Tokyo Tyrant构建兼容Memcached协议、支持故障转移、高并发的分布式key-value持久存储系统:http://blog.s135.com/post/362/   ln -s /usr/local/tokyocabinet-1.4.47/lib/libtokyocabinet.so.9 /usr/local/lib/libtokyocabinet.so.9 tokyotyrant优点:1.用Tokyo Cabinet读写速度非常快,是Berkeley DB 等 DBM 的几倍。2.故障转移 (双机互为主辅模式)3.日志文件体积小4.任何Memcached客户端均可直接调用tokyotyrant。还可以通过HTTP方式调用 curl -X PUT http://192.168.0.249:1978/key -d "value"curl http://192.168.0.249:1978/keycurl -X DELETE http://192.168.0.249:1978/key 缺点:1.存进去的数据不到满了不会过期 2.当我们从中取数据时,会是一个序列化的字符串,没有自动反序列化处理3.32位操作系统 Tokyo Cabinet 数据库单个文件不能超过2G 启动:ttserver -host 192.168.0.249 -port 1978 -thnum 8 -dmn … 继续阅读

发表在 服务器端 | 标签为 , , | 留下评论

面试题

索引设计原则,主从读写分离,垂直分区,水平分区,负载均衡,反向代理,分布式部署,nginx,lighttpd 索引设计原则 http://dev.firnow.com/course/7_databases/mysql/Mysqljs/20090820/168951.html 1. 最合适的索引列是在查询语句中的条件部分经常出现的列。2. 使用唯一值索引。即列值尽可能具有唯一性。3. 使用短索引。如需索引字符串,尽量使用尽可能短的但是能区分列值的长度。较短的列值意味着,缓存中能存放更多的值,也就增加的命中率。4. 利用最左前缀。如果创建了多列索引(n列),则其最作列集也可作为索引来使用。5. 不要过度索引。修改表时数据库需要更新索引,过度的索引不但耗费额外的空间,而且降低了修改更新操作的效率。6. InnoDB中数据按默认顺序存放,尽量设置主键。如果设置了主键,则innodb按主键顺序存放;如果没有,则按唯一索引存放。7. Btree(默认)适合范围搜索,Hash适合单值搜索。   主从读写分离、垂直分区、水平分区 http://itsoul.javaeye.com/blog/777208 1、读写分离:当数据库访问量还不是很大的时候,我们可以适当增加服务器,数据库主从复制的方式将读写分离; (可用mysqlproxy) 2、垂直分区:当写入操作一旦增加的时候,那么主从数据库将花更多的时间的放在数据同步上,这个时候服务器也是不堪重负的;那么就有了数据的垂直分区,数据的垂直分区思路是将写入操作比较频繁的数据表,如用户表_user,或者订单表_orders,那么我们就可以把这个两个表分离出来,放在不同的服务器,如果这两个表和其他表存在联表查询,那么就只能把原来的sql语句给拆分了,先查询一个表,在查询另一个,虽然说这个会消耗更过性能,但比起那种大量数据同步,负担还是减轻了不少; 3、水平分区:但是往往事情不尽人意,可能采取垂直分区能撑一段时间,由于网站太火了,访问量又每日100w,一下子蹦到了1000w,这个时候可以采取数据的进行分离,我们可以根据user的Id不同进行分配,如采取%2的形式,或者%10的形式,当然这种形式对以后的扩展有了很大的限制,当我由10个分区增加到20个的时候,所有的数据都得重新分区,那么将是一个的很庞大的计算量;以下提供几种常见的算法:   哈希算法:就是采用user_id%的方式;   范围:可以根据user_id字符值范围分区,如1-1000为一区,1001-2000则是另一个区等;   映射关系:就是将user_id存在的所对应的分区放在数据库中保存,当用户操作时先去查询所在分区,再进行操作; 对于以上几种扩展方式,读写分离主要是操作上的扩展,垂直分区主要是对写入较频繁数据表的分离,水平分区主要是数据分离; 其他参考: http://fanqiang.chinaunix.net/db/mysql/2006-05-08/4135.shtml   负载均衡:http://wuchengyi.javaeye.com/blog/670260 反向代理:http://baike.baidu.com/view/1165595.htm 可以用apache或者nginx作为反向代理服务器  

发表在 心情随笔 | 标签为 , , | 留下评论

【转】Uchome 所用程序通用方法汇总

function_common.php 引用: //SQL ADDSLASHESfunction saddslashes($string) return $string; //取消HTML代码function shtmlspecialchars($string)   return $string; //字符串解密加密function authcode($string, $operation = ‘DECODE’, $key = ”, $expiry = 0) //清空cookiefunction clearcookie() //cookie设置function ssetcookie($var, $value, $life=0) //数据库连接function dbconnect() //获取在线IPfunction getonlineip($format=0) //判断当前用户登录状态function checkauth() //获取用户app列表function getuserapp($uid=0) //获取到表名function tname($name) //对话框function showmessage($msgkey, … 继续阅读

发表在 Uchome | 标签为 , , , , , | 留下评论

php加密技术

主要有crypt(),md5(),sha1()这3个函数。还有加密扩展库mcrypt和mhash 1.crypt()(单向加密,安全性较低) String crypt(String str[,String salt]); salt参数为加密时使用的干扰串,如果省去,会随机生成一个干扰串,该函数支持4种算法和长度。 2.md5() String md5(String str[,bool raw_output]); raw_output参数默认为false,如果为真,函数返回一个二进制形式的密文。 3.sha1()     secure hash algorithm(安全哈希算法) String sha1(String str[,bool raw_output]); 函数返回一个40位的16进制数,如果raw_output为真,则返回一个20位的2进制数。                                                   Mcrypt库 libmcrypt.dll 到windows(php.ini配置的initDir 目录),然后配置php.ini文件中的extension=libmcrypt.dll; mcypt支持20多种加密算法和8种加密模式。 mcypt_list_algorithms()和mcypt_list_modes()都返回一个数组,可以用foreach循环出来查看mcypt支持的加密算法和模式。 <?php $en_dir = mcrypt_list_algorithms() ; echo "Mcrypt支持的算法有:"; foreach($en_dir as $en_value){    … 继续阅读

发表在 Php | 标签为 , | 留下评论