CentOS6.4 PHP5.2添加ZendDebug扩展 完美支持Zend Studio10.5

之前一段时间用的开发环境是wamp,这个集成包的优点是:安装简单,操作便捷,缺点是:每次重装系统后都要重新安装配置环境,并且和线上的lamp环境不一致,有时本地运行正常的代码上到线上却出现莫名其妙的问题,所以考虑重新为本地安装lamp开发环境,即:windows8+VMware Workstation 10 +CentOs6.4 64位 + lamp + Zend Studio10.5

安装完成后发现无法为PHP添加ZendDebug扩展,查看资料才知道zend官方在PHP5.2之后就不再对ZendDebug提供更新支持,所以如果要用Zend Studio + ZendDebug调试代码的话PHP的版本必须在5.3以下(当然也可以用Zend Studio+Xdebug 组合),无奈只有编译PHP5.2.*老版本安装lamp。

ZendDebug下载:linux64位 linux32位 Zend官方下载

ZendDebug配置过程如下:

[root@E /]#yum -y install php-devel

选择对应版本的ZendDebug.so文件放至:/usr/lib64/php/modules/目录下

(因为本机安装的为PHP5.2.1.7,所以选择ZendDebugger-20110410-linux-glibc23-x86_64/ZendDebugger-20110410-linux-glibc23-x86_64/5_2_x_comp/ZendDebugger.so)

在php.ini中最下方添加配置:

[root@E /]#vi /etc/php.ini
[Zend]
zend_extension=/usr/lib64/php/modules/ZendDebugger.so  //扩展文件绝对路径
zend_debugger.allow_hosts=127.0.0.1/32,192.168.0.0/16   //设置你允许访问的主机IP范围
zend_debugger.expose_remotely=always

保存

[root@E /]#service httpd restart   //重启apache

用phpinfo查看,未发现ZendDebugger扩展,说明加载失败。

用php -v查看,有报错:

[root@E /]# php -v
Failed loading /usr/lib64/php/modules/ZendDebugger.so: libssl.so.0.9.8: cannot open shared object file: No such file or directory
PHP 5.3.3 (cli) (built: Nov 22 2013 10:59:29)
Copyright (c) 1997-2010 The PHP Group
Zend Engine v2.3.0, Copyright (c) 1998-2010 Zend Technologies
原因:因为最新的linux发行版本 libssl 和 libcrypto 已升级到1.0.0,而系统中找不到 libssl.so.0.9.8文件

解决:只要创建相应的软链接即可

[root@E /]# ll /usr/lib64/libssl*
-rwxr-xr-x. 1 root root 221568 2 nov  23 2013 /usr/lib64/libssl3.so
lrwxrwxrwx. 1 root root 16 11 nov 26 19:31 /usr/lib64/libssl.so -> libssl.so.1.0.1e
lrwxrwxrwx. 1 root root 16 11 nov 26 19:31 /usr/lib64/libssl.so.10 -> libssl.so.1.0.1e
-rwxr-xr-x. 1 root root 436984 12 nov  4 2013 /usr/lib64/libssl.so.1.0.1e
建立软连接:
[root@E /]#ln -s /usr/lib64/libssl.so.1.0.1e /usr/lib64/libssl.so.0.9.8

[root@E /]# ll /usr/lib64/libcrypto*
lrwxrwxrwx. 1 root root 19 11 nov 26 19:31 /usr/lib64/libcrypto.so -> libcrypto.so.1.0.1e
lrwxrwxrwx. 1 root root 19 11 nov 26 19:31 /usr/lib64/libcrypto.so.10 -> libcrypto.so.1.0.1e
-rwxr-xr-x. 1 root root 1946880 12 nov  4 2013 /usr/lib64/libcrypto.so.1.0.1e
建立软连接:
[root@E /]#ln -s /usr/lib64/libcrypto.so.1.0.1e /usr/lib64/libcrypto.so.0.9.8
[root@E /]#service httpd restart   //重启apache
[root@E /]# php -v
Zend Debugger requires Zend Engine API version 220060519.
The Zend Engine API version 220090626 which is installed, is newer.
Contact Zend Technologies at http://www.zend.com/ for a later version of Zend Debugger.

PHP 5.3.3 (cli) (built: Jul 12 2013 20:35:47)
Copyright (c) 1997-2010 The PHP Group
Zend Engine v2.3.0, Copyright (c) 1998-2010 Zend Technologies

报错解决

用phpinfo查看ZendDebug扩展加载成功!

Zend Studio10.5测试,调试正常!

