首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Memcached ClassNotFound异常

Memcached ClassNotFound异常
EN

Stack Overflow用户
提问于 2013-08-05 21:15:25
回答 2查看 1.6K关注 0票数 0

所以我想我有点搞不懂memcached是怎么工作的。我正在使用不同的框架开发相同的API,所有这些框架都包含memcached ( java版本spymemcached)。当我在我的第一个框架上设置memcached时,它正常工作。现在我正在尝试将它合并到我所使用的第二个框架中,我一直得到一个ClassNotFoundException,它试图在我使用的第一个框架中找到一个类,因此不会缓存任何东西。也许有人能告诉我我逻辑上的缺陷。下面是两个类(因为我在不同的平台上构建相同的API,所以它们是相同的),core.Party类在第一个类中(在运行各自的应用程序时工作),pojo.PojoParty是其中一个,而我使用的第二个框架似乎没有连接到memcached。

下面是它发生的类的构造函数:

代码语言:javascript
复制
    package resources;

import health.TemplateHealthCheck;

import java.net.InetSocketAddress;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.Connection;
import java.sql.ResultSetMetaData;
import java.util.HashMap; 

import com.codahale.metrics.Gauge;
import com.codahale.metrics.Meter;
import com.codahale.metrics.MetricRegistry;
import com.codahale.metrics.Counter;
import com.codahale.metrics.RatioGauge;

import contextListener.MyAdminServletContextListener;

import pojo.PartyPojo;

