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

[经验分享] Memcached 与 Wowza 项目的集成

[复制链接]

尚未签到

发表于 2015-11-19 07:13:16 | 显示全部楼层 |阅读模式
集群是 Wowza 部署的必修课,集群环境下的 Wowza 插件所依赖到的缓存采用 Memcached 作为解决方案是个不错的选择。本文简单介绍如何在 Wowza 插件开发项目中加入 Memcached 支持,关于 Memcached 数据原子性、Memcached 的集群以及 java 进程内缓存暂时没有涉及。本文示例代码用的是 spymemcached 2.8.4。
        本文在博客《使用 spring 集成 dbcp 数据库连接池到 Wowza 插件》示例项目的基础上对 Memcached 进行集成,该博客代码下载地址:http://download.iyunv.com/detail/defonds/7098633。
        1. 导入上篇博客示例代码
        将《使用 spring 集成 dbcp 数据库连接池到 Wowza 插件》的示例代码导入 Eclipse。关于 Eclipse 的 Wowza 插件的安装、Wowza 项目的新建及其调试、spring 的集成请参阅以前博客。成功导入后 Eclipse 下的视图如下:
DSC0000.jpg
        2. Memcached 公共接口实现
        新建 CacheService 接口代码如下:
package com.defonds.wms.module.cache.service;
public interface CacheService {
void init(); // while server start up, do something
void destory(); // while server shut down, do something
void put(String key, Object object); // set new value to cache
void remove(String key); // remove from cache
Object get(String key); // get current value from cache
boolean exist(String key); // check whether the key already exist in cache or not
}
        CacheService 的实现类 CacheServiceImpl 代码:
package com.defonds.wms.module.cache.service;
import java.io.IOException;
import java.net.InetSocketAddress;
import net.spy.memcached.MemcachedClient;
import com.wowza.wms.logging.WMSLogger;
import com.wowza.wms.logging.WMSLoggerFactory;
public class CacheServiceImpl implements CacheService {
private static final WMSLogger logger = WMSLoggerFactory.getInstance().getLoggerObj(CacheServiceImpl.class.getName());
private MemcachedClient memcachedClient = null;
private String memcachedIpAddress; // memcached server ip address
private Integer memcachedServerPort; // memcached server port
private Integer memcachedObjectExpiration; // objects set to memcached will be expired after 86400 (86400 = 60 * 60 * 24) seconds
@Override
public void init() {
logger.debug("CacheServiceImpl--init--debug--memcachedIpAddress=" + this.memcachedIpAddress
+ ";memcachedServerPort=" + this.memcachedServerPort
+ ";memcachedObjectExpiration=" + this.memcachedObjectExpiration);
try {
logger.debug("CacheServiceImpl--init--debug--MemcachedClient will init now");
this.memcachedClient = new MemcachedClient(new InetSocketAddress(this.memcachedIpAddress, this.memcachedServerPort));
} catch (IOException e) {
logger.error(e.getMessage(), e);
}
}
@Override
public void destory() {
this.memcachedClient.shutdown();
}
@Override
public void put(String key, Object object) {
try {
this.memcachedClient.set(key, this.memcachedObjectExpiration, object);
} catch (Exception e) {
logger.error("CacheServiceImpl--put-- insert object into memcached failed!");
}
}
@Override
public void remove(String key) {
try {
this.memcachedClient.delete(key);
} catch (Exception e) {
logger.error("CacheServiceImpl--remove-- delete object from memcached failed!");
}
}
@Override
public Object get(String key) {
Object object = null;
try {
object = this.memcachedClient.get(key);
} catch (Exception e) {
logger.error("CacheServiceImpl--get-- select object from memcached failed!");
}
return object;
}
@Override
public boolean exist(String key) {
Object object = null;
try {
object = this.memcachedClient.get(key);
} catch (Exception e) {
logger.error("CacheServiceImpl--exist-- select object from memcached failed!");
}
if (object == null) {
return false;
} else {
return true;
}
}
public void setMemcachedIpAddress(String memcachedIpAddress) {
this.memcachedIpAddress = memcachedIpAddress;
}
public void setMemcachedServerPort(Integer memcachedServerPort) {
this.memcachedServerPort = memcachedServerPort;
}
public void setMemcachedObjectExpiration(Integer memcachedObjectExpiration) {
this.memcachedObjectExpiration = memcachedObjectExpiration;
}
}
        3. 加入 spymemcached 支持
        将 spymemcached-2.8.4.jar 添加到 defonds-server-module 的编译环境和运行环境(运行环境就是 %wowza%/lib)。
        4. 配置 Memcached
        就是 Memcached 服务器地址、端口号以及数据保鲜期的配置。config.properties 中加入以下:
