Как сделать параметр Dynami c в аннотации @Scheduled? - PullRequest
0 голосов
/ 19 июня 2020

У меня есть запланированное задание, и я хочу получить fixedRate динамически, но не могу решить, как это сделать.

FixedRate получает значение в миллисекундах, но я хочу указать время в часах. И я также попытался прочитать параметр из файла свойств и умножить его, но у меня не получилось. Как я могу это сделать?

package com.ipera.communicationsuite.scheduleds;

import com.ipera.communicationsuite.models.FreeDbSize;
import com.ipera.communicationsuite.repositories.interfaces.IFreeDbSizeRepository;
import com.ipera.communicationsuite.repositories.interfaces.settings.IPropertiesRepository;
import com.ipera.communicationsuite.utilities.mail.SMTPConnection;
import lombok.AllArgsConstructor;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.context.annotation.PropertySource;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;

import java.io.File;
import java.util.ArrayList;
import java.util.List;

@Component
@AllArgsConstructor
@PropertySource("classpath:scheduled.properties")
public class KeepAlive {
    private static Logger logger = LoggerFactory.getLogger(KeepAlive.class);

    private IFreeDbSizeRepository freeDbSizeRepository;
    private SMTPConnection smtpConnection;
    private IPropertiesRepository propertiesRepository;



    @Scheduled(fixedRateString ="${keepAlive.timer}")
    public void keepAliveMailSender() {
        StringBuilder content = new StringBuilder();
        ArrayList<File> files = getDrivers();
        List<FreeDbSize> list = freeDbSizeRepository.getFreeDbSize();
        FreeDbSize dbDiskInfo = freeDbSizeRepository.dbDiskSize();
        content.append("DB file size is: ").append(list.get(0).getType().equals("mdf") ? list.get(0).getFileSize() : list.get(1).getFileSize()).append(" MB\n")
                .append("DB log size is: ").append(list.get(0).getType().equals("ldf") ? list.get(0).getFileSize() : list.get(1).getFileSize()).append(" MB\n");
        propertiesRepository.updateByKey("DatabaseSize", list.get(0).getType().equals("mdf") ? list.get(0).getFileSize().toString() : list.get(1).getFileSize().toString());
        propertiesRepository.updateByKey("DatabaseLogSize", list.get(0).getType().equals("ldf") ? list.get(0).getFileSize().toString() : list.get(1).getFileSize().toString());
        propertiesRepository.updateByKey("FreeDiskSpaceForDb", dbDiskInfo.getFreeSpace().toString());
        for (int i = 0; i < files.size(); i++) {
            content.append("Free size for driver ").append(files.get(i)).append(" is ").append(files.get(i).getFreeSpace() / (1024 * 1024)).append(" MB\n");
            propertiesRepository.createIfNotExistOrUpdate(("FreeSpaceInDisk".concat(Character.toString(files.get(i).toString().charAt(0)))), Long.toString(files.get(i).getFreeSpace() / (1024 * 1024)));
        }
        if (dbDiskInfo.getName().equals("-1")) {
            content.append("This application has not permission to run query for calculate free size of disk.");
        } else {
            content.append("Free size of disk which contains Db is: ").append(dbDiskInfo.getFreeSpace());
        }
        smtpConnection.sendMail(content.toString(), "Server Is Up!!!", "fkalabalikoglu@iperasolutions.com", "", "", "", "");
        logger.info("KeepAlive has runned.");

    }


    public ArrayList<File> getDrivers() {
        ArrayList<File> list = new ArrayList<>();

        File[] drives = File.listRoots();
        if (drives != null && drives.length > 0) {
            for (File aDrive : drives) {
                list.add(aDrive);
            }

        }
        return list;
    }
}

А также мой собственный файл здесь:

keepAlive.timer=86400000

1 Ответ

0 голосов
/ 19 июня 2020

Вы можете использовать SpEL в своей аннотации, например:

@Scheduled(fixedRateString ="#{new Long('${keepAlive.timer}') * 1000 * 3600}")

, чтобы вычислить выражение. Итак, keepAlive.timer будет количеством часов.

Но на мой взгляд это было бы некрасивым решением. Я бы предпочел поместить его в свойствах, как у вас сейчас, и просто добавить комментарий вроде:

# 24 hours is: 1000 * 3600 * 24  
keepAlive.timer=86400000

Другой способ использовать часы - использовать атрибут cron , который дает вам больше гибкость, но перед использованием может потребоваться некоторое изучение:

В вашем коде:

@Scheduled(cron = "${keepAlive.timer}")

и выражение cron в ваших свойствах - например, например:

keepAlive.timer="*/60 00 21 * * ?"

Это будет запускаться каждый день @ 21.00

Обратите внимание на это «* / 60», оно должно также принимать здесь «0», но в моем случае это не

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...