这次碰到个问题,写的php代码访问时总是超时,凭经验判断是数据库问题。
但是逐步调试下去,发现是mysql_real_escape_string导致超时。
后来才发现,php文档里写了,这样的函数是需要数据库连接的,我这个调用是在数据库连接建立之前,所以php一直尝试获取最近的连接,但是又没有,结果就超时了。
同样的问题存在mysql_开头的函数中。
另外的问题是mysql_insert_id没有返回值,发现是之前的insert操作执行后马上关闭了连接,导致再打开一个新连接再调用mysql_insert_id就会没有返回值。
所以mysql_insert_id应该与insert 语句使用同一个连接。
Continue reading mysql_函数引出的问题
这几天忙的手都打搅了,稀里糊涂的某个项目要用Perl,尝试了一下,windows下配置apache和Perl执行CGI还是很简单的。
首先要有Perl环境,每个perl cgi文件的顶部都有个路径
#!d:/perl/bin/perl.exe
这里就是说明使用哪里的perl引擎来执行此脚本,所以刚开始的同学很能copy个helloworld放在那里,结果运行报错,像apache日志里:The system cannot find the path specified. : couldn't create child process
这种情况下就要检查代码第一行与实际安装的Perl环境是否一致了。
windows下使用ActivePerl是最好的了。安装我没碰到什么问题,最好让其建立环境变量。
然后是Apache的配置:
也很简单,只要两点:
1 : AddHandler cgi-script .cgi .pl 这个是需要的
2:Options execCGI 这个也是需要的
将这两个设置配置到文件夹下,则可以和php handler同时使用。
另外较“普遍”的方式是使用
ScriptAlias /cgi-bin/ "D:/cgi-bin/" 需要反注释
AddHandler cgi-script .cgi .pl 需要反注释,在<IfModule mime_module>中
Options execCGI 在配置的文件夹中。
其中/cgi-bin/可以改为你想要的名字,这样做会将所有此apache服务的站点中以/cgi-bin/开头的请求转为D:/cgi-bin/中的cgi文件来执行,比如
apache配置了localhost:8001,localhost:8002两个站点,那么请求
localhost:8001/cgi-bin/test.pl -->执行D:/cgi-bin/test.pl
localhost:8002/cgi-bin/test.php -->执行D:/cgi-bin/test.php
localhost:8002/cgi-bin/test.html -->执行D:/cgi-bin/test.html
不管扩展名是什么,都认为是cgi脚本。
参见:
http://programmingnote.com/blog/?p=28 中文
http://www.thesitewizard.com/archive/addcgitoapache.shtml 这里最详细
Continue reading Perl web开发 windows下配置
使用bind作为dns server.
首先检查服务器是否已经安装bind: http://linux.vbird.org/linux_server/0350dns.php#what_software
rpm -qa | grep '^bind'
没有的话安装:
http://ftp.isc.org/isc/bind9/cur/9.7/doc/arm/Bv9ARM.html
cd /opt/zk
wget http://ftp.isc.org/isc/bind9/cur/9.7/bind-9.7.6-P2.tar.gz
tar zxvf bind-9.7.6-P2.tar.gz
cd bind-9.7.6-P2
./configure --prefix=/usr/local/named --enable-threads && make && make install
参见:
http://linux.vbird.org/linux_server/0350dns.php#what_software
http://www.cdnunion.com/htmldata/11/7/2006_04/DNSPeiZhi-BINDAnZhuangPeiZhiQuanGuoCheng107_1.html
Continue reading linux下dns server安装配置
安装:
cd /home/root
wget http://www.squid-cache.org/Versions/v3/3.1/squid-3.1.20.tar.gz
tar zxvf squid-3.1.20.tar.gz
cd squid-3.1.20
./configure --prefix=/usr/local/squid
make && make install
这个要说明一下,尝鲜不一定是好事,因为我此时先下了最新版本3.2.1安装,结果就报错,然后才转为安装3.1.20,一点问题都没有。这是经验之谈,最后那个版本号越大的越保险。
配置文档:
http://www.squid-cache.org/Doc/config
结合实际应用场景的原理解释:
http://www.cnblogs.com/PeterBi/archive/2011/03/25/1995228.html
反向代理,负载均衡集群配置:
http://www.ibm.com/developerworks/cn/linux/l-cn-squid/
上面的链接解决了我的疑惑,cache_peer 这个配置既可以配置兄弟代理服务器,也可以配置原始服务器。
看这个配置会明白很多:
cache_effective_user squid
cache_effective_group squid
######### 设定 squid 的主机名 , 如无此项 squid 将无法启动
visible_hostname squid1.nlc.gov.cn
############# 配置 squid 为加速模式 #################
http_port 80 accel vhost vport
icp_port 3130
##### 配置 squid2、squid3 为其邻居,当 squid1 在其缓存中没有找到请求的资源时,
通过 ICP 查询去其邻居中取得缓存
cache_peer squid2.ibm.com.cn sibling 80 3130
cache_peer squid3.ibm.com.cn sibling 80 3130
##### squid1 的三个父节点,originserver 参数指明是源服务器,
round-robin 参数指明 squid 通过轮询方式将请求分发到其中一台父节点;
squid 同时会对这些父节点的健康状态进行检查,如果父节点 down 了,
那么 squid 会从剩余的 origin 服务器中抓取数据
cache_peer 210.82.118.195 parent 8080 0 no-query originserver round-robin \
name=webServer1
cache_peer 192.168.76.226 parent 8080 0 no-query originserver round-robin \
name=webServer2
cache_peer 192.168.76.227 parent 8080 0 no-query originserver round-robin \
name=webServer3
#### 将 wenjin.cache.ibm.com.cn 域的请求通过 RR 轮询方式转发到三个父节点中的一个
cache_peer_domain webServer1 webServer2 webServer3 wenjin.cache.ibm.com.cn
##### 下面是一些访问控制、日志和缓存目录的设置
acl localnet src 192.168.76.223 192.168.76.224 192.168.76.225
acl all src 0.0.0.0/0.0.0.0
http_access allow all
icp_access allow localnet
cache_log /usr/local/squid/var/logs/cache.log
access_log /usr/local/squid/var/logs/access.log squid
cache_dir ufs /usr/local/squid/var/cache/ 1000 16 256
####### 对 squid 的一些优化 ###############
maximum_object_size 10240 KB ### 能缓存的最大对象为 10M
maximum_object_size_in_memory 512 KB ### 内存中缓存的最大对象 512K
cache_mem 256 MB ###squid 用于缓存的内存量
Squid安装设试命令:
1,初始化你在 squid.conf 里配置的 cache 目录
#/usr/local/squid/sbin/squid -z //初始化缓存空间
如果有错误提示,请检查你的 cache目录的权限。
2,对你的squid.conf 排错,即验证 squid.conf 的 语法和配置。
#/usr/local/squid/sbin/squid -k parse
如果squid.conf 有语法或配置错误,这里会返回提示你,如果没有返回,恭喜,可以尝试启动squid。
3,在前台启动squid,并输出启动过程。
#/usr/local/squid/sbin/squid -N -d1
如果有到 ready to server reques,恭喜,启动成功。
然后 ctrl + c,停止squid,并以后台运行的方式启动它。
其实这种方式打印的就是cache.log的内容
这前三步是验证你是否能运行squid的重要步骤
4,启动squid在后台运行。
#/usr/local/squid/sbin/squid -s
这时候可以 ps -A 来查看系统进程,可以看到俩个 squid 进程。
5,停止 squid
#/usr/local/squid/sbin/squid -k shutdown
这个不用解释吧。
6,重引导修改过的 squid.conf
#/usr/local/squid/sbin/squid -k reconfigure //载入新的配置文件
这个估计用的时候比较多,当你发现你的配置有不尽你意的时候,可以随时修改squid.conf,然后别忘记对你的 squid.conf排错,然后再执行此指令,即可让squid重新按照你的 squid.conf 来运行。
7./usr/local/squid/sbin/squid -k rotate 轮循日志
8,把squid添加到系统启动项
编辑 /etc/rc.d/rc.local
添加如下行: /usr/local/squid/sbin/squid -s
利用Runc脚本........
关于配置问题:
#设置cache 内存大小为1G
cache_mem 1000 MB
#设置cache_dir 地址,第一个数字参数不能小于cache_mem设置的大小,否则会出警告“WARNING cache_mem is larger than total disk cache space!”,所以设为1000。16,256表示第一级和第二级目录。设置完了需用 squid -z来使cache目录生效。
cache_dir ufs /var/spool/squid 1000 16 256
注意
acl localnet src 192.168.0.0/16 # RFC1918 possible internal network
/16不是指0-16,16是指netmask
测试:
例如我有个应用在局域网192.168.0.2:10080/appweb/
我这样配置
cache_peer 192.168.0.2 parent 10080 no-query originserver
那么我将我的浏览器启用代理,将其指向我配置的squid服务器和对应端口。
那么我访问www.google.com/appweb/
嘿嘿,访问的其实是192.168.0.2:10080/appweb/
因为这里配置缓存服务器是192.168.0.2:10080
然而要注意squid默认只是缓存get请求,如果www.google.com/appweb/有个post的ajax请求www.google.com/appweb/ajax的话,squid还是会找实际的www.google.com/appweb/ajax的。
查看日志:
tail -f /usr/local/squid/var/logs/access.log
日志意义:
http://wiki.squid-cache.org/SquidFaq/SquidLogs#access.log
http://blog.csdn.net/starxu85/article/details/3256469
发现日志里一个HIT也没有,晕!倒是有些TCP_REFRESH_UNMODIFIED/304
从浏览器中看,似乎TCP_REFRESH_UNMODIFIED/304对应的资源是命中的。X-Cache HIT from xxx.xxx.COM
搞不懂。
squid命中又有很多因素,它和http 请求状态(头部信息)有很大关系,另外带参数的get请求也是默认不缓存的。
另外测试squid,也可以配置一个dns服务器,然后使用浏览器来访问测试。
参见DNS server配置 http://kazge.com/archives/896.html。
参见:
http://blog.51yip.com/server/638.html squid cache 服务器端的安装,配置
http://blog.51yip.com/apachenginx/898.html apache利用mod_cache缓存图片等
http://blog.51yip.com/cache/618.html varnish cache 反向代理服务器和http加速器的安装和配置
http://www.cnblogs.com/sxwgf/archive/2012/03/10/2389470.html 浅谈Squid在图片存储架构中的应用
http://os.51cto.com/art/201009/225813.htm 巧用Squid的ACL和访问列表实现高效访问控制
Continue reading web缓存-squid
办公我目前还是使用的xp系统,桌面上一堆快捷方式,听说CLaunch比较好,就用了一下,感觉如下:
界面太简单,刚开始我都不知道怎么用,不知道怎么设置快捷键,设置界面拉长,结果有些部分看不见(在win7下没有这个问题)。
没有搜索功能!这个怎么会没有呢,要是有该多。
批量导入快捷方式不方便,我的做法是把桌面的快捷方式拖到Claunch中去,结果很多快捷方式导入无效(点击没作用),看来批量导入的效果不行,最后我还是一个个导入的。-----这个是由于这种方式的导入是指向拖进来的快捷方式,例如我在桌面上建个文件夹的快捷方式,将其拖入Claunch,这样导入的快捷方式是指向桌面这个快捷方式的快捷方式(有点拗口),如果你将桌面的快捷方式删除了,那么claunch中的快捷方式由于找不到这个文件所以就不起作用了。
有些快捷方式导入不了。例如skype,outlook这样形式的快捷方式,导入后不起作用。
我来讲一下怎样设置快捷键,这个网上讲得少:
以设置显示/隐藏 CLaunch主界面为例:
右键Claunch托盘图标,点击options,出现设置界面:

