`

Memcached

 
阅读更多

Memcached服务端自动启动

 
经测试,要使得Memcached能够提供session共享服务,必须启动Memcached服务端为系统服务。本人较为初级,一般都是按向导安装的。
所以,要将其设为自动启动的服务也就困难了。

上网搜索了一下,结果,得到以下一些结果,做个记录:

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,

想开机自动启动的话,只需在/etc/rc.d/rc.local中加入一行,上面命令
有人用以下命令:
/usr/local/memcached/bin/memcached -d -m 20 -p 11211 -u apache
上面有些东西可以参考一下:即,ip不指定时,默认是本机,用户,最好选择是:apache 或 deamon
这样,也就是属于哪个用户的服务,由哪个用户启动。

 

2、较正规的方法:

To add a service to chkconfig you will normally need a couple of special comments below the shebang of a shell script:

Shell代码 复制代码 收藏代码
  1. #!/bin/sh   
  2. # chkconfig: - 55 45  
  3. # description:  The memcached daemon is a network memory cache service.   
  4. # processname: memcached  

 

After adding the lines to /etc/init.d/memcached you can then issue

chkconfig --add memcached
There are of course additional run levels a process can start at so to check that you would issue

chkconfig --list | grep "memcached"
A common run level for memcached would be

chkconfig --level 345 memcached on

说明:chkconfig --add memcached 用来添加memcached服务
chkconfig --list | grep "memcached" 检查服务是否添加
还可以简写为这样:
chkconfig  --list | grep mem

chkconfig --level 345 memcached on 设置运行级别。
建议:最好使用chkconfig --level 235 memcached on 这样的话与apache级别相同,即只要有apache,就有memcached

3、更复杂的做法,创建完美的启动脚本

网上找到以下两个脚本:

 

Shell代码 复制代码 收藏代码
  1. #!/bin/sh   
  2. #   
  3. # memcached:    MemCached Daemon   
  4. #   
  5. # chkconfig:    - 90 25  
  6. # description:  MemCached Daemon   
  7. #   
  8. # Source function library.   
  9. . /etc/rc.d/init.d/functions   
  10. . /etc/sysconfig/network   
  11. #[ ${NETWORKING} = "no" ] && exit 0  
  12. #[ -r /etc/sysconfig/dund ] || exit 0  
  13. #. /etc/sysconfig/dund   
  14. #[ -z "$DUNDARGS" ] && exit 0  
  15. start()   
  16. {   
  17.         echo -n $"Starting memcached: "  
  18.         daemon $MEMCACHED -u daemon -d -m 1024 -l 127.0.0.1 -p 11211  
  19.         echo   
  20. }   
  21. stop()   
  22. {   
  23.         echo -n $"Shutting down memcached: "  
  24.         killproc memcached   
  25.         echo   
  26. }   
  27. MEMCACHED="/usr/local/memcached/bin/memcached"  
  28. [ -f $MEMCACHED ] || exit 1  
  29. # See how we were called.   
  30. case "$1" in   
  31.   start)   
  32.         start   
  33.         ;;   
  34.   stop)   
  35.         stop   
  36.         ;;   
  37.   restart)   
  38.         stop   
  39.         sleep 3  
  40.         start   
  41.         ;;   
  42.     *)   
  43.         echo $"Usage: $0 {start|stop|restart}"  
  44.         exit 1  
  45. esac   
  46. exit 0  

  

Shell代码 复制代码 收藏代码
  1. #!/bin/sh   
  2. #   
  3. # memcached:    MemCached Daemon   
  4. #   
  5. # chkconfig:    - 90 25    
  6. # description:  MemCached Daemon   
  7. #   
  8. # Source function library.   
  9. . /etc/rc.d/init.d/functions   
  10. . /etc/sysconfig/network   
  11.     
  12. start()    
  13. {   
  14.         echo -n $"Starting memcached: "  
  15.         daemon /usr/local/bin/memcached -u daemon -d -m 4096 -l 10.10.10.220 -p 58728  
  16.         echo   
  17. }   
  18.     
  19. stop()    
  20. {   
  21.         echo -n $"Shutting down memcached: "  
  22.         killproc memcached    
  23.         echo   
  24. }   
  25.     
  26. [ -f /usr/local/bin/memcached ] || exit 0  
  27.     
  28. # See how we were called.   
  29. case "$1" in   
  30.   start)   
  31.         start   
  32.         ;;   
  33.   stop)   
  34.         stop   
  35.         ;;   
  36.   restart|reload)   
  37.         stop   
  38.         start   
  39.         ;;   
  40.   condrestart)   
  41.         stop   
  42.         start   
  43.         ;;   
  44.   *)   
  45.         echo $"Usage: $0 {start|stop|restart|reload|condrestart}"  
  46.         exit 1  
  47. esac   
  48. exit 0  

  


在上述指定目录创建了上述某一个脚本以后,就可以进行以下操作:
 
[root@crm ~]# chkconfig  --add memcached 
[root@crm ~]# chkconfig  --level 235  memcached  on
[root@crm ~]# chkconfig  --list | grep mem
memcached       0:off   1:off   2:on   3:on    4:off   5:on   6:off

接下来,可以用以下命令启动与停止 memcached

/etc/rc.d/init.d/memcached  start  
/etc/rc.d/init.d/memcached  stop
/etc/rc.d/init.d/memcached  restart
如: 
[root@crm ~]# /etc/rc.d/init.d/memcached  restart
Shutting down memcached: [  OK  ]
Starting memcached:      [  OK  ]

同时,还可以用:
service memcached start
这样的命令操作

然后,可以用ps命令查看进程信息。
[root@crm ~]# ps aux | grep mem
daemon   23781  0.0  0.2 13892 9860 ?  Ss 16:51:00  /.../memcached -u daemon -d -m 1024 -l 172.16.0.106 -p 11211

以上两个脚本前一个脚本中,对网络进行检查。其它都是针对服务启动与停止的命令提示设置。
有人说,复杂的脚本并不好懂,自己也不会写,却想要更完善的,怎么办?
那就到网上找高手的。最好的捷径就是到对应的RPM包中去找。(如果直接用RPM包安装,这些事情都不用做了)
当然,memcached多数情况下都是编译安装,因为,很多时候都是找不到对应的版本。
脚本中 # chkconfig: - 55 45 运行级别这一列参数用的是 -,这样,是不在脚本中写死,可以通过 chkconfig  --level 235  memcached  on 灵活设置。
最后就是,目前仍不了解
. /etc/sysconfig/network
#[ ${NETWORKING} = "no" ] && exit 0
#[ -r /etc/sysconfig/dund ] || exit 0
#. /etc/sysconfig/dund
#[ -z "$DUNDARGS" ] && exit 0
这一段的详细含义。需要进一步学习!

分享到:
评论

相关推荐

    memcached windows稳定版

    在终端(也即cmd命令界面)下输入 ‘c:\memcached\memcached.exe -d install’ 安装 3. 再输入: ‘c:\memcached\memcached.exe -d start’ 启动。NOTE: 以后memcached将作为windows的一个服务每次开机时自动启动...

    memcached安装软件 libevent magent memcached

    Memcached是一款高性能、分布式内存对象缓存系统,广泛应用于Web应用中,用于减轻数据库的负载。它通过在内存中存储数据来提供快速的数据访问,从而提高应用的性能。本篇文章将详细讲解如何安装和配置memcached,...

    memcached 64位 window

    标题"memcached 64位 window"指的是在Windows操作系统上运行的64位版本的Memcached缓存系统。Memcached是一种分布式内存对象缓存系统,广泛用于减轻数据库负载,提高Web应用的性能。由于是64位版本,这意味着它可以...

    php7 的memcached扩展php_memcached.dll扩展

    Memcached是一种分布式内存对象缓存系统,广泛应用于Web应用程序,以提高数据读取速度,减轻数据库负载。在PHP环境中,使用Memcached扩展可以方便地存储和检索数据,尤其适用于处理高并发场景。 `...

    hibernate-memcached包

    **hibernate-memcached包** 是一个专为Hibernate框架设计的扩展,目的是将流行的分布式内存缓存系统Memcached整合到Hibernate中,作为其二级缓存解决方案。在大型分布式应用中,缓存技术是提高性能的关键,特别是...

    memcached-1.5.11.tar.gz

    《深入理解Memcached:基于1.5.11版本的剖析》 Memcached,一个高性能、分布式的内存对象缓存系统,广泛应用于Web应用中,用于减轻数据库的负载,提高数据访问速度。本文将深入探讨Memcached的1.5.11版本,解析其...

    java_memcached-release_2.5.1.jar Memcache java jar 包

    Java Memcached是一个流行的Java客户端库,用于与Memcached缓存系统进行交互。Memcached是一种分布式内存对象缓存系统,常用于减轻数据库负载,提高Web应用的性能。在本例中,我们关注的是`java_memcached-release_...

    memcached+tomcat7共享session所需要的jar包

    标题中的“memcached+tomcat7共享session所需要的jar包”是指使用Memcached作为分布式缓存系统,实现Tomcat7服务器间的Session共享。这通常是为了在集群环境中解决Session复制或粘滞会话的问题,提高Web应用的可扩展...

    memcached-win-32/64-1.4.4-14

    memcached的基本设置: -p 监听的端口 -l 连接的IP地址, 默认是本机 -d start 启动memcached服务 -d restart 重起memcached服务 -d stop|shutdown 关闭正在运行的memcached服务 -d install 安装memcached服务 -d ...

    memcached数据完整迁移到redis

    标题 "memcached数据完整迁移到redis" 描述的是一个数据迁移的过程,从使用 memcached 存储的数据转换到使用 redis 存储。这个过程在 IT 领域中是常见的,因为不同的缓存系统有不同的特性和优势。让我们深入探讨这个...

    memcached安装包以及MemCachedClient

    **Memcached 安装与使用详解** Memcached 是一款高性能的分布式内存缓存系统,用于在Web应用中减轻数据库负载。它将数据存储在内存中,以键值对的形式提供快速访问,尤其适用于高并发场景。Memcached 使用简单,可...

    memcached 完整的项目,服务端(win) 客户端 包括jar包

    **Memcached 完整项目详解** Memcached 是一个高性能、分布式的内存对象缓存系统,用于在应用服务器之间共享数据,减少数据库负载。这个项目包含了 Memcached 的服务端(适用于 Windows)以及 Java 客户端,是开发...

    windows下memcached+memcached.dll 5.3.8

    标题中的“Windows下memcached+memcached.dll 5.3.8”指的是在Windows操作系统上安装和使用Memcached服务的场景,其中`memcached.dll 5.3.8`是Memcached服务器的一个特定版本的动态链接库文件。Memcached是一款高...

    memcached服务器端memcached.exe 下载

    标题“memcached服务器端memcached.exe 下载”指的是获取memcached服务端的可执行文件,`memcached.exe`是Windows环境下运行memcached服务的程序。这个绿色版的memcached意味着它无需安装,下载解压后即可直接运行,...

    memcached-win64-1.4.4-14.zip

    Memcached 是一个高性能、分布式内存对象缓存系统,它广泛应用于Web应用中,用来减轻数据库负载,提高数据访问速度。Memcached的设计理念是简单而快速,通过在内存中存储键值对来提供高速的数据访问。这里我们关注的...

    memcached-win32-1.4.4-14.zip

    标题"memcached-win32-1.4.4-14.zip"指的是Memcached的Windows 32位版本,版本号为1.4.4,构建编号14。这个压缩包是一个软件分发包,用于在32位Windows系统上部署和运行Memcached。 描述中提到,Memcached是一个...

    python-memcached python-memcached

    Python-memcached是Python语言的一个库,用于与Memcached缓存系统进行交互。Memcached是一种高性能、分布式内存对象缓存系统,广泛应用于Web应用中,用于减轻数据库的负载,提高数据访问速度。Python-memcached库则...

Global site tag (gtag.js) - Google Analytics