public interface Vertx extends Measured
You use an instance of this class for functionality including:
Most functionality in Vert.x core is fairly low level.
 To create an instance of this class you can use the static factory methods: vertx(),
 vertx(io.vertx.core.VertxOptions) and clusteredVertx(io.vertx.core.VertxOptions, Handler).
 
Please see the user manual for more detailed usage information.
| Modifier and Type | Method and Description | 
|---|---|
| boolean | cancelTimer(long id)Cancels the timer with the specified  id. | 
| Future<Void> | close()Stop the Vertx instance and release any resources held by it. | 
| void | close(Handler<AsyncResult<Void>> completionHandler)Like  close()but the completionHandler will be called when the close is complete | 
| static Future<Vertx> | clusteredVertx(VertxOptions options)Same as  clusteredVertx(VertxOptions, Handler)but with anhandlercalled when the operation completes | 
| static void | clusteredVertx(VertxOptions options,
              Handler<AsyncResult<Vertx>> resultHandler)Creates a clustered instance using the specified options. | 
| DatagramSocket | createDatagramSocket()Create a datagram socket using default options | 
| DatagramSocket | createDatagramSocket(DatagramSocketOptions options)Create a datagram socket using the specified options | 
| DnsClient | createDnsClient()Create a DNS client to connect to the DNS server configured by  VertxOptions.getAddressResolverOptions() | 
| DnsClient | createDnsClient(DnsClientOptions options)Create a DNS client to connect to a DNS server | 
| DnsClient | createDnsClient(int port,
               String host)Create a DNS client to connect to a DNS server at the specified host and port, with the default query timeout (5 seconds)
  | 
| HttpClient | createHttpClient()Create a HTTP/HTTPS client using default options | 
| HttpClient | createHttpClient(HttpClientOptions options)Create a HTTP/HTTPS client using the specified options | 
| HttpServer | createHttpServer()Create an HTTP/HTTPS server using default options | 
| HttpServer | createHttpServer(HttpServerOptions options)Create an HTTP/HTTPS server using the specified options | 
| NetClient | createNetClient()Create a TCP/SSL client using default options | 
| NetClient | createNetClient(NetClientOptions options)Create a TCP/SSL client using the specified options | 
| NetServer | createNetServer()Create a TCP/SSL server using default options | 
| NetServer | createNetServer(NetServerOptions options)Create a TCP/SSL server using the specified options | 
| WorkerExecutor | createSharedWorkerExecutor(String name)Like  createSharedWorkerExecutor(String, int)but with theVertxOptions.setWorkerPoolSize(int)poolSize. | 
| WorkerExecutor | createSharedWorkerExecutor(String name,
                          int poolSize)Like  createSharedWorkerExecutor(String, int, long)but with theVertxOptions.setMaxWorkerExecuteTime(long)maxExecuteTime. | 
| WorkerExecutor | createSharedWorkerExecutor(String name,
                          int poolSize,
                          long maxExecuteTime)Like  createSharedWorkerExecutor(String, int, long, TimeUnit)but with thens unit. | 
| WorkerExecutor | createSharedWorkerExecutor(String name,
                          int poolSize,
                          long maxExecuteTime,
                          TimeUnit maxExecuteTimeUnit)Create a named worker executor, the executor should be closed when it's not needed anymore to release
 resources.
 This method can be called mutiple times with the same  name. | 
| static Context | currentContext()Gets the current context | 
| Set<String> | deploymentIDs()Return a Set of deployment IDs for the currently deployed deploymentIDs. | 
| Future<String> | deployVerticle(Class<? extends Verticle> verticleClass,
              DeploymentOptions options)Like  deployVerticle(Verticle, DeploymentOptions)butVerticleinstance is created by invoking the
 default constructor ofverticleClass. | 
| void | deployVerticle(Class<? extends Verticle> verticleClass,
              DeploymentOptions options,
              Handler<AsyncResult<String>> completionHandler)Like  deployVerticle(Verticle, DeploymentOptions, Handler)butVerticleinstance is created by
 invoking the default constructor ofverticleClass. | 