如上图所示,这里是设置显示主界面快捷键,红框中是要设置的快捷键(在键盘上按对应的键即可)。

如上图所示,这里是设置隐藏主界面快捷键,红框中是要设置的快捷键。
我也不太清楚Assigned key和Hot key的区别,反正大家看图,如果不照着做就不行。
这样就设置好了。
这里也顺便说说Vstart(音速启动):
我的系统安装后,它默认的快捷方式中文的都是乱码,我将其全部删除,然后再导入,又不是乱码了。
它主界面上有个搜索框,但是是网页搜索而不是我最想要的快捷方式搜索,它的快捷方式搜索要右键点击出搜索菜单项再来搜索,这样的设计真是厉害哈!
如果是win7用户这个东西基本就是鸡肋了。
Continue reading CLaunch和vstart
这次碰到个问题,我使用了一个span元素,样式定义为
line-height:1.5;
使用firebug查看,box高度并没有变化,但是其父元素的高度却增加了。
捣鼓了半天才明白,原来span默认是内联,内联元素的height和line-height不会对其box高度起作用。
但是line-height虽不影响本身,但是会影响最近的block显示的祖先元素box高度。(因为line-height定义是相邻行文字基线间的距离。)
height则不会影响本身和祖先元素。
如果将span设置为block显示,那么height和line-heigt将会影响到元素本身box高度。
还发现如果是html5 DOCTYPE效果不会一样,似乎高度要高一点。
然后看看字体,从英文排版到中文排版,line-height是一样的,不回因为字体改变而影响高度,但是主要的问题是安全的中文字体好看的真是没有。
目前公认最安全的是arial,兼顾中西,win和mac。但是arial也不是很好看,而且字体大小最好不要小于12px,否则看着像蚂蚁团,模糊不清。
参见:
http://www.cnblogs.com/rainman/archive/2011/08/05/2128068.html 深入理解CSS中的行高
http://dancewithnet.com/2009/11/22/default-web-font-style/ 默认Web字体样式
Continue reading 我来说说行高 line-height 和 内联 inline 以及字体