欢迎光临
我们一直在努力

使用Netty框架中的HashedWheelTimer实现高并发定时任务

项目目录结构

HighConcurrencyTimerProject/
├── src/
│   ├── main/
│   │   ├── java/
│   │   │   ├── com/
│   │   │   │   ├── example/
│   │   │   │   │   ├── HighConcurrencyTimerExample.java
│   │   │   │   │   ├── ThreadPoolExample.java
│   ├── test/
│   │   ├── java/
│   │   │   ├── com/
│   │   │   │   ├── example/
│   │   │   │   │   ├── HighConcurrencyTimerExampleTest.java
│   │   │   │   │   ├── ThreadPoolExampleTest.java
├── pom.xmlHighConcurrencyTimerProject/
├── src/
│   ├── main/
│   │   ├── java/
│   │   │   ├── com/
│   │   │   │   ├── example/
│   │   │   │   │   ├── HighConcurrencyTimerExample.java
│   │   │   │   │   ├── ThreadPoolExample.java
│   ├── test/
│   │   ├── java/
│   │   │   ├── com/
│   │   │   │   ├── example/
│   │   │   │   │   ├── HighConcurrencyTimerExampleTest.java
│   │   │   │   │   ├── ThreadPoolExampleTest.java
├── pom.xml

代码文件

HighConcurrencyTimerExample.java

package com.example;

import io.netty.util.HashedWheelTimer;
import io.netty.util.Timeout;
import io.netty.util.TimerTask;

import java.util.concurrent.TimeUnit;

public class HighConcurrencyTimerExample {
    public static void main(String[] args) {
        // 创建一个HashedWheelTimer实例,时间轮的精度为1毫秒,槽数为1024
        HashedWheelTimer timer = new HashedWheelTimer(1, TimeUnit.MILLISECONDS, 1024);

        // 创建并添加100万个定时任务
        for (int i = 0; i < 1000000; i++) {
            timer.newTimeout(new TimerTask() {
                @Override
                public void run(Timeout timeout) {
                    System.out.println("Task executed at: " + new java.util.Date());
                }
            }, 1, TimeUnit.SECONDS);
        }

        // 关闭定时器
        Runtime.getRuntime().addShutdownHook(new Thread(timer::stop));
    }
}

ThreadPoolExample.java

package com.example;

import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;

public class ThreadPoolExample {
    public static void main(String[] args) {
        ScheduledExecutorService executorService = Executors.newScheduledThreadPool(10);
        for (int i = 0; i < 1000000; i++) {
            executorService.schedule(() -> System.out.println("Task executed at: " + new java.util.Date()), 1, TimeUnit.SECONDS);
        }
        executorService.shutdown();
    }
}

pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.example</groupId>
    <artifactId>HighConcurrencyTimerProject</artifactId>
    <version>1.0-SNAPSHOT</version>
    <dependencies>
        <dependency>
            <groupId>io.netty</groupId>
            <artifactId>netty-all</artifactId>
            <version>4.1.68.Final</version>
        </dependency>
    </dependencies>
</project>

构建项目

  • 打开终端,导航到项目根目录,运行以下命令来构建项目:
mvn clean install

运行项目:

  • 使用以下命令运行 HighConcurrencyTimerExample:
mvn exec:java -Dexec.mainClass="com.example.HighConcurrencyTimerExample"

当你运行 HighConcurrencyTimerExample 时,控制台会每秒输出大量任务执行的时间戳。例如:

Task executed at: Fri Dec 27 22:10:00 CST 2024
Task executed at: Fri Dec 27 22:10:00 CST 2024
Task executed at: Fri Dec 27 22:10:00 CST 2024
...
  • 使用以下命令运行 ThreadPoolExample:
mvn exec:java -Dexec.mainClass="com.example.ThreadPoolExample"

当你运行 ThreadPoolExample 时,控制台也会每秒输出大量任务执行的时间戳。例如:

Task executed at: Fri Dec 27 22:10:00 CST 2024
Task executed at: Fri Dec 27 22:10:00 CST 2024
Task executed at: Fri Dec 27 22:10:00 CST 2024
...

https://segmentfault.com/a/1190000045684813

未经允许不得转载:IT极限技术分享汇 » 使用Netty框架中的HashedWheelTimer实现高并发定时任务

评论 抢沙发

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址