转载请注明出处:怡然之乐 – FineYi

参考资料:stackoverflow  forums.zend.com CSDN

CentOS6.4 LAMP环境为PHP添加Xdebug扩展手记

CentOS6.4 LAMP环境为PHP添加Xdebug扩展手记

之前一直用Zend Studio结合Zend debug+ Firefox+toolbar组合跟踪、调试代码,用起来非常方便。但是Zend官方对zend debug在PHP5.2之后就不再提供支持。目前PHP已更新到5.4,所以就不能再用zend debug调试代码,Xdebug扩展也可以实现类似zend debug的功能。现提供在linux下为PHP添加Xdebug扩展的方法。

当前环境:CentOS6.4 64位 / PHP Version 5.3.3

安装依赖:
[root@E /]# yum -y install gcc automake autoconf libtool make wget php-devel

下载
http://xdebug.org/files/
最新版本:2.2.3
[root@E /]# cd /home/soft
[root@E /]# wget install http://xdebug.org/files/xdebug-2.2.3.tgz
[root@E /]# tar -zxvf xdebug-2.2.3.tgz
[root@E /]# cd xdebug-2.2.3/

查看phpize和php-config路径
[root@E xdebug-2.2.3]# whereis phpize php-config
phpize: /usr/bin/phpize /usr/share/man/man1/phpize.1.gz
php-config: /usr/bin/php-config /usr/share/man/man1/php-config.1.gz

接着执行:
[root@E /]# /usr/bin/phpize  ./configure --enable-xdebug --with-php-config=/usr/bin/php-config

无报错的话执行
[root@E /]# make
在当前目录会生成./modules/xdebug.so
复制到php扩展目录
[root@E xdebug-2.2.3]# cp modules/xdebug.so /usr/lib64/php/modules/

修改php.ini
[root@E modules]# vi /etc/php.ini
在底部加入:
[Xdebug]
zend_extension="/usr/lib64/php/modules/xdebug.so"
xdebug.profiler_enable = on
xdebug.default_enable = on
xdebug.trace_output_dir="/tmp/xdebug"
xdebug.trace_output_name = trace.%c.%p
xdebug.profiler_output_dir="/tmp/xdebug"
xdebug.profiler_output_name="cachegrind.out.%s

重启apache:
[root@E modules]# service httpd restart

phpinfo查看:

Xdebug

Xdebug扩展添加成功!

转载请注明出处:怡然之乐 – FineYi

参考资料:xdebug file  XMSND  SinaBlog

sublime text2 配置SVN

sublime text2是一款绝对性感、好用的编辑器,用用你就知道…

使用Package Control组件安装

安装package control组件,然后直接在线安装:

