RxJava/RxAndroid:timer(long delay, TimeUnit unit)

本文介绍RxJava中的timer方法,用于创建一个在指定时间后发射一个特定值的Observable。通过示例展示如何设置一个3秒后的输出任务,并解释了其与interval操作符的区别。

RxJava/RxAndroid:timer(long delay, TimeUnit unit)


timer起到定时器的作用,本例使用timer延迟3秒执行一个输出任务:

package com.example.fly.myapplication;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;

import java.util.concurrent.TimeUnit;

import io.reactivex.Observable;
import io.reactivex.android.schedulers.AndroidSchedulers;
import io.reactivex.observers.DisposableObserver;
import io.reactivex.schedulers.Schedulers;

public class MainActivity extends AppCompatActivity {

    private final String TAG = "输出";

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        Log.d(TAG, "" + System.currentTimeMillis());
        Observable.timer(3, TimeUnit.SECONDS)
                .subscribeOn(Schedulers.io())
                .observeOn(AndroidSchedulers.mainThread())
                .subscribeWith(mDisposableObserver);
    }

    private DisposableObserver<Long> mDisposableObserver = new DisposableObserver<Long>() {

        @Override
        public void onNext(Long aLong) {
            Log.d(TAG, "onNext:" + aLong);
            Log.d(TAG, "" + System.currentTimeMillis());
        }

        @Override
        public void onComplete() {
            Log.d(TAG, "onComplete");
        }

        @Override
        public void onError(Throwable e) {
            Log.e(TAG, e.toString(), e);
        }
    };
}

输出:

02-08 14:13:14.582 18410-18410/com.example.fly.myapplication D/输出: 1518070394582
02-08 14:13:17.661 18410-18410/com.example.fly.myapplication D/输出: onNext:0
02-08 14:13:17.661 18410-18410/com.example.fly.myapplication D/输出: 1518070397661
02-08 14:13:17.661 18410-18410/com.example.fly.myapplication D/输出: onComplete

注意到第一次打印系统时间是:02-08 14:13:14

第二次打印出来的时间是:02-08 14:13:17。即延迟3秒。

timer不是周期性的执行任务,只是定时在某一个时间点发射一个事件,这和操作符interval周期性执行任务不同。

override def onQueryProgress(event: QueryProgressEvent): Unit = { val progress: StreamingQueryProgress = event.progress if (progress == null) { logger.warn("Progress is null, skipping metric reporting.") return } val batchId: Long = progress.batchId val actualTriggerTime: String = progress.timestamp // 获取批次触发时间 val numInputRows: Long = progress.numInputRows try { val instant: Instant = Instant.parse(actualTriggerTime) val actualTriggerTimeStamp: Long = instant.toEpochMilli // 打印相关变量的值 logger.info("batchId is::{}", batchId) logger.info("actualTriggerTimeStamp is::{}", actualTriggerTimeStamp) logger.info("numInputRows is::{}", numInputRows) // 计算实际调度延迟 val watermark: String = progress.eventTime.get("watermark") // val currentTime = System.currentTimeMillis() // 当前时间 // val maxEventTime = progress.eventTime.get("max") val watermarkTimestamp: Long = java.time.Instant.parse(watermark).toEpochMilli val schedulingDelay: Long = System.currentTimeMillis() - watermarkTimestamp // val maxEventTimestamp = java.time.Instant.parse(maxEventTime).toEpochMilli // val eventTimeLag = currentTime - maxEventTimestamp // 数据从产生到当前的时间差 // val watermarkLag = maxEventTimestamp - watermarkTimestamp // 水印滞后于最新事件的差距 // 更新调度延迟指标 metricRegistry.timer("schedulingDelay").update(schedulingDelay, TimeUnit.MILLISECONDS) logger.info(s"Updated scheduling delay: $schedulingDelay ms") // val eventDelayMetricKey = "event" + "_" + "time" + "_" + "lag" // metricRegistry.timer(eventDelayMetricKey).update(eventTimeLag, TimeUnit.MILLISECONDS) // logger.info(s"Updated event lag: $eventTimeLag ms") // // val watermarkMetricKey = "watermark" + "_" + "time" + "_" + "lag" // metricRegistry.timer(watermarkMetricKey).update(watermarkLag, TimeUnit.MILLISECONDS) // logger.info(s"Updated watermark lag: $watermarkLag ms") // 获取处理时间:triggerExecution阶段的耗时 val processingDelay: lang.Long = progress.durationMs.get("triggerExecution") if(processingDelay > 0) { metricRegistry.timer("processingDelay").update(processingDelay, TimeUnit .MILLISECONDS) logger.info(s"Updated processing time: $processingDelay ms") }else{ logger.warn("Processing time is zero or not found in progress durationMs.") } if(numInputRows > 0){ metricRegistry.counter("inputRows").inc(numInputRows) }else{ logger.warn("numInputRows is zero or not found in progress.") } 代码找那个上报到graphite的numInputRows为什么是一个累加值
03-19
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值