| Future<String> | deployVerticle(String name)Deploy a verticle instance given a name. | 
| Future<String> | deployVerticle(String name,
              DeploymentOptions options)Like  deployVerticle(Verticle)butDeploymentOptionsare provided to configure the
 deployment. | 
| void | deployVerticle(String name,
              DeploymentOptions options,
              Handler<AsyncResult<String>> completionHandler)Like  deployVerticle(String, Handler)butDeploymentOptionsare provided to configure the
 deployment. | 
| void | deployVerticle(String name,
              Handler<AsyncResult<String>> completionHandler)Like  deployVerticle(String)but the completionHandler will be notified when the deployment is complete. | 
| Future<String> | deployVerticle(java.util.function.Supplier<Verticle> verticleSupplier,
              DeploymentOptions options)Like  deployVerticle(Verticle, DeploymentOptions)butVerticleinstance is created by invoking theverticleSupplier. | 
| void | deployVerticle(java.util.function.Supplier<Verticle> verticleSupplier,
              DeploymentOptions options,
              Handler<AsyncResult<String>> completionHandler)Like  deployVerticle(Verticle, DeploymentOptions, Handler)butVerticleinstance is created by
 invoking theverticleSupplier. | 
| Future<String> | deployVerticle(Verticle verticle)Deploy a verticle instance that you have created yourself. | 
| Future<String> | deployVerticle(Verticle verticle,
              DeploymentOptions options)Like  deployVerticle(Verticle)butDeploymentOptionsare provided to configure the
 deployment. | 
| void | deployVerticle(Verticle verticle,
              DeploymentOptions options,
              Handler<AsyncResult<String>> completionHandler)Like  deployVerticle(Verticle, Handler)butDeploymentOptionsare provided to configure the
 deployment. | 
| void | deployVerticle(Verticle verticle,
              Handler<AsyncResult<String>> completionHandler)Like  deployVerticle(Verticle)but the completionHandler will be notified when the deployment is complete. | 
| EventBus | eventBus()Get the event bus object. | 
| Handler<Throwable> | exceptionHandler() | 
| Vertx | exceptionHandler(Handler<Throwable> handler)Set a default exception handler for  Context, set onContext.exceptionHandler(Handler)at creation. | 
| <T> Future<T> | executeBlocking(Handler<Promise<T>> blockingCodeHandler)Same as  executeBlocking(Handler, Handler)but with anhandlercalled when the operation completes | 
| <T> Future<T> | executeBlocking(Handler<Promise<T>> blockingCodeHandler,
               boolean ordered)Same as  executeBlocking(Handler, boolean, Handler)but with anhandlercalled when the operation completes | 
| <T> void | executeBlocking(Handler<Promise<T>> blockingCodeHandler,
               boolean ordered,
               Handler<AsyncResult<T>> resultHandler)Safely execute some blocking code. | 
| <T> void | executeBlocking(Handler<Promise<T>> blockingCodeHandler,
               Handler<AsyncResult<T>> resultHandler)Like  executeBlocking(Handler, boolean, Handler)called with ordered = true. | 
| FileSystem | fileSystem()Get the filesystem object. | 
| Context | getOrCreateContext()Gets the current context, or creates one if there isn't one | 
| boolean | isClustered()Is this Vert.x instance clustered? | 
| boolean | isNativeTransportEnabled() | 
| io.netty.channel.EventLoopGroup | nettyEventLoopGroup()Return the Netty EventLoopGroup used by Vert.x | 
| TimeoutStream | periodicStream(long delay)Returns a periodic timer as a read stream. | 
| void | registerVerticleFactory(VerticleFactory factory)Register a  VerticleFactorythat can be used for deploying Verticles based on an identifier. | 
| void | runOnContext(Handler<Void> action)Puts the handler on the event queue for the current context so it will be run asynchronously ASAP after all
 preceeding events have been handled. | 
