package org.apache.lucene.store; /** * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You under the Apache License, Version 2.0 * (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ import java.io.IOException; import java.io.File; /** * Simple standalone tool that forever acquires & releases a * lock using a specific LockFactory. Run without any args * to see usage. * * @see VerifyingLockFactory * @see LockVerifyServer */ public class LockStressTest { public static void main(String[] args) throws Exception { if (args.length != 6) { System.out.println("\nUsage: java org.apache.lucene.store.LockStressTest myID verifierHostOrIP verifierPort lockFactoryClassName lockDirName sleepTime\n" + "\n" + " myID = int from 0 .. 255 (should be unique for test process)\n" + " verifierHostOrIP = host name or IP address where LockVerifyServer is running\n" + " verifierPort = port that LockVerifyServer is listening on\n" + " lockFactoryClassName = primary LockFactory class that we will use\n" + " lockDirName = path to the lock directory (only set for Simple/NativeFSLockFactory\n" + " sleepTimeMS = milliseconds to pause betweeen each lock obtain/release\n" + "\n" + "You should run multiple instances of this process, each with its own\n" + "unique ID, and each pointing to the same lock directory, to verify\n" + "that locking is working correctly.\n" + "\n" + "Make sure you are first running LockVerifyServer.\n" + "\n"); System.exit(1); } final int myID = Integer.parseInt(args[0]); if (myID < 0 || myID > 255) { System.out.println("myID must be a unique int 0..255"); System.exit(1); } final String verifierHost = args[1]; final int verifierPort = Integer.parseInt(args[2]); final String lockFactoryClassName = args[3]; final String lockDirName = args[4]; final int sleepTimeMS = Integer.parseInt(args[5]); LockFactory lockFactory; try { lockFactory = Class.forName(lockFactoryClassName).asSubclass(LockFactory.class).newInstance(); } catch (IllegalAccessException e) { throw new IOException("IllegalAccessException when instantiating LockClass " + lockFactoryClassName); } catch (InstantiationException e) { throw new IOException("InstantiationException when instantiating LockClass " + lockFactoryClassName); } catch (ClassCastException e) { throw new IOException("unable to cast LockClass " + lockFactoryClassName + " instance to a LockFactory"); } catch (ClassNotFoundException e) { throw new IOException("unable to find LockClass " + lockFactoryClassName); } File lockDir = new File(lockDirName); if (lockFactory instanceof FSLockFactory) { ((FSLockFactory) lockFactory).setLockDir(lockDir); } lockFactory.setLockPrefix("test"); LockFactory verifyLF = new VerifyingLockFactory((byte) myID, lockFactory, verifierHost, verifierPort); Lock l = verifyLF.makeLock("test.lock"); while(true) { boolean obtained = false; try { obtained = l.obtain(10); } catch (LockObtainFailedException e) { System.out.print("x"); } if (obtained) { System.out.print("l"); l.release(); } Thread.sleep(sleepTimeMS); } } }