views:

306

answers:

0

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.NoInitialContextException: 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"&gt;

  <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 );
  }
          }