日期:2014-05-16  浏览次数:20817 次

linux下安装memcache

1.下载

http://www.monkey.org/~provos/libevent-2.0.12-stable.tar.gz

http://memcached.googlecode.com/files/memcached-1.4.5.tar.gz

?

2.安装

安装libevent

tar xvf libevent-2.0.12-stable.tar.gz

cd libevent-2.0.12-stable

./configure -prefix=/usr

make

make install

查看安装是否成功

ls -all /usr/lib | grep libevent

?

?

安装memcached

tar xvf memcached-1.4.5.tar.gz

cd memcached-1.4.5

./configure -with-libevent=/usr

make

make install

查看安装是否成功

ls -all/usr/local/bin/mem*

?

3.开防火墙,假设使用端口11211

?

vi /etc/sysconfig/iptables

添加

-A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 11211 -j ACCEPT

保存退出

重启服务使刚才的设置生效

service iptables restart

?

?

搞定

?

启动memcached

/usr/local/bin/memcached -d -m 128 -u root -l 192.168.49.130 -p 11211 -c 1024?-P /tmp/memcached.pid

参数说明

?

-d 启动一个守护进程

-m 分配给Memcache使用的内存数量(MB)

-u 运行Memcache的用户

-l 是监听的服务器IP地址

-p Memcache监听的端口

-c 最大运行的并发连接数,默认是1024

-P 设置保存Memcache的pid文件

?

?

关闭memcached

1.查询memcached的pid

cat /tmp/memcached.pid

显示22376

如果没指定-P参数,则先ps -A查看进程,找出memcached的pid,例如我这里显示的是

?

22182 ? ? ? ? ?00:00:00 memcached

?

2.kill pid

例如kill?22182

?

将memcached加入启动项

vi /etc/rc.d/rc.local

在最后加入启动命令

/usr/local/bin/memcached -d -m 128 -u root -l 192.168.49.130 -p 11211 -c 1024?-P /tmp/memcached.pid

保存退出

?

添加到服务

vim /etc/rc.d/rc.local

添加

/usr/local/bin/memcached -d -m 128 -u root -l 192.168.49.130 -p 11211 -c 1024?-P /tmp/memcached.pid

?

?

测试

?

package com.gary.test;

import com.danga.MemCached.MemCachedClient;
import com.danga.MemCached.SockIOPool;

public class TestMemcached {

	String[] servers = { "192.168.49.130:11211" };
	Integer[] weights = { 3 };
	
	MemCachedClient mcc = new MemCachedClient();
	SockIOPool pool = SockIOPool.getInstance();

	public TestMemcached() {
		init();
	}
	
	private void init(){
		pool.setServers(servers);
		pool.setWeights(weights);

		pool.setInitConn(5);
		pool.setMinConn(5);
		pool.setMaxConn(250);
		pool.setMaxIdle(30);

		pool.setMaintSleep(30);
		pool.initialize();
	}

	public void testPut() {
		for (int i = 1; i <= 3; i++) {
			// 如果以前存在,则不去更新
			boolean b = mcc.add("key" + i, "value" + i); 
			System.out.println("key" + i +" - result: " + b);
		}
	}

	public void testReplace() {
		// 如果key不存在,则返回flase,更新失败
		boolean b = mcc.replace("key2", "newValue");
		System.out.println("update " + b);
	}

	public void testGet() {
		Object obj = mcc.get("key2");
		System.out.println(obj);
	}
	
	public void testDelete() {
		Object key3 = mcc.get("key3");
		System.out.println("key3:" + key3);
		mcc.delete("key3");
		System.out.println("after delete");
		Object key3now = mcc.get("key3");
		System.out.println("key3 now:" + key3now);
	}
	
	
	public static void main(String args[]) {
		TestMemcached tm = new TestMemcached();
		tm.testPut();
		tm.testReplace();
		tm.testGet();
		tm.testDelete();
		//最后关闭池
		tm.pool.shutDown();
	}
}

?

?测试结果

?

key1 - result: true
key2 - result: true
key3 - result: true
update true
newValue
key3:value3
after delete
key3 now:null
?