import net.spy.memcached.MemcachedClient;

    public class DBConnection {

        public static Connection con;
        private static ResultSet resultSet;
        private static PreparedStatement ps;
        private static ResultSetMetaData meta;
        private static HashMap<String,PartyPojo> map;
        private static DBConnection connection;
        private static PartyPojo party;
        private static final InetSocketAddress isa= new InetSocketAddress("atom1.cisco.com",11211);
        private static MemcachedClient memcache;
        private static Meter hits = MyAdminServletContextListener.registry.meter(MetricRegistry.name("Meter",
                "get-hits")); 
        private static Meter calls = MyAdminServletContextListener.registry.meter(MetricRegistry.name("Meter",
                "get-calls"));
        private static Counter evictions = MyAdminServletContextListener.registry.counter(MetricRegistry.name("Counter",
                "Memcache-Evictions"));
        private static int getHits,getCalls;
        private final static int MAX_MEMCACHED_EXPIRATION=2505600;

        private DBConnection()
        {
            try 
            {
                map = new HashMap<String,PartyPojo>();
                Class.forName("com.mysql.jdbc.Driver");
                con = DriverManager.getConnection(
                        "jdbc:mysql://atom3.cisco.com:3306/reddb", "redteam",
                        "redteam");     
                //initialize memcache
                memcache   = new MemcachedClient(isa); //this line produces error
                //this is just a integer variable I was using to make sure my Meters were measuring correctly
                getHits = Integer.valueOf(DBConnection.memcache.getStats().get(DBConnection.isa).
                        get("get_hits"));
                getCalls = Integer.valueOf(DBConnection.memcache.getStats().get(DBConnection.isa).
                        get("cmd_get"));
                metricsRegistry();      
            }
            catch (Exception e)
            {
                e.printStackTrace();
            }
        }

下面是它试图到达的类,它不是第二个框架的一部分(这是来自第一个框架的pojo类):

代码语言:javascript
复制
    package core;

import java.io.Serializable;
import java.util.HashMap;

public class Party implements Serializable {


    /**
     * 
     */
    private static final long serialVersionUID = 1L;
    HashMap <String,String> partyInfo = new HashMap<String,String>();

    public HashMap<String,String> getPartyInfo() throws Exception
    {
        return partyInfo;
    }
 }

这是相同的类,但在这个项目中,我试图运行

代码语言:javascript
复制
    package pojo;

import java.io.Serializable;
import java.util.HashMap;

import javax.xml.bind.annotation.XmlAccessType;
import javax.xml.bind.annotation.XmlAccessorType;
import javax.xml.bind.annotation.XmlRootElement;
import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;

import org.eclipse.persistence.oxm.annotations.XmlPath;


@XmlRootElement(name="Party") 
@XmlAccessorType(XmlAccessType.FIELD)
public class PartyPojo implements Serializable {

    /**
     * 
     */
    private static final long serialVersionUID = -4892745279086305480L;
    /**
     * 
     */
    /**
     * 
     */
    @XmlPath(".")
    @XmlJavaTypeAdapter(MapAdapter.class)

    HashMap <String,String> partyInfo = new HashMap<String,String>();

    public HashMap<String,String> getPartyInfo() throws Exception
    {
        return partyInfo;
    }
 }

下面是堆栈跟踪:

代码语言:javascript
复制
 2013-08-05 15:54:39.810 INFO net.spy.memcached.MemcachedConnection:  Added {QA sa=atom1.cisco.com/173.36.62.251:11211, #Rops=0, #Wops=0, #iq=0, topRop=null, topWop=null, toWrite=0, interested=0} to connect queue
2013-08-05 15:54:39.847 INFO net.spy.memcached.MemcachedConnection:  Connection state changed for sun.nio.ch.SelectionKeyImpl@529762a
2013-08-05 15:54:40.120 WARN net.spy.memcached.transcoders.SerializingTranscoder:  Caught CNFE decoding 434 bytes of data
java.lang.ClassNotFoundException: core.Party
    at java.net.URLClassLoader$1.run(Unknown Source)
    at java.net.URLClassLoader$1.run(Unknown Source)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(Unknown Source)
    at java.lang.ClassLoader.loadClass(Unknown Source)
    at sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source)
    at java.lang.ClassLoader.loadClass(Unknown Source)
    at java.lang.Class.forName0(Native Method)
    at java.lang.Class.forName(Unknown Source)
    at java.io.ObjectInputStream.resolveClass(Unknown Source)
    at java.io.ObjectInputStream.readNonProxyDesc(Unknown Source)
    at java.io.ObjectInputStream.readClassDesc(Unknown Source)
    at java.io.ObjectInputStream.readOrdinaryObject(Unknown Source)
    at java.io.ObjectInputStream.readObject0(Unknown Source)
    at java.io.ObjectInputStream.readObject(Unknown Source)
    at net.spy.memcached.transcoders.BaseSerializingTranscoder.deserialize(BaseSerializingTranscoder.java:129)
    at net.spy.memcached.transcoders.SerializingTranscoder.decode(SerializingTranscoder.java:88)
    at net.spy.memcached.transcoders.TranscodeService$1.call(TranscodeService.java:63)
    at java.util.concurrent.FutureTask$Sync.innerRun(Unknown Source)
    at java.util.concurrent.FutureTask.run(Unknown Source)
    at net.spy.memcached.transcoders.TranscodeService$Task.run(TranscodeService.java:110)
    at net.spy.memcached.transcoders.TranscodeService$Task.get(TranscodeService.java:96)
    at net.spy.memcached.internal.GetFuture.get(GetFuture.java:63)
    at net.spy.memcached.MemcachedClient.get(MemcachedClient.java:997)
    at net.spy.memcached.MemcachedClient.get(MemcachedClient.java:1018)
    at resources.DBConnection.readOneParty(DBConnection.java:114)
    at resources.OnePartyResource.getParty(OnePartyResource.java:57)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
    at java.lang.reflect.Method.invoke(Unknown Source)
    at com.sun.jersey.spi.container.JavaMethodInvokerFactory$1.invoke(JavaMethodInvokerFactory.java:60)
    at com.sun.jersey.server.impl.model.method.dispatch.AbstractResourceMethodDispatchProvider$TypeOutInvoker._dispatch(AbstractResourceMethodDispatchProvider.java:185)
    at com.sun.jersey.server.impl.model.method.dispatch.ResourceJavaMethodDispatcher.dispatch(ResourceJavaMethodDispatcher.java:75)
    at com.sun.jersey.server.impl.uri.rules.HttpMethodRule.accept(HttpMethodRule.java:288)
    at com.sun.jersey.server.impl.uri.rules.SubLocatorRule.accept(SubLocatorRule.java:134)
    at com.sun.jersey.server.impl.uri.rules.RightHandPathRule.accept(RightHandPathRule.java:147)
    at com.sun.jersey.server.impl.uri.rules.ResourceClassRule.accept(ResourceClassRule.java:108)
    at com.sun.jersey.server.impl.uri.rules.RightHandPathRule.accept(RightHandPathRule.java:147)
    at com.sun.jersey.server.impl.uri.rules.RootResourceClassesRule.accept(RootResourceClassesRule.java:84)
    at com.sun.jersey.server.impl.application.WebApplicationImpl._handleRequest(WebApplicationImpl.java:1469)
    at com.sun.jersey.server.impl.application.WebApplicationImpl._handleRequest(WebApplicationImpl.java:1400)
    at com.sun.jersey.server.impl.application.WebApplicationImpl.handleRequest(WebApplicationImpl.java:1349)
    at com.sun.jersey.server.impl.application.WebApplicationImpl.handleRequest(WebApplicationImpl.java:1339)
    at com.sun.jersey.spi.container.servlet.WebComponent.service(WebComponent.java:416)
    at com.sun.jersey.spi.container.servlet.ServletContainer.service(ServletContainer.java:537)
    at com.sun.jersey.spi.container.servlet.ServletContainer.service(ServletContainer.java:699)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:848)
    at org.eclipse.jetty.servlet.ServletHolder.handle(ServletHolder.java:698)
    at org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:505)
    at org.eclipse.jetty.server.session.SessionHandler.doHandle(SessionHandler.java:211)
    at org.eclipse.jetty.server.handler.ContextHandler.doHandle(ContextHandler.java:1094)
    at org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler.java:432)
    at org.eclipse.jetty.server.session.SessionHandler.doScope(SessionHandler.java:175)
    at org.eclipse.jetty.server.handler.ContextHandler.doScope(ContextHandler.java:1028)
    at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:136)
    at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:97)
    at org.eclipse.jetty.server.Server.handle(Server.java:445)
    at org.eclipse.jetty.server.HttpChannel.handle(HttpChannel.java:267)
    at org.eclipse.jetty.server.HttpConnection.onFillable(HttpConnection.java:224)
    at org.eclipse.jetty.io.AbstractConnection$ReadCallback.run(AbstractConnection.java:358)
    at org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:601)
    at org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:532)
    at java.lang.Thread.run(Unknown Source)
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-08-08 21:21:06

我想出来了,答案很尴尬。因此,由于我急于在不同的框架上完成代码,所以我基本上将代码从一个复制到另一个。本质上,它正在存储来自第一个API的值;但是,当我试图使用其他API查询相同的值时,它试图将这些值存储在相同的密钥位置。因此,为什么它找不到对象,它是在错误的项目!因此,我基本上附加了一个程序的字符串键,这样它才能正确地返回。

显然,这是一个令人尴尬的错误,但我认为这是我第一次在多个程序中使用任何类型的缓存系统。

票数 1
EN

Stack Overflow用户

发布于 2013-08-05 21:32:27

memcached (或任何序列化程序)试图从序列化的表单中重构对象时,它必须能够访问适当的类。您在反序列化方面没有可用的core.Party,因此memcached没有用于传入数据流的Java表示。

当您谈到“不同的平台”时,您似乎误解了Java库的工作方式。由于您在两个方面都使用Java,所以不应该有这个类的两个“副本”,您应该只有一个类是可用的。如果有一些共享代码(如Party),但有一些其他代码不应该在两个发行版之间共享,那么将Party放在两个项目所包含的库jar中。Maven和其他构建管理系统使得这很容易。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/18067847

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档