百科问答小站 logo
百科问答小站 font logo



阿里云linux服务器怎么配置memcache


user avatar   网友的相关建议: 
      一、什么是memcache
memcache是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨大的hash表,它能够用来存储各种格式的数据,包括图像、视频、文件以及数据库检索的结果等
二、libevent介绍
libevent是一个事件触发的网络库,适用于windows、linux、bsd等多种平台,内部使用select、epoll、kqueue等系统调用管理事件机制。著名的用于apache的php缓存库memcached据说也是libevent based,而且libevent在使用上可以做到跨平台
三、准备工作
下载:memcache:http://www.danga.com/memcached/dist/memcached-1.2.2.tar.gz
下载:http://www.monkey.org/~provos/libevent-1.3.tar.gz
四、安装过程
1、卸载低版本的libevent
#ls -al /usr/lib |grep libevent
lrwxrwxrwx 1 root root libevent-1.1a.so.1 -> libevent-1.1a.so.1.0.2
-rwxr-xr-x 1 root root libevent-1.1a.so.1.0.2
查看当前libevent版本,如果版本低于1.3,建议先卸载
#rpm -e libevent --nodeps
卸载libevent,
#ls -al /usr/lib |grep libevent
再次查看,卸载成功
2、安装libevent
#tar zxvf libevent-1.3.tar.gz
解压libevent
#cd libevent-1.3
#./configure --prefix=/usr
#make
#make install
配置安装libevent到/usr目录下
#ls -al /usr/lib |grep libevent
lrwxrwxrwx 1 root root 21 11?? 12 17:38 libevent-1.2.so.1 -> libevent-1.2.so.1.0.3
-rwxr-xr-x 1 root root 263546 11?? 12 17:38 libevent-1.2.so.1.0.3
-rw-r–r– 1 root root 454156 11?? 12 17:38 libevent.a
-rwxr-xr-x 1 root root 811 11?? 12 17:38 libevent.la
lrwxrwxrwx 1 root root 21 11?? 12 17:38 libevent.so -> libevent-1.2.so.1.0.3
再此查看,安装libevent1.3版本成功
3、安装memcached,同时需要安装中指定libevent的安装位置
#tar zxvf memcached-1.2.6.tar.gz
#cd memcached-1.2.6
解压进入mamcache目录
#./configure --with-libevent=/usr/
#make
#make install
安装完成后会把memcached放到 /usr/local/bin/memcached
#ls -al /usr/local/bin/memcached
-rwxr-xr-x 1 root root 137986 11?? 12 17:39 /usr/local/bin/memcached
查看memcache安装成功
五、memcached的基本设置
#/usr/local/bin/memcached -d -m 2000 -u root -p 12000 -c 256 -P ./memcached.pid
1.启动Memcache的服务器端:
# /usr/local/bin/memcached -d -m 10 -u root -l 192.168.0.200 -p 12000 -c 256 -P /tmp/memcached.pid
-d选项是启动一个守护进程,
-m是分配给Memcache使用的内存数量,单位是MB,我这里是10MB,
-u是运行Memcache的用户,我这里是root,
-l是监听的服务器IP地址,如果有多个地址的话,我这里指定了服务器的IP地址192.168.0.200,
-p是设置Memcache监听的端口,我这里设置了12000,最好是1024以上的端口,
-c选项是最大运行的并发连接数,默认是1024,我这里设置了256,按照你服务器的负载量来设定,
-P是设置保存Memcache的pid文件,我这里是保存在 /tmp/memcached.pid,

也可以启动多个守护进程,不过端口不能重复。

六:客户端测试
1、下载java_memcached-release_2.5.1.zip
2、创建一个java project,将java_memcached-release_2.5.1.jar包引用。
3、在main函数中,创建2个类,如下

package com.danga.MemCached;
import java.io.Serializable;
import com.danga.MemCached.MemCachedClient;
import com.danga.MemCached.SockIOPool;

public class TestObj implements Serializable {

private static final long serialVersionUID = 1L;
private String name;
private Long id;

public TestObj()
{
}
public Long getId()
{
return id;
}
public void setId(Long id)
{
this.id = id;
}
public String getName()
{
return name;
}
public void setName(String name)
{
this.name = name;
}

public String toString()
{
return "id:"+this.getId()+";name:"+this.getName();
}
}