按Ctrl+` 调出console
粘贴以下代码到底部命令行并回车:

重启Sublime Text 2。
如果在Perferences->package settings中看到package control这一项,则安装成功。

如果这种方法不能安装成功,可以下载文件手动安装,点击下载
用Package Control安装插件的方法:

按下Ctrl+Shift+P调出命令面板,输入install 调出 Install Package 选项并回车

install
然后在列表中选中要安装的插件,建议装TortoiseSVN 。

svn

配置SVN

打开 preference –> Browse package  然后找到文件夹名称为 TortoiseSVN 的,点进去,用本编辑器打开 TortoiseSVN.sublime-settings 这个文件,把这个地址改成你的SVN安装地址。

seting
配置成功后,就可以用了
ssss
快捷键
alt+u 更新 svn_update
alt+c 提交 svn_commit
官方下载:sublime text2
sublimetxet插件

 

 

sphinx(coreseek)导入搜狗词库

    来自官网的介绍:

    Coreseek 是一款中文全文检索/搜索软件,以GPLv2许可协议开源发布,基于Sphinx研发并独立发布,专攻中文搜索和信息处理领域,适用于行业/垂直搜索、论坛/站内搜索、数据库搜索、文档/文献检索、信息检索、数据挖掘等应用场景。

    Coreseek安装配置:

    或者
2. Coreseek安装请参考官方文档:
    官方提供的文档写的很清晰,安装、配置、调试过程不再叙述。
    PS:安装之前请务必先装好 操作系统基础开发库及mysql依赖库以支持mysql数据源和xml数据源,否则后面的编译安装可能会失败。

    词库转换:

    Coreseek自带的词库大概1M多,词库量比较小,不能满足公司项目的需要,所以需要扩展词库。
    搜狗词库提供丰富的个性化词库,可以去下载你需要的词库包。
    下载地址:http://pinyin.sogou.com/dict/
搜狗包的格式为scel,不能直接读取,需用工具转换为txt格式。
    工具下载地址:
    用工具转换为“无拼音纯单词”格式的文本文件。如下图:
    20130531124906
    转换之后的文件内容格式如下
阿巴嘎旗政府

阿坝交通局
阿坝旅游局
阿坝人事局
阿坝县公安局
阿坝邮政局
阿坝州委
阿尔山市委

需要转换为mmseg需要的词典格式,如下

阿巴嘎旗政府 1
x:1
阿坝交通局 1
x:1
阿坝旅游局 1
x:1
阿坝人事局 1
x:1
阿坝县公安局 1
x:1
阿坝邮政局 1
x:1
 
    写了个在线转换工具放到SAE上了Coreseek/Sphinx词库转换
    PS:转换过程中新词库要和老词库合并,并排重。

    新生成的词库放到mmseg3/etc/目录下:
#/usr/local/mmseg3/etc/unigram.txt
生成索引
#/usr/local/mmseg3/bin/mmseg -u /usr/local/mmseg3/etc/unigram.txt
重命名为uni.lib
#mv unigram.txt.lib uni.lib
重启sphinx
# cd /usr/local/coreseek/
#./bin/searchd  -c etc/sphinx.conf –stop
#./bin/searchd  -c etc/sphinx.conf
完事…
ps:新词库生成后务必要重启sphinx,否则索引不生效。
    参考资料:无聊记
    转载请注明出处:怡然之乐 – FineYi

Hello Universe!

1.PHP中session默认有效期是1440秒(24分钟)。

2.面向对象程序设计的三大思想是:封装、继承、多态。

3.多态,就是指基类和派生类中可以有同名但功能完全不同的函数或方法。

4. …

web集群的PHP Session共享 解决方案

Web集群PHP Session共享解决方案:

 

1. 基于Cookie的Session共享

把用户相关的Session信息存储到浏览器的Cookie中,也称为客户端Session。

采用Flash Cookie、URL重写的方式传递Session信息的方案也可以归为此类。

缺点:只能够存储字符串、数值等基本类型的数据;Cookie大小存在限制;安全性;带宽及数据解压缩、网络传输性能问题。

 

2. 基于NFS的Session共享

通过NFS方式来实现各台服务器间的Session共享,各台服务器只需要mount共享服务器的存储Session的磁盘即可,实现较为简单。

但NFS对高并发读写的性能并不高,在硬盘I/O性能和网络带宽上存在较大瓶颈,尤其是对于Session这样的小文件的频繁读写操作。

基于磁盘阵列/SAN/NAS等共享存储的方案道理也类似。

 

3. 基于数据库的Session共享

把Session信息存储到数据库表(比如mysql的内存表Heap),这样实现不同应用服务器间Session信息的共享.

缺点:由于数据库服务器相对于应用服务器更难扩展且资源更为宝贵,在高并发的Web应用中,最大的性能瓶颈通常在于数据库服务器。因此如果将 Session存储到数据库表,频繁的增加、删除、查询操作很容易造成数据库表争用及加锁,最终影响业务。

 

4.基于Memcached/Tokyo Tyrant/Redis 等Key-Value DB的Session共享

这种方案的可扩展性高,读写速度快,推荐使用。

Memcached实现PHP Session共享,有memcache和memcached两个扩展可用。

1).使用memcache扩展的配置,在php.ini中修改,

session.save_handler = memcache
session.save_path = “tcp://127.0.0.1:11211″

使用多个 memcached server 时用逗号”,”隔开,并且和 Memcache::addServer() 文档中说明的一样,可以带额外的参数”persistent”、”weight”、”timeout”、”retry_interval” 等等,类似这样的:”tcp://host1:port1persistent=1&weight=2,tcp://host2:port2″

2).使用Memcached扩展的配置,在php.ini中修改

session.save_handler = memcached
session.save_path = “127.0.0.1:11211,127.0.0.1:11212″

 

参考资料:无名小站

linux下用C语言连接mysql实现增删改查

公司内部培训,领导要求在linux环境下用c语言连接mysql数据库,实现增删改查功能,做一个demo。

环境:Red Hat Enterprise Linux 4

①安装mysql

②创建数据库表:bbb

CREATE TABLE `bbb` (
`id` int(11) NOT NULL auto_increment,
`name2` varchar(20) default NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM  DEFAULT CHARSET=utf8

C的代码:

#include 
#include 
#include 
#include  
/*定义数据库连接需要的宏*/
#define HOST "localhost"
#define USERNAME "root"
#define PASSWORD "ictspace"
#define DATABASE "test"

/*执行传入的sql語句*/
void exe_sql(char* sql) {
	MYSQL my_connection; /*这是一个数据库连接*/
	int res; /*执行sql語句后的返回标志*/
	/*初始化mysql连接my_connection*/
	mysql_init(&my_connection);
	if (mysql_real_connect(&my_connection, HOST, USERNAME, PASSWORD,DATABASE, 0, NULL, 0)) {
		/*连接成功*/
		printf("数据库执行exe_sql连接成功!n");
		mysql_query(&my_connection, "set names utf8");
		/*mysql_query函数执行传入的sql語句,返回一个int值,如果为0,执行成功*/
		res = mysql_query(&my_connection, sql);
		if (res) {/*执行失败了*/
			printf("Error: mysql_query !\n");
			mysql_close(&my_connection);
		} else {/*执行成功了*/
			/*mysql_affected_rows返回执行sql后影响的行数*/
			printf("%d 行受到影响!\n", mysql_affected_rows(&my_connection));
			mysql_close(&my_connection);
		}
	} else {
		/*数据库连接失败*/
		printf("数据库执行exe_sql连接失败!\n");
	}
}

/*执行传入的sql語句,并打印出查询結果*/
void query_sql(char* sql) {
	MYSQL my_connection; /*这是一个数据库连接*/
	int res; /*执行sql語句后的返回标志*/
	MYSQL_RES *res_ptr; /*指向查询结果的指针*/
	MYSQL_FIELD *field; /*字段结构指针*/
	MYSQL_ROW result_row; /*按行返回的查询信息*/
	int row, column; /*查询返回的行数和列数*/
	int i, j; /*只是控制循环的两个变量*/
	/*初始化mysql连接my_connection*/
	mysql_init(&my_connection);
	if (mysql_real_connect(&my_connection, HOST, USERNAME, PASSWORD,DATABASE, 0, NULL, 0)) {/*连接成功*/
		printf("数据库查询query_sql连接成功!\n");
		mysql_query(&my_connection, "set names utf8");
		/*执行传入的sql語句,返回一个int值,如果为0,证明語句执行成功*/
		res = mysql_query(&my_connection, sql);
		if (res) { /*执行失败*/
			printf("Error: mysql_query !\n");
			mysql_close(&my_connection);
		} else { 
			/*执行成功了*/
			/*将查询的結果给res_ptr*/
			res_ptr = mysql_store_result(&my_connection);
			/*如果结果不为空,就把结果print*/
			if (res_ptr) {
				/*取得結果的行数和*/
				column = mysql_num_fields(res_ptr);
				row = mysql_num_rows(res_ptr);
				printf("查询到 %lu 行 \n", row);
				/*输出結果的字段名*/
				for (i = 0; field = mysql_fetch_field(res_ptr); i++)
				printf("%s\t", field->name);
				printf("\n");
				/*按行输出結果*/
				for (i = 1; i < row; i++) {
					result_row = mysql_fetch_row(res_ptr);
					for (j = 0; j < column; j++)
					printf("%s\t", result_row[j]);
					printf("\n");
				}
			}
			mysql_close(&my_connection);
		}
	}
}

int main(int argc, char *argv[]) {
	char *query;
	/*插入操作*/
	char *exe = "insert into bbb values('','eee');";
	/*更新操作*/
	//char *exe = "update `bbb` set `name2` = 'zzz' where `id` = 10";
	/*删除操作*/
	//char *exe = "delete from bbb where `name2` = 'eee'";
	exe_sql(exe);
	/*测试查询*/
	query="select * from bbb;";
	query_sql(query);
	return 0;
}

编译命令:
gcc-o c_mysql_demo -g c_mysql_demo.c -I /usr/include/mysql/ -L /usr/lib/ -l mysqlclient

参数说明:

-I(大写的i) 表示要连接的头文件目录,因为使用了<mysql.h> ,-L表示要连接的库文件目录 -l(小写的L) 表示要连接的具体的库名称,在/usr/lib/ 下,有叫做libmysqlclient.so的库,指定具体的库的名字时,默认去掉头尾的lib和.so直接使用中间的mysqlclient
如果不用-I -L ,可能导致找不到头文件 或者 函数未定义的错误
by
无报错,编译成功。

查看表:
select

执行程序:
exe

再次查看表bbb:
select_2

数据插入成功!

更新、删除操作类似,只需改一下sql语句即可。