memcached.ip.address=172.21.0.117
memcached.server.port=12111
#objects set to memcached will be expired after 86400 (86400 = 60 * 60 * 24) seconds
memcached.object.expiration=86400
        5. 使用 spring 对 CacheService 进行管理
        我们把 CacheService 对象的生命周期全权交给 spring 进行管理。spring-context.xml 中的 beans 标签下加入以下配置:
<!-- cache related -->
<bean id=&quot;cacheService&quot; class=&quot;com.defonds.wms.module.cache.service.CacheServiceImpl&quot; init-method=&quot;init&quot;>
<property name=&quot;memcachedIpAddress&quot; value=&quot;${memcached.ip.address}&quot;></property>
<property name=&quot;memcachedServerPort&quot; value=&quot;${memcached.server.port}&quot;></property>
<property name=&quot;memcachedObjectExpiration&quot; value=&quot;${memcached.object.expiration}&quot;></property>
</bean>
        6. 部署并调试
        使用文本编辑器打开 Wowza 安装目录下的 conf 文件夹中的 Server.xml,在 ServerListeners 标签下添加以下内容:
<ServerListener>
<BaseClass>com.defonds.wms.module.server.DefondsWowzaServerListener</BaseClass>
</ServerListener>
        在任何插件类中加入如下代码:
ApplicationContext appCtx = ApplicationContextUtils.getApplicationContext();  
// test cache
String testFlag = &quot;now&quot; + System.currentTimeMillis();
CacheService cacheService = (CacheService) appCtx.getBean(&quot;cacheService&quot;);
if (!cacheService.exist(&quot;somekey&quot;)) {
cacheService.put(&quot;somekey&quot;, testFlag);
}
logger.debug(&quot;DefondsWowzaServerListener-onServerInit-memcached-somekey=&quot; + cacheService.get(&quot;somekey&quot;));
        执行该插件类后打印接过如下:
DEBUG server comment - DefondsWowzaServerListener-onServerInit-memcached-somekey=now1398324763217
        测试成功。
        注意:关于 Wowza 插件的 log
        Wowza 的 logging 实现采用的是 Apache 的 log4j logging 工具,log4j 的配置文件在 %wowza%/conf/log4j.properties,默认配置如下:
log4j.rootCategory=INFO, stdout, serverAccess, serverError
        如果我们想在开发时对插件项目中的一些自定义类中修改日志级别,只能在 %wowza%/conf/log4j.properties 进行修改,在其他地方另加自定义 log4j.properties Wowza 是不认的。比如我们要将 CacheServiceImpl 的日志级别修改为 DEBUG,那么应该在 %wowza%/conf/log4j.properties 文件末尾添加一行:
log4j.logger.com.defonds.wms.module.cache.service=DEBUG
        然后重启 Wowza 即可。
        另外,CacheServiceImpl 里获取 WMSLogger 一定要用这种写法:
        WMSLogger logger = WMSLoggerFactory.getInstance().getLoggerObj(CacheServiceImpl.class.getName());
        其他的诸如 WMSLoggerFactory.getLogger(CacheServiceImpl.class) 或者 WMSLoggerFactory.getLogger(null) 虽然也能输出日志,但 log4j.logger.com.defonds.wms.module.cache.service=DEBUG 对其日志级别的修改无效。
        后记
        本资源源码已上传 csdn 资源,有兴趣的朋友可以去下载一下,链接地址:http://download.iyunv.com/detail/defonds/7245973。   
版权声明:本文为博主原创文章,未经博主允许不得转载。

运维网声明 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-140853-1-1.html 上篇帖子: Linux下搭建Memcached缓存系统 下篇帖子: Memcached服务器安装
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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