package com.danga.MemCached;
import java.io.Serializable;
import com.danga.MemCached.MemCachedClient;
import com.danga.MemCached.SockIOPool;

public class MemcacheTest
{

//create a static client as most installs only need
// a single instance
protected static MemCachedClient mcc = new MemCachedClient();

// set up connection pool once at class load
static
{

// server list and weights
String[] servers ={"192.168.0.226:12000"};

Integer[] weights = { 3 };

// grab an instance of our connection pool
SockIOPool pool = SockIOPool.getInstance();

// set the servers and the weights
pool.setServers( servers );
pool.setWeights( weights );

// set some basic pool settings
// 5 initial, 5 min, and 250 max conns
// and set the max idle time for a conn
// to 6 hours
pool.setInitConn( 5 );
pool.setMinConn( 5 );
pool.setMaxConn( 250 );
pool.setMaxIdle( 1000 * 60 * 60 * 6 );

// set the sleep for the maint thread
// it will wake up every x seconds and
// maintain the pool size
pool.setMaintSleep( 30 );

// set some TCP settings
// disable nagle
// set the read timeout to 3 secs
// and don't set a connect timeout
pool.setNagle( false );
pool.setSocketTO( 3000 );
pool.setSocketConnectTO( 0 );

// initialize the connection pool
pool.initialize();

// lets set some compression on for the client
// compress anything larger than 64k
mcc.setCompressEnable( true );
mcc.setCompressThreshold( 64 * 1024 );
}

public static void bulidCache()
{
mcc.set( "foo", "This is a test String" );
TestObj obj = new TestObj();
obj.setId(new Long(1));
obj.setName("test");
mcc.set("testObj", obj);
}

// from here on down, you can call any of the client calls
public static void output()
{
//
String bar = (String) mcc.get( "foo" );
System.out.println(bar);
TestObj obj = (TestObj)mcc.get("testObj");
System.out.println("ID : "+obj.getId()+" "+"Name : "+obj.getName());
}

public static void main(String[] args)
{
bulidCache();
output();
}

}

4、运行结果
This is a test String
ID : 1
Name : test

memcache配置成功~~~~~~~~~~~~~~~~~~~~



相关阿里云话题

阿里云服务器的mysql数据库,里面有多个数据表,请问怎么远程连接
阿里云服务器,用的官方推荐的镜像盘作为系统,系统默认已装好PHP环境和FTP,但是FTP上传不上去。
阿里云esc服务器怎么配置多个网站
阿里云云服务器登陆计时器过期怎么办
阿里云服务器,GGtbviewer.exe这个进程不停地出现,占用CUP和内存,如何解决啊?
win10远程连接阿里云window系统服务器时,不能连接,显示出现内部错误,
有谁做过阿里云服务器? 哪位行行好愿意教我怎么用phpStudy搭建服务器
阿里云ecs云服务器,用的阿里的一键安装配置环境,为什么ftp登陆不上?
请问前辈高手,西部数码云服务器和阿里云的云服务器哪个稳定,快速,备案哪个容易些,谢谢
阿里云服务器的公网ip可是进到别的网站?急急急急 十万火急
为什么在公司内网无法SSH连接到外网的阿里云服务器
阿里云esc怎么配置ftp服务器
阿里云的域名可以绑定其他服务器吗
阿里云服务器 windows server 2012上部署了tomcat6.0+jdk1.6+mysql5.6项目打开连不上数据库
阿里云里面的香港服务器也需要备案吗
阿里云晕服务器没有快照可以恢复前几天数据吗
我申请了阿里云的云服务器和虚拟主机,数据库也有了,现在要用SQL2008连接到我的数据库中,为什么
甘肃网站域名不能备案,必须要用本地服务器或者阿里云有其他办法吗
阿里云ECS服务器安装WDCP安装discuz论坛,但是打开打开网页提示500错误,多次错误后科技进入网站。
在阿里云服务器上面上传java项目,运行环境可以用电脑上的jdk和tocmet吗? 管用吗?



前一个讨论
阿里云ecs服务器怎么查询xftp登陆密码
下一个讨论
阿里云服务器的mysql数据库,里面有多个数据表,请问怎么远程连接





© 2024-09-20 - tinynew.org. All Rights Reserved.
© 2024-09-20 - tinynew.org. 保留所有权利