suse linux下memcached的装置装备小记51CTO博客 - 牛牛娱乐

suse linux下memcached的装置装备小记51CTO博客

2019年04月02日14时29分44秒 | 作者: 振华 | 标签: 装置,装备,运用 | 浏览: 995

  Memcached 是一个高性能的分布式内存目标缓存体系,用于动态Web应用以减轻数据库负载。它经过在内存中缓存数据和目标来削减读取数据库的次数,从而将数据库负载大幅度下降,更好的分配资源,完成更快速拜访。

  Memcached运用了libevent来均衡任何数量的翻开链接,运用非堵塞的网络I/O,对内部目标完成引证计数, 运用自己的页块分配器和哈希表,因而虚拟内存不会发生碎片。

环境:SUSE LINUX ENTERPRISE SERVER 10 (64bit)
软件版别:libevent-2.0.10   memcached-1.4.5

一、装置Memcached
Memcached会用到libevent这个库来进行Socket的处理,所以先装置libevent。具体步骤如下:
 

1、装置libevent:

# tar zxvf libevent-2.0.10-stable.tar.gz

# cd libevent-2.0.10-stable

# ./configure -prefix=/usr(指定装置途径)

留意红框中的三个NO,首要是因为没有GCC和C、C++的编译环境,刺进SUSE LINUX 10的光盘运用YAST2指令装置相应的包即可。

# make

# make install

注:需求的包大致是
glibc-devel-2.4-31.74.1.x86_64.rpm
libmudflap-4.1.2_20070115-0.29.6.x86_64.rpm
gcc-4.1.2_20070115-0.29.6.x86_64.rpm
libstdc++-devel-4.1.2_20070115-0.29.6.x86_64.rpm
gcc-c++-4.1.2_20070115-0.29.6.x86_64.rpm

2、测验libevent是否装置成功

 

都已装置上了没问题。

 

3、装置memcached,一起需求指定libevent的装置方位:

# tar zxvf memcached-1.4.5.tar.gz

# cd  memcached-1.4.5

# ./configure -prefix=/usr  -with-libevent=/usr

# make

# make install

假如中心呈现报错,同上请仔细检查过错信息,依照过错信息提示来装备或许添加相应的库或许途径。

装置完成后会把memcached放到 /usr/local/bin/memcached途径下。

4、测验是否成功装置memcached:

5、发动Memcached的服务器端:

# /usr/local/bin/memcached -d -m 1000 -u root -l 192.168.1.252 -p 8990 -c 2000 -P /tmp/memcached.pid

-d选项是发动一个看护进程

-m是分配给Memcached运用的内存数量,单位是MB,我这儿是1000MB

-u是运转Memcached的用户,我这儿是root

-l是监听的服务器IP地址,我这儿指定服务器的IP地址192.168.1.252

-p是设置Memcached监听的端口,我这儿设置了8990,最好是1024以上的端口

-c选项是最大运转的并发连接数,默许是1024,我这儿设置了2000,依照你服务器的负载量来设定

-P是设置保存Memcached的pid文件,我这儿是保存在 /tmp/memcached.pid

假如要完毕Memcached进程,履行:

# kill cat /tmp/memcached.pid

也能够发动多个看护进程,不过端口不能重复。

6、发动Memcached的服务器端遇到的过错处理:
如图:
 

 

呈现这个过错需求咱们修正装备文件,能够如下操作:
 

处理办法:
# cd /etc/ld.so.conf.d/
# vi  berkeley-db.conf
输入/usr/local/db-5.2.28/lib保存
# vi libevent.conf
输入/usr/local/libevent-2.0.10-stable/lib保存
# ldconfig

再看正常发动了

7、再装备一下客户端就好了。

二、 memcached client for java 客户端
下载最新版的客户端程序包:java_memcached-release_2.5.1.zip,解压后,文件夹里找到java_memcached-release_2.5.1.jar,这个便是客户端的JAR包。将此JAR包添加到项目的构建途径里,则项目中就能够运用Memcached了。

示例代码:
import com.danga.MemCached.*;
public class MyCache {
    public static void main(String[] args) {
       /**

        * 初始化SockIOPool,办理memcached的连接池

        * */

       String[] servers = { "192.168.1.252:8990" };

       SockIOPool pool = SockIOPool.getInstance();

       pool.setServers(servers);

       pool.setFailover(true);

       pool.setInitConn(10);

       pool.setMinConn(5);

       pool.setMaxConn(250);

       pool.setMaintSleep(30);

       pool.setNagle(false);

       pool.setSocketTO(3000);

       pool.setAliveCheck(true);

       pool.initialize();       

       /**

        * 树立MemcachedClient实例

        * */

       MemCachedClient memCachedClient = new MemCachedClient();

       for (int i = 0; i < 1000; i++) {

           /**

            * 将目标加入到memcached缓存

            * */

           boolean success = memCachedClient.set("" + i, "Hello!");

           /**

            * 从memcached缓存中按key值取目标

            * */

           String result = (String) memCachedClient.get("" + i);

           System.out.println(String.format("set( %d ): %s", i, success));

           System.out.println(String.format("get( %d ): %s", i, result));

       }

    }

版权声明
本文来源于网络,版权归原作者所有,其内容与观点不代表牛牛娱乐立场。转载文章仅为传播更有价值的信息,如采编人员采编有误或者版权原因,请与我们联系,我们核实后立即修改或删除。

猜您喜欢的文章