开发者

Problem with Hibernate Shards & JNDI

开发者 https://www.devze.com 2022-12-14 17:27 出处:网络
I\'m trying to run a sample program for hibernate shards. I\'m all done with it but whenever I run the test program I get an Exception

I'm trying to run a sample program for hibernate shards. I'm all done with it but whenever I run the test program I get an Exception

javax.naming.NoInitialContextException: Need to specify class name in environment or system property

After googling I got to know that I've to set the JNDI properties. I did like this

Hashtable env = new Hashtable();
env.put( Context.INITIAL_CONTEXT_FACTORY,"com.sun.enterprise.naming.SerialInitContextFactory");
env.put( Context.PROVIDER_URL, "<some-IP>:3306" );
Context initialContext = new InitialContext(env);

javax.naming.No开发者_运维问答InitialContextException: Cannot instantiate class: com.sun.enterprise.naming.SerialInitContextFactory [Root exception is java.lang.ClassNotFoundException: com.sun.enterprise.naming.SerialInitContextFactory]
at javax.naming.spi.NamingManager.getInitialContext(NamingManager.java:657)
at javax.naming.InitialContext.getDefaultInitCtx(InitialContext.java:288)
at javax.naming.InitialContext.init(InitialContext.java:223)
at javax.naming.InitialContext.<init>(InitialContext.java:197)
at com.hibshards.test.JNDIProperties.setProperties(JNDIProperties.java:18)
at com.hibshards.test.SessionFactoryImpl.createSessionFactory(SessionFactoryImpl.java:32)
at com.hibshards.test.ShardTest.main(ShardTest.java:17)
Caused by: java.lang.ClassNotFoundException: com.sun.enterprise.naming.SerialInitContextFactory
at java.net.URLClassLoader$1.run(URLClassLoader.java:200)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:188)
at java.lang.ClassLoader.loadClass(ClassLoader.java:307)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
at java.lang.ClassLoader.loadClass(ClassLoader.java:252)
at java.lang.ClassLoader.loadClassInternal(ClassLoader.java:320)
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:247)
at com.sun.naming.internal.VersionHelper12.loadClass(VersionHelper12.java:46)
at javax.naming.spi.NamingManager.getInitialContext(NamingManager.java:654)
... 6 more

But still things are not working.:-( Please help. What n where I'm missing?

Here is the code :

public class SessionFactoryImpl {

    private static final String SHARD_CFG_0 = "/com/hibshards/config/shard0.hibernate.cfg.xml";
    private static final String SHARD_CFG_1 = "/com/hibshards/config/shard1.hibernate.cfg.xml";
    private static final String SHARDED_TABLE = "com/hibshards/orm/weather.hbm.xml";

    public static SessionFactory createSessionFactory() throws NamingException {
        Configuration prototypeConfig = new Configuration().configure( SHARD_CFG_0 );
        prototypeConfig.addResource( SHARDED_TABLE );

        List<ShardConfiguration> shardConfigs = new ArrayList<ShardConfiguration>();
        shardConfigs.add( buildShardConfig( SHARD_CFG_0 ) );
        shardConfigs.add( buildShardConfig( SHARD_CFG_1 ) );

        ShardStrategyFactory shardStrategyFactory = buildShardStrategyFactory();
        ShardedConfiguration shardedConfig = new ShardedConfiguration(
                prototypeConfig,
                shardConfigs,
                shardStrategyFactory);
        return shardedConfig.buildShardedSessionFactory();
    }

    private static ShardStrategyFactory buildShardStrategyFactory() {

        ShardStrategyFactory shardStrategyFactory = new ShardStrategyFactory() {
            public ShardStrategy newShardStrategy(List<ShardId> shardIds) {
                RoundRobinShardLoadBalancer loadBalancer = new RoundRobinShardLoadBalancer( shardIds );
                ShardSelectionStrategy pss = new RoundRobinShardSelectionStrategy( loadBalancer );
                ShardResolutionStrategy prs = new AllShardsShardResolutionStrategy( shardIds );
                ShardAccessStrategy pas = new SequentialShardAccessStrategy();
                return new ShardStrategyImpl( pss, prs, pas );
            }
        };
        return shardStrategyFactory;
    }

    private static ShardConfiguration buildShardConfig( String configFile ) {
        Configuration config = new Configuration().configure( configFile );
        return new ConfigurationToShardConfigurationAdapter( config );
    }
}

<?xml version='1.0' encoding='utf-8'?>
 <!DOCTYPE hibernate-configuration PUBLIC
 "-//Hibernate/Hibernate Configuration DTD//EN"
 "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">

  <hibernate-configuration>
  <session-factory name="HibernateSessionFactory0"> 
<property name="dialect">org.hibernate.dialect.MySQLDialect</property>
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
    <property name="connection.url">jdbc:mysql://localhost:3306/shardDB</property>
   <property name="connection.username">root</property>
    <property name="connection.password">root</property>
   <property name="hibernate.connection.shard_id">0</property> 
    <property name="hibernate.shard.enable_cross_shard_relationship_checks">true</property> 
  </session-factory>
    </hibernate-configuration>


public class JNDIProperties { 
public static void setProperties() throws NamingException {
    Properties properties = new Properties();
    properties.put( Context.INITIAL_CONTEXT_FACTORY, "com.sun.enterprise.naming.SerialInitContextFactory");
    properties.put( Context.PROVIDER_URL, "file:///");
    Context initialContext = new InitialContext( properties );
  }
          }


In a simple java application, you don't need a name for the session factory..try removing the name in your cfg.xml file and executing it

0

精彩评论

暂无评论...
验证码 换一张
取 消