本文整理匯總了Java中java.util.concurrent.Executors.newSingleThreadScheduledExecutor方法的典型用法代碼示例。如果您正苦於以下問題:Java Executors.newSingleThreadScheduledExecutor方法的具體用法?Java Executors.newSingleThreadScheduledExecutor怎麽用?Java Executors.newSingleThreadScheduledExecutor使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類java.util.concurrent.Executors
的用法示例。
在下文中一共展示了Executors.newSingleThreadScheduledExecutor方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: scheduleClockUpdating
import java.util.concurrent.Executors; //導入方法依賴的package包/類
private void scheduleClockUpdating() {
ScheduledExecutorService scheduler = Executors.newSingleThreadScheduledExecutor(new ThreadFactory() {
@Override
public Thread newThread(Runnable runnable) {
Thread thread = new Thread(runnable, "System Clock");
thread.setDaemon(true);
return thread;
}
});
scheduler.scheduleAtFixedRate(new Runnable() {
@Override
public void run() {
now.set(System.currentTimeMillis());
}
}, precision, precision, TimeUnit.MILLISECONDS);
}
示例2: contextInitialized
import java.util.concurrent.Executors; //導入方法依賴的package包/類
@Override
public void contextInitialized(ServletContextEvent sce) {
Notifier.start();
// scheduled-notifier start
// new WsScheduledNotifier();
// webhook start
Webhooks.instance();
try {
long pingDelay = NotifierConfig.instance().pingDelay();
if (pingDelay > 0) {
ScheduledExecutorService pinging = Executors.newSingleThreadScheduledExecutor();
pinging.scheduleWithFixedDelay(
CommitNotifier::sendPing,
10L,
pingDelay,
TimeUnit.SECONDS);
}
} catch (IOException e) {
Logs.common.error("ping", e);
}
}
示例3: buildCoapMessaging
import java.util.concurrent.Executors; //導入方法依賴的package包/類
@Override
protected CoapUdpMessaging buildCoapMessaging() {
boolean isSelfCreatedExecutor = false;
if (scheduledExecutorService == null) {
scheduledExecutorService = Executors.newSingleThreadScheduledExecutor();
isSelfCreatedExecutor = true;
}
if (blockSize != null && blockSize.isBert()) {
throw new IllegalArgumentException("BlockSize with BERT support is defined only for CoAP overt TCP/TLS 2017 standard draft");
}
CoapUdpMessaging server = new CoapUdpMessaging(checkAndGetCoapTransport());
server.setSpecialCoapTransactionPriority(blockTransferPriority);
server.setTransmissionTimeout(transmissionTimeout);
server.init(duplicationMaxSize, scheduledExecutorService, isSelfCreatedExecutor,
midSupplier, maxQueueSize, defaultTransactionPriority, delayedTransactionTimeout, duplicatedCoapMessageCallback);
return server;
}
示例4: sendMsg
import java.util.concurrent.Executors; //導入方法依賴的package包/類
public void sendMsg() {
System.out.println("sendMsg");
ScheduledExecutorService newScheduledThreadPool = Executors.newSingleThreadScheduledExecutor();
Random random = new Random();
// int delay = random.nextInt(2) + 1;
int delay = 3;
System.out.println("delay = " + delay);
newScheduledThreadPool.scheduleWithFixedDelay(new Monitor(), 1, delay, TimeUnit.SECONDS);
}
示例5: doStart
import java.util.concurrent.Executors; //導入方法依賴的package包/類
@Override
protected void doStart() {
if (config.isEnable()) {
this.scheduler = Executors.newSingleThreadScheduledExecutor(
new ThreadFactoryBuilder()
.setDaemon(true)
.setNameFormat("memory-reporter-thread")
.setUncaughtExceptionHandler((t, e) ->
log.error("Problem in memory reporter", e))
.build());
this.scheduledJob = this.scheduler.scheduleAtFixedRate(() -> {
reportGC();
reportMemoryPool();
reportMemoryUsage();
}, config.getInterval(), config.getInterval(), TimeUnit.MILLISECONDS);
}
notifyStarted();
}
示例6: start
import java.util.concurrent.Executors; //導入方法依賴的package包/類
/**
* Start this server, causing it to poll JMX at the configured frequency.
*/
@Override
public void start() {
try {
socket = new DatagramSocket();
hostname = InetAddress.getLocalHost().getHostName();
} catch (SocketException ex) {
logger.error("Could not create socket for metrics collection.");
throw new FlumeException(
"Could not create socket for metrics collection.", ex);
} catch (Exception ex2) {
logger.warn("Unknown error occured", ex2);
}
for (HostInfo host : hosts) {
addresses.add(new InetSocketAddress(
host.getHostName(), host.getPortNumber()));
}
collectorRunnable.server = this;
if (service.isShutdown() || service.isTerminated()) {
service = Executors.newSingleThreadScheduledExecutor();
}
service.scheduleWithFixedDelay(collectorRunnable, 0,
pollFrequency, TimeUnit.SECONDS);
}
示例7: testDuplicationAfterCleanUpTimeout
import java.util.concurrent.Executors; //導入方法依賴的package包/類
@Test
public void testDuplicationAfterCleanUpTimeout() throws Exception {
final int timeout = 300;
final int collectionSize = 1;
DuplicationDetector detector = new DuplicationDetector(TimeUnit.MILLISECONDS, timeout, collectionSize, Executors.newSingleThreadScheduledExecutor());
final int cleanupInterval = 100;
detector.setCleanDelayMili(cleanupInterval);
detector.start();
try {
CoapPacket packet = mock(CoapPacket.class);
when(packet.getRemoteAddress()).thenReturn(InetSocketAddress.createUnresolved("testHost", 8080));
when(packet.getMessageId()).thenReturn(9);
CoapPacket firstIsDuplicated = detector.isMessageRepeated(packet);
Thread.sleep(timeout + cleanupInterval + 10);
CoapPacket secondIsDuplicated = detector.isMessageRepeated(packet);
assertNull("insertion to empty duplicate check list fails", firstIsDuplicated);
assertNull("second insertion after timeout with same id fails", secondIsDuplicated);
} finally {
detector.stop();
}
}
示例8: triggerCheckpoint
import java.util.concurrent.Executors; //導入方法依賴的package包/類
@Override
public CompletableFuture<Checkpoint> triggerCheckpoint(
long checkpointId, long checkpointTimestamp, Executor executor) throws Exception {
final String checkpointName = createCheckpointName(checkpointId);
// The method only offers an 'Executor', but we need a 'ScheduledExecutorService'
// Because the hook currently offers no "shutdown()" method, there is no good place to
// shut down a long lived ScheduledExecutorService, so we create one per request
// (we should change that by adding a shutdown() method to these hooks)
// ths shutdown
final ScheduledExecutorService scheduledExecutorService = Executors.newSingleThreadScheduledExecutor();
final CompletableFuture<Checkpoint> checkpointResult =
this.readerGroup.initiateCheckpoint(checkpointName, scheduledExecutorService);
// Add a timeout to the future, to prevent long blocking calls
scheduledExecutorService.schedule(() -> checkpointResult.cancel(false), triggerTimeout, TimeUnit.MILLISECONDS);
// we make sure the executor is shut down after the future completes
checkpointResult.handle((success, failure) -> scheduledExecutorService.shutdownNow());
return checkpointResult;
}
示例9: NodeManager
import java.util.concurrent.Executors; //導入方法依賴的package包/類
@Autowired
public NodeManager(SystemProperties config, EthereumListener ethereumListener,
ApplicationContext ctx, PeerConnectionTester peerConnectionManager) {
this.config = config;
this.ethereumListener = ethereumListener;
this.peerConnectionManager = peerConnectionManager;
PERSIST = config.peerDiscoveryPersist();
if (PERSIST) peerSource = ctx.getBean(PeerSource.class);
discoveryEnabled = config.peerDiscovery();
key = config.getMyKey();
homeNode = new Node(config.nodeId(), config.externalIp(), config.listenPort());
table = new NodeTable(homeNode, config.isPublicHomeNode());
logStatsTimer.scheduleAtFixedRate(new TimerTask() {
@Override
public void run() {
logger.trace("Statistics:\n {}", dumpAllStatistics());
}
}, 1 * 1000, 60 * 1000);
this.pongTimer = Executors.newSingleThreadScheduledExecutor();
for (Node node : config.peerActive()) {
getNodeHandler(node).getNodeStatistics().setPredefined(true);
}
}
示例10: Countly
import java.util.concurrent.Executors; //導入方法依賴的package包/類
/**
* Constructs a Countly object.
* Creates a new ConnectionQueue and initializes the session timer.
*/
Countly() {
connectionQueue_ = new ConnectionQueue();
Countly.userData = new UserData(connectionQueue_);
timerService_ = Executors.newSingleThreadScheduledExecutor();
timerService_.scheduleWithFixedDelay(new Runnable() {
@Override
public void run() {
onTimer();
}
}, TIMER_DELAY_IN_SECONDS, TIMER_DELAY_IN_SECONDS, TimeUnit.SECONDS);
}
示例11: start
import java.util.concurrent.Executors; //導入方法依賴的package包/類
@Override
public void start ( final BundleContext context ) throws Exception
{
logger.info ( "Starting bundle" );
this.executor = Executors.newSingleThreadScheduledExecutor ( new NamedThreadFactory ( context.getBundle ().getSymbolicName () ) );
this.factory = new ConnectionAnalyzerFactory ( this.executor, context );
}
示例12: scheduleClockUpdating
import java.util.concurrent.Executors; //導入方法依賴的package包/類
private void scheduleClockUpdating() {
ScheduledExecutorService scheduler = Executors.newSingleThreadScheduledExecutor(new ThreadFactory() {
public Thread newThread(Runnable runnable) {
Thread thread = new Thread(runnable, "System Clock");
thread.setDaemon(true);
return thread;
}
});
scheduler.scheduleAtFixedRate(new Runnable() {
public void run() {
now.set(System.currentTimeMillis());
}
}, period, period, TimeUnit.MILLISECONDS);
}
示例13: testReschedule
import java.util.concurrent.Executors; //導入方法依賴的package包/類
@Test
public void testReschedule() throws InterruptedException {
ScheduledExecutorService ses =
Executors.newSingleThreadScheduledExecutor();
final Object tc = this;
SingletonTask st1 = new SingletonTask(ses, new Runnable() {
@Override
public void run() {
synchronized (tc) {
ran += 1;
}
time = System.nanoTime();
}
});
st1.reschedule(20, TimeUnit.MILLISECONDS);
Thread.sleep(5);
assertFalse("Check that task hasn't run yet", ran > 0);
st1.reschedule(20, TimeUnit.MILLISECONDS);
Thread.sleep(5);
assertFalse("Check that task hasn't run yet", ran > 0);
st1.reschedule(20, TimeUnit.MILLISECONDS);
Thread.sleep(5);
assertFalse("Check that task hasn't run yet", ran > 0);
st1.reschedule(20, TimeUnit.MILLISECONDS);
Thread.sleep(5);
assertFalse("Check that task hasn't run yet", ran > 0);
st1.reschedule(20, TimeUnit.MILLISECONDS);
Thread.sleep(5);
assertFalse("Check that task hasn't run yet", ran > 0);
st1.reschedule(20, TimeUnit.MILLISECONDS);
Thread.sleep(5);
assertFalse("Check that task hasn't run yet", ran > 0);
st1.reschedule(20, TimeUnit.MILLISECONDS);
Thread.sleep(5);
assertFalse("Check that task hasn't run yet", ran > 0);
st1.reschedule(20, TimeUnit.MILLISECONDS);
Thread.sleep(5);
assertFalse("Check that task hasn't run yet", ran > 0);
ses.shutdown();
ses.awaitTermination(5, TimeUnit.SECONDS);
assertEquals("Check that task ran only once", 1, ran);
}
示例14: AutoReconnectController
import java.util.concurrent.Executors; //導入方法依賴的package包/類
/**
* Create a new reconnect controller for the provided connection
*
* @param connection
* the connection to manage
* @param reconnectDelay
* the minimum delay between reconnect attempts
*/
public AutoReconnectController ( final Connection connection, long reconnectDelay )
{
this.connection = connection;
this.reconnectDelay = reconnectDelay;
if ( this.connection == null )
{
throw new IllegalArgumentException ( "'connection' must not be null" );
}
if ( reconnectDelay <= 0 )
{
reconnectDelay = DEFAULT_RECONNECT_DELAY;
}
final ThreadFactory threadFactory = new NamedThreadFactory ( "AutoReconnect/" + connection.getConnectionInformation ().toMaskedString () );
synchronized ( this )
{
this.executor = Executors.newSingleThreadScheduledExecutor ( threadFactory );
}
this.connection.addConnectionStateListener ( this );
if ( !Boolean.getBoolean ( "org.eclipse.scada.core.client.AutoReconnectController.disableZombieMode" ) )
{
this.zombieJob = this.executor.scheduleWithFixedDelay ( new Runnable () {
@Override
public void run ()
{
checkDead ();
}
}, reconnectDelay, reconnectDelay, TimeUnit.MILLISECONDS );
}
}
示例15: configure
import java.util.concurrent.Executors; //導入方法依賴的package包/類
@Override
public void configure(Map configurationValues) {
log.usingHibernateBuiltInConnectionPool();
connectionCreator = buildCreator( configurationValues );
final int minSize = ConfigurationHelper.getInt( MIN_SIZE, configurationValues, 1 );
final int maxSize = ConfigurationHelper.getInt( AvailableSettings.POOL_SIZE, configurationValues, 20 );
final int initialSize = ConfigurationHelper.getInt( INITIAL_SIZE, configurationValues, minSize );
final long validationInterval = ConfigurationHelper.getLong( VALIDATION_INTERVAL, configurationValues, 30 );
log.hibernateConnectionPoolSize( maxSize, minSize );
log.debugf( "Initializing Connection pool with %s Connections", initialSize );
for ( int i = 0; i < initialSize; i++ ) {
connections.add( connectionCreator.createConnection() );
}
executorService = Executors.newSingleThreadScheduledExecutor();
executorService.scheduleWithFixedDelay(
new Runnable() {
private boolean primed;
@Override
public void run() {
int size = connections.size();
if ( !primed && size >= minSize ) {
// IMPL NOTE : the purpose of primed is to allow the pool to lazily reach its
// defined min-size.
log.debug( "Connection pool now considered primed; min-size will be maintained" );
primed = true;
}
if ( size < minSize && primed ) {
int numberToBeAdded = minSize - size;
log.debugf( "Adding %s Connections to the pool", numberToBeAdded );
for (int i = 0; i < numberToBeAdded; i++) {
connections.add( connectionCreator.createConnection() );
}
}
else if ( size > maxSize ) {
int numberToBeRemoved = size - maxSize;
log.debugf( "Removing %s Connections from the pool", numberToBeRemoved );
for ( int i = 0; i < numberToBeRemoved; i++ ) {
Connection connection = connections.poll();
try {
connection.close();
}
catch (SQLException e) {
log.unableToCloseConnection( e );
}
}
}
}
},
validationInterval,
validationInterval,
TimeUnit.SECONDS
);
}