@Test public void testSerializationConfig() { SerializationConfig serializationConfig = config.getSerializationConfig(); assertEquals(ByteOrder.BIG_ENDIAN, serializationConfig.getByteOrder()); assertEquals(false, serializationConfig.isCheckClassDefErrors()); assertEquals(13, serializationConfig.getPortableVersion()); Map<Integer, String> dataSerializableFactoryClasses = serializationConfig.getDataSerializableFactoryClasses(); assertFalse(dataSerializableFactoryClasses.isEmpty()); assertEquals( DummyDataSerializableFactory.class.getName(), dataSerializableFactoryClasses.get(1)); Map<Integer, DataSerializableFactory> dataSerializableFactories = serializationConfig.getDataSerializableFactories(); assertFalse(dataSerializableFactories.isEmpty()); assertEquals(DummyDataSerializableFactory.class, dataSerializableFactories.get(2).getClass()); Map<Integer, String> portableFactoryClasses = serializationConfig.getPortableFactoryClasses(); assertFalse(portableFactoryClasses.isEmpty()); assertEquals(DummyPortableFactory.class.getName(), portableFactoryClasses.get(1)); Map<Integer, PortableFactory> portableFactories = serializationConfig.getPortableFactories(); assertFalse(portableFactories.isEmpty()); assertEquals(DummyPortableFactory.class, portableFactories.get(2).getClass()); Collection<SerializerConfig> serializerConfigs = serializationConfig.getSerializerConfigs(); assertFalse(serializerConfigs.isEmpty()); GlobalSerializerConfig globalSerializerConfig = serializationConfig.getGlobalSerializerConfig(); assertNotNull(globalSerializerConfig); assertEquals(dummySerializer, globalSerializerConfig.getImplementation()); }
@Test public void testGlobalSerializer() { String name = randomName(); String val = "true"; String xml = "<hazelcast xmlns=\"http://www.hazelcast.com/schema/config\">\n" + "<serialization><serializers><global-serializer override-java-serialization=\"" + val + "\">" + name + "</global-serializer></serializers></serialization>" + "</hazelcast>"; Config config = new InMemoryXmlConfig(xml); GlobalSerializerConfig globalSerializerConfig = config.getSerializationConfig().getGlobalSerializerConfig(); globalSerializerConfig.getClassName(); assertEquals(name, globalSerializerConfig.getClassName()); assertTrue(globalSerializerConfig.isOverrideJavaSerialization()); }
public Node(HazelcastInstanceImpl hazelcastInstance, Config config, NodeContext nodeContext) { this.hazelcastInstance = hazelcastInstance; this.threadGroup = hazelcastInstance.threadGroup; this.config = config; configClassLoader = config.getClassLoader(); this.groupProperties = new GroupProperties(config); SerializationService ss; try { ss = new SerializationServiceBuilder() .setClassLoader(configClassLoader) .setConfig(config.getSerializationConfig()) .setManagedContext(hazelcastInstance.managedContext) .setHazelcastInstance(hazelcastInstance) .build(); } catch (Exception e) { throw ExceptionUtil.rethrow(e); } serializationService = (SerializationServiceImpl) ss; systemLogService = new SystemLogService(groupProperties.SYSTEM_LOG_ENABLED.getBoolean()); final AddressPicker addressPicker = nodeContext.createAddressPicker(this); try { addressPicker.pickAddress(); } catch (Throwable e) { throw ExceptionUtil.rethrow(e); } final ServerSocketChannel serverSocketChannel = addressPicker.getServerSocketChannel(); address = addressPicker.getPublicAddress(); localMember = new MemberImpl(address, true, UuidUtil.createMemberUuid(address)); String loggingType = groupProperties.LOGGING_TYPE.getString(); loggingService = new LoggingServiceImpl( systemLogService, config.getGroupConfig().getName(), loggingType, localMember); logger = loggingService.getLogger(Node.class.getName()); initializer = NodeInitializerFactory.create(configClassLoader); try { initializer.beforeInitialize(this); } catch (Throwable e) { try { serverSocketChannel.close(); } catch (Throwable ignored) { } throw ExceptionUtil.rethrow(e); } securityContext = config.getSecurityConfig().isEnabled() ? initializer.getSecurityContext() : null; nodeEngine = new NodeEngineImpl(this); clientEngine = new ClientEngineImpl(this); connectionManager = nodeContext.createConnectionManager(this, serverSocketChannel); partitionService = new PartitionServiceImpl(this); clusterService = new ClusterServiceImpl(this); textCommandService = new TextCommandServiceImpl(this); initializer.printNodeInfo(this); buildNumber = initializer.getBuildNumber(); VersionCheck.check(this, initializer.getBuild(), initializer.getVersion()); JoinConfig join = config.getNetworkConfig().getJoin(); MulticastService mcService = null; try { if (join.getMulticastConfig().isEnabled()) { MulticastConfig multicastConfig = join.getMulticastConfig(); MulticastSocket multicastSocket = new MulticastSocket(null); multicastSocket.setReuseAddress(true); // bind to receive interface multicastSocket.bind(new InetSocketAddress(multicastConfig.getMulticastPort())); multicastSocket.setTimeToLive(multicastConfig.getMulticastTimeToLive()); try { // set the send interface final Address bindAddress = addressPicker.getBindAddress(); // http://bugs.sun.com/bugdatabase/view_bug.do?bug_id=4417033 // http://bugs.sun.com/bugdatabase/view_bug.do?bug_id=6402758 if (!bindAddress.getInetAddress().isLoopbackAddress()) { multicastSocket.setInterface(bindAddress.getInetAddress()); } } catch (Exception e) { logger.warning(e); } multicastSocket.setReceiveBufferSize(64 * 1024); multicastSocket.setSendBufferSize(64 * 1024); String multicastGroup = System.getProperty("hazelcast.multicast.group"); if (multicastGroup == null) { multicastGroup = multicastConfig.getMulticastGroup(); } multicastConfig.setMulticastGroup(multicastGroup); multicastSocket.joinGroup(InetAddress.getByName(multicastGroup)); multicastSocket.setSoTimeout(1000); mcService = new MulticastService(this, multicastSocket); mcService.addMulticastListener(new NodeMulticastListener(this)); } } catch (Exception e) { logger.severe(e); } this.multicastService = mcService; initializeListeners(config); joiner = nodeContext.createJoiner(this); }