mysql乱码问题 配置mysql utf-8编码

在编译安装mysql 时可能会忘记配置mysql 编码为utf-8,下面的例子mysql版本为mysql-5.5.29

修改my.cnf

[mysqld]
collation-server = utf8_unicode_ci
init-connect='SET NAMES utf8'
character-set-server = utf8

阅读全文

linux 安装 python Django mysql-python

安装python

下载python

http://www.python.org/

./configure –prefix=/home/admin/python

指定安装目录

安装django

https://www.djangoproject.com/download/

 

下载后解压进入目录

python setup.py install

安装mysql-python

你需要gcc,setuptools,mysql,zlib

详情可见readme

http://sourceforge.net/projects/mysql-python/files/mysql-python/1.2.3/

阅读全文

volatile 使用场景

什么是volatile变量

java语言提供了一种削弱的同步机制,即volatile变量,用来确保将变量的更新操作通知到其他线程。当把变量声明为volatile类型后,编译器与运行时都会注意到这个变量是共享的,因此不会将该变量上的操作与其他内存操作一起重排序。volatile变量不会被缓存在寄存器或者对其他处理器不可见的地方,因此在读取volatile类型的变量时总会返回最新写入的值。

另外,在旧的内存模型,volatile变量不能被重排序,但它们可能会受到非volatile变量重排序的影响。这破坏了volatile字段做为一个线程到另一个线程的信号条件的有效性。在新的内存模型中volatile变量一样不能被重排序,但将不会受到非volatile变量的影响。

 

为什么要使用volatile

volatile变量修饰符如果使用恰当的话,它比synchronized的使用和执行成本会更低,因为它不会引起线程上下文的切换和调度。

 

应用volatile变量的三个原则

(1)写入变量不依赖此变量的值,或者只有一个线程修改此变量

(2)变量的状态不需要与其它变量共同参与不变约束

(3)访问变量不需要加锁

 

例1


	volatile boolean shutdown;

	public void shutdown() {
		shutdown = true;
	}

	public void dowork() {
		while (!shutdown) {
			// do something
		}
	}

这是一个适用的场景。

 

例2


	public static int race = 0;

	public static void increase() {
		race++;
	}

	public static int getRace() {
		return race;
	}

这是一个不能用volatile关键字的例子

简单的说

加锁机制既可以确保可见性又可以确保原子性,而volatile变量只能确保可见性。

 

参考

Older Material (for the memory model historians among you)
http://www.cs.umd.edu/~pugh/java/memoryModel/index.html#older

What does volatile do?
http://www.cs.umd.edu/~pugh/java/memoryModel/jsr-133-faq.html#volatile

Java并发编程实战
http://book.douban.com/subject/10484692/

linux vim快捷键大全 速查

vim快捷键图

一. 移动:
h,j,k,l: 左,下,上,右。
w: 下一个词的词首。
e:下一个词的词尾。
b:上一个词的词首。
<>: v 模式选中后进行缩进。

阅读全文

pl/sql 链接 oracle

1. 从Oracle下载 Instant Client,不需要安装,解压到一个目录中即可。
例如在本机上解压到了E:\OracleClient下边,实际上Oracle客户端的路径是E:\OracleClient\instantclient_11_2

下载地址 http://www.oracle.com/technetwork/database/features/instant-client/index.html
2. 配置操作系统环境变量

TNS_ADMIN=E:\OracleClient\instantclient_11_2

3.进入instantclient_11_2文件夹,新建一个名为tnsnames.ora文件,

文件内容如下:

test =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.2)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = test)
)
)

注意database name 和ip 根据实际填写。
4.安装PL/SQL Developer
5.进入PL/SQL Developer,(虽不能登录,但可以进入) 选择Tools->Preferences,在Oracle Home、OCI Library两栏中分别填入Oracle客户端的路径和OCI文件的路径,我在这两个选项中填写的内容是“E:\OracleClient\instantclient_11_2”和“E:\OracleClient\instantclient_11_2\oci.dll”。
6.重启一下PL/SQL,登录。

编译Hadoop eclipse plugin

Hadoop 版本 1.0.4

编辑${HADOOP_HOME}/src/contrib/build-contrib.xml

<project name="hadoopbuildcontrib" xmlns:ivy="antlib:org.apache.ivy.ant">
<property name="eclipse.home" location="/home/Develop/eclipse"/>
<property name="version" value="1.0.4"/>
<property name="name" value="${ant.project.name}"/>
<property name="root" value="${basedir}"/>
<property name="hadoop.root" location="${root}/../../../"/>
<!-- Load all the default properties, and any the user wants -->
<!-- to contribute (without having to type -D or edit this file -->

</project>

编辑%Hadoop_HOME%\src\contrib\eclipse-plugin\build.xml

 <path id="eclipse-sdk-jars">
 <fileset dir="${eclipse.home}/plugins/">
 <include name="org.eclipse.ui*.jar"/>
 <include name="org.eclipse.jdt*.jar"/>
 <include name="org.eclipse.core*.jar"/>
 <include name="org.eclipse.equinox*.jar"/>
 <include name="org.eclipse.debug*.jar"/>
 <include name="org.eclipse.osgi*.jar"/>
 <include name="org.eclipse.swt*.jar"/>
 <include name="org.eclipse.jface*.jar"/>

<include name="org.eclipse.team.cvs.ssh2*.jar"/>
 <include name="com.jcraft.jsch*.jar"/>
 </fileset>
 <fileset dir="../../../">
 <include name="hadoop*.jar"/>
 </fileset>
 </path>
<pre>

然后ant

如有提示找不到hadoop-core-1.0.4,commons-cli-1.2.jar,只需复制到对应目录即可

Parallels Desktop 8 pd8 破解 无限试用

因版权问题现在不提供破解方法

安装php memcached扩展支持

需要安装的插件

http://pecl.php.net/package/memcached

https://launchpad.net/libmemcached/+download

先安装libmemcached

./configure –prefix=/usr/local/libmemcached  –with-memcached
make && make install

如果遇到libmemcached编译报错请看
libmemcached 编译错误

阅读全文

linux nginx gzip 配置详解

先看示例

gzip on;
gzip_buffers 4 16k;
gzip_comp_level 2;
gzip_min_length 1000;
gzip_http_version 1.1;
gzip_proxied expired no-cache no-store private auth;
gzip_types text/plain application/xml;
gzip_disable "MSIE [1-6]\.";
gzip_vary off;

打开nginx.conf找到gzip修改就可以了。

阅读全文

删除wordpress侧边栏的功能

找到网站wordpress安装目录,在wp-includes/default-widgets.php中,在此文件里搜索查找<li>标签里带有rss2_url、comments_rss2_url、wordpress.org,就可以找到了。

return top