| long | setPeriodic(long delay,
           Handler<Long> handler)Set a periodic timer to fire every  delaymilliseconds, at which pointhandlerwill be called with
 the id of the timer. | 
| long | setTimer(long delay,
        Handler<Long> handler)Set a one-shot timer to fire after  delaymilliseconds, at which pointhandlerwill be called with
 the id of the timer. | 
| SharedData | sharedData()Get the shared data object. | 
| TimeoutStream | timerStream(long delay)Returns a one-shot timer as a read stream. | 
| Future<Void> | undeploy(String deploymentID)Undeploy a verticle deployment. | 
| void | undeploy(String deploymentID,
        Handler<AsyncResult<Void>> completionHandler)Like  undeploy(String)but the completionHandler will be notified when the undeployment is complete. | 
| void | unregisterVerticleFactory(VerticleFactory factory)Unregister a  VerticleFactory | 
| Set<VerticleFactory> | verticleFactories()Return the Set of currently registered verticle factories. | 
| static Vertx | vertx()Creates a non clustered instance using default options. | 
| static Vertx | vertx(VertxOptions options)Creates a non clustered instance using the specified options | 
isMetricsEnabledstatic Vertx vertx()
static Vertx vertx(VertxOptions options)
options - the options to usestatic void clusteredVertx(VertxOptions options, Handler<AsyncResult<Vertx>> resultHandler)
The instance is created asynchronously and the resultHandler is called with the result when it is ready.
options - the options to useresultHandler - the result handler that will receive the resultstatic Future<Vertx> clusteredVertx(VertxOptions options)
clusteredVertx(VertxOptions, Handler) but with an handler called when the operation completesstatic Context currentContext()
null if there is no current contextContext getOrCreateContext()
NetServer createNetServer(NetServerOptions options)
options - the options to useNetServer createNetServer()
NetClient createNetClient(NetClientOptions options)
options - the options to useNetClient createNetClient()
HttpServer createHttpServer(HttpServerOptions options)
options - the options to useHttpServer createHttpServer()
HttpClient createHttpClient(HttpClientOptions options)
options - the options to useHttpClient createHttpClient()
DatagramSocket createDatagramSocket(DatagramSocketOptions options)
options - the options to useDatagramSocket createDatagramSocket()
FileSystem fileSystem()
EventBus eventBus()
DnsClient createDnsClient(int port, String host)
port - the porthost - the hostDnsClient createDnsClient()
VertxOptions.getAddressResolverOptions()
 
 DNS client takes the first configured resolver address provided by DnsResolverProvider.nameServerAddresses()}
DnsClient createDnsClient(DnsClientOptions options)
options - the client optionsSharedData sharedData()
long setTimer(long delay,
              Handler<Long> handler)
delay milliseconds, at which point handler will be called with
 the id of the timer.delay - the delay in milliseconds, after which the timer will firehandler - the handler that will be called with the timer ID when the timer firesTimeoutStream timerStream(long delay)
delay milliseconds after
 the ReadStream.handler(io.vertx.core.Handler<T>) has been called.delay - the delay in milliseconds, after which the timer will firelong setPeriodic(long delay,
                 Handler<Long> handler)
delay milliseconds, at which point handler will be called with
 the id of the timer.delay - the delay in milliseconds, after which the timer will firehandler - the handler that will be called with the timer ID when the timer firesTimeoutStream periodicStream(long delay)
delay milliseconds after
 the ReadStream.handler(io.vertx.core.Handler<T>) has been called.delay - the delay in milliseconds, after which the timer will fireboolean cancelTimer(long id)
