设为首页 收藏本站
查看: 1057|回复: 0

[经验分享] suse linux下memcached的安装配置小记

[复制链接]

尚未签到

发表于 2018-12-24 11:56:37 | 显示全部楼层 |阅读模式
  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(&quot;&quot; + i, &quot;Hello!&quot;);
  /**
  * 从memcached缓存中按key值取对象
  * */
  String result = (String) memCachedClient.get(&quot;&quot; + i);
  System.out.println(String.format(&quot;set( %d ): %s&quot;, i, success));
  System.out.println(String.format(&quot;get( %d ): %s&quot;, i, result));
  }
  }
  }




运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-655272-1-1.html 上篇帖子: 使用Memcached提高.NET应用程序的性能 下篇帖子: NOSQL系列
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表