id.id - The id of the timer to cancelvoid runOnContext(Handler<Void> action)
action - - a handler representing the action to executeFuture<Void> close()
The instance cannot be used after it has been closed.
The actual close is asynchronous and may not complete until after the call has returned.
void close(Handler<AsyncResult<Void>> completionHandler)
close() but the completionHandler will be called when the close is completecompletionHandler - The handler will be notified when the close is complete.Future<String> deployVerticle(Verticle verticle)
Vert.x will assign the verticle a context and start the verticle.
The actual deploy happens asynchronously and may not complete until after the call has returned.
verticle - the verticle instance to deploy.void deployVerticle(Verticle verticle, Handler<AsyncResult<String>> completionHandler)
deployVerticle(Verticle) but the completionHandler will be notified when the deployment is complete.
 If the deployment is successful the result will contain a string representing the unique deployment ID of the deployment.
This deployment ID can subsequently be used to undeploy the verticle.
verticle - the verticle instance to deploycompletionHandler - a handler which will be notified when the deployment is completeFuture<String> deployVerticle(Verticle verticle, DeploymentOptions options)
deployVerticle(Verticle) but DeploymentOptions are provided to configure the
 deployment.verticle - the verticle instance to deployoptions - the deployment options.Future<String> deployVerticle(Class<? extends Verticle> verticleClass, DeploymentOptions options)
deployVerticle(Verticle, DeploymentOptions) but Verticle instance is created by invoking the
 default constructor of verticleClass.Future<String> deployVerticle(java.util.function.Supplier<Verticle> verticleSupplier, DeploymentOptions options)
deployVerticle(Verticle, DeploymentOptions) but Verticle instance is created by invoking the
 verticleSupplier.
 
 The supplier will be invoked as many times as DeploymentOptions.getInstances().
 It must not return the same instance twice.
 
Note that the supplier will be invoked on the caller thread.
void deployVerticle(Verticle verticle, DeploymentOptions options, Handler<AsyncResult<String>> completionHandler)
deployVerticle(Verticle, Handler) but DeploymentOptions are provided to configure the
 deployment.verticle - the verticle instance to deployoptions - the deployment options.completionHandler - a handler which will be notified when the deployment is completevoid deployVerticle(Class<? extends Verticle> verticleClass, DeploymentOptions options, Handler<AsyncResult<String>> completionHandler)
deployVerticle(Verticle, DeploymentOptions, Handler) but Verticle instance is created by
 invoking the default constructor of verticleClass.void deployVerticle(java.util.function.Supplier<Verticle> verticleSupplier, DeploymentOptions options, Handler<AsyncResult<String>> completionHandler)
deployVerticle(Verticle, DeploymentOptions, Handler) but Verticle instance is created by
 invoking the verticleSupplier.
 
 The supplier will be invoked as many times as DeploymentOptions.getInstances().
 It must not return the same instance twice.
 
Note that the supplier will be invoked on the caller thread.
Future<String> deployVerticle(String name)
 Given the name, Vert.x selects a VerticleFactory instance to use to instantiate the verticle.
 
For the rules on how factories are selected please consult the user manual.
name - the name.void deployVerticle(String name, Handler<AsyncResult<String>> completionHandler)
deployVerticle(String) but the completionHandler will be notified when the deployment is complete.
 If the deployment is successful the result will contain a String representing the unique deployment ID of the deployment.
This deployment ID can subsequently be used to undeploy the verticle.
name - The identifiercompletionHandler - a handler which will be notified when the deployment is completeFuture<String> deployVerticle(String name, DeploymentOptions options)
deployVerticle(Verticle) but DeploymentOptions are provided to configure the
 deployment.name - the nameoptions - the deployment options.void deployVerticle(String name, DeploymentOptions options, Handler<AsyncResult<String>> completionHandler)
deployVerticle(String, Handler) but DeploymentOptions are provided to configure the
 deployment.name - the nameoptions - the deployment options.completionHandler - a handler which will be notified when the deployment is completeFuture<Void> undeploy(String deploymentID)
The actual undeployment happens asynchronously and may not complete until after the method has returned.
deploymentID - the deployment IDvoid undeploy(String deploymentID, Handler<AsyncResult<Void>> completionHandler)
undeploy(String) but the completionHandler will be notified when the undeployment is complete.deploymentID - the deployment IDcompletionHandler - a handler which will be notified when the undeployment is completeSet<String> deploymentIDs()
void registerVerticleFactory(VerticleFactory factory)
VerticleFactory that can be used for deploying Verticles based on an identifier.factory - the factory to registervoid unregisterVerticleFactory(VerticleFactory factory)
VerticleFactoryfactory - the factory to unregisterSet<VerticleFactory> verticleFactories()
boolean isClustered()
<T> void executeBlocking(Handler<Promise<T>> blockingCodeHandler, boolean ordered, Handler<AsyncResult<T>> resultHandler)
 Executes the blocking code in the handler blockingCodeHandler using a thread from the worker pool.
 
 When the code is complete the handler resultHandler will be called with the result on the original context
 (e.g. on the original event loop of the caller).
 
 A Future instance is passed into blockingCodeHandler. When the blocking code successfully completes,
 the handler should call the Promise.complete(T) or Promise.complete(Object) method, or the Promise.fail(java.lang.Throwable)
 method if it failed.
 
 In the blockingCodeHandler the current context remains the original context and therefore any task
 scheduled in the blockingCodeHandler will be executed on the this context and not on the worker thread.
 
The blocking code should block for a reasonable amount of time (i.e no more than a few seconds). Long blocking operations or polling operations (i.e a thread that spin in a loop polling events in a blocking fashion) are precluded.
When the blocking operation lasts more than the 10 seconds, a message will be printed on the console by the blocked thread checker.
 Long blocking operations should use a dedicated thread managed by the application, which can interact with
 verticles using the event-bus or Context.runOnContext(Handler)
T - the type of the resultblockingCodeHandler - handler representing the blocking code to runresultHandler - handler that will be called when the blocking code is completeordered - if true then if executeBlocking is called several times on the same context, the executions
                 for that context will be executed serially, not in parallel. if false then they will be no ordering
                 guarantees<T> void executeBlocking(Handler<Promise<T>> blockingCodeHandler, Handler<AsyncResult<T>> resultHandler)
executeBlocking(Handler, boolean, Handler) called with ordered = true.<T> Future<T> executeBlocking(Handler<Promise<T>> blockingCodeHandler, boolean ordered)
executeBlocking(Handler, boolean, Handler) but with an handler called when the operation completes<T> Future<T> executeBlocking(Handler<Promise<T>> blockingCodeHandler)
executeBlocking(Handler, Handler) but with an handler called when the operation completesio.netty.channel.EventLoopGroup nettyEventLoopGroup()
WorkerExecutor createSharedWorkerExecutor(String name)
createSharedWorkerExecutor(String, int) but with the VertxOptions.setWorkerPoolSize(int) poolSize.WorkerExecutor createSharedWorkerExecutor(String name, int poolSize)
createSharedWorkerExecutor(String, int, long) but with the VertxOptions.setMaxWorkerExecuteTime(long) maxExecuteTime.WorkerExecutor createSharedWorkerExecutor(String name, int poolSize, long maxExecuteTime)
createSharedWorkerExecutor(String, int, long, TimeUnit) but with the ns unit.WorkerExecutor createSharedWorkerExecutor(String name, int poolSize, long maxExecuteTime, TimeUnit maxExecuteTimeUnit)
name. Executors with the same name will share
 the same worker pool. The worker pool size , max execute time and unit of max execute time are set when the worker pool is created and
 won't change after.
 The worker pool is released when all the WorkerExecutor sharing the same name are closed.
name - the name of the worker executorpoolSize - the size of the poolmaxExecuteTime - the value of max worker execute timemaxExecuteTimeUnit - the value of unit of max worker execute timeboolean isNativeTransportEnabled()
Vertx exceptionHandler(Handler<Throwable> handler)
Context, set on Context.exceptionHandler(Handler) at creation.handler - the exception handlerCopyright © 2021 Eclipse. All rights reserved.