123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147 |
- using NTMiner.Core.Kernels;
- using System;
- using System.Collections.Generic;
- using System.IO;
- using System.Linq;
- namespace NTMiner {
- public class Cleaner {
- public static Cleaner Instance { get; private set; } = new Cleaner();
- private Cleaner() {
- VirtualRoot.BuildEventPath<Per24HourEvent>("周期清理过期日志、过期内核包、过期下载文件", LogEnum.DevConsole, message => {
- AutoClear();
- }, this.GetType());
- }
- public void Clear() {
- CleanKernels();
- AutoClear();
- }
- private void AutoClear() {
- ClearLogs();
- ClearPackages();
- ClearDownload();
- }
- /// <summary>
- /// 启动时删除Temp/Download目录下的下载文件,启动时调一次即可
- /// </summary>
- private void ClearDownload() {
- try {
- foreach (var fileFullName in Directory.GetFiles(MinerClientTempPath.DownloadDirFullName)) {
- FileInfo fileInfo = new FileInfo(fileFullName);
- if (fileInfo.LastWriteTime.AddDays(1) < DateTime.Now) {
- try {
- File.Delete(fileFullName);
- }
- catch {
- }
- }
- }
- }
- catch (Exception e) {
- Logger.ErrorDebugLine(e);
- }
- }
- /// <summary>
- /// 清理掉下载时间超过1个月且服务器已经删除的内核包
- /// </summary>
- private void ClearPackages() {
- HashSet<string> packageFileNames = new HashSet<string>(StringComparer.OrdinalIgnoreCase);
- foreach (var kernel in NTMinerContext.Instance.ServerContext.KernelSet.AsEnumerable().ToArray()) {
- if (!string.IsNullOrEmpty(kernel.Package)) {
- packageFileNames.Add(kernel.Package);
- }
- }
- try {
- int n = 0;
- foreach (string fileFullName in Directory.GetFiles(HomePath.PackagesDirFullName)) {
- FileInfo fileInfo = new FileInfo(fileFullName);
- bool isPackageExitInServer = packageFileNames.Contains(fileInfo.Name);
- if (isPackageExitInServer) {
- continue;
- }
- if (fileInfo.LastWriteTime.AddMonths(1) < DateTime.Now) {
- try {
- File.Delete(fileFullName);
- }
- catch {
- }
- n++;
- }
- }
- if (n == 0) {
- Logger.OkDebugLine("没有过期的Package");
- }
- else {
- Logger.OkDebugLine("过期Package清理完成");
- }
- }
- catch (Exception e) {
- Logger.ErrorDebugLine(e);
- }
- }
- /// <summary>
- /// 删除除当前正在挖矿的内核外的包解压目录
- /// </summary>
- private void CleanKernels() {
- try {
- foreach (var kernelProcessName in NTMinerContext.Instance.ServerContext.KernelSet.GetAllKernelProcessNames()) {
- if (!NTMinerContext.Instance.IsMining || NTMinerContext.Instance.LockedMineContext.Kernel.GetProcessName() != kernelProcessName) {
- Windows.TaskKill.Kill(kernelProcessName, waitForExit: true);
- }
- }
- string currentKernelDir = string.Empty;
- var currentMineContext = NTMinerContext.Instance.LockedMineContext;
- if (currentMineContext != null && currentMineContext.Kernel != null) {
- currentKernelDir = currentMineContext.Kernel.GetKernelDirFullName();
- }
- foreach (string dir in Directory.GetDirectories(MinerClientTempPath.KernelsDirFullName)) {
- if (string.IsNullOrEmpty(currentKernelDir) || dir != currentKernelDir) {
- try {
- Directory.Delete(dir, recursive: true);
- }
- catch (Exception e) {
- Logger.ErrorDebugLine(e);
- }
- }
- }
- }
- catch (Exception e) {
- Logger.ErrorDebugLine(e);
- }
- }
- private void ClearLogs() {
- try {
- List<string> toRemoves = new List<string>();
- foreach (var fileFullName in Directory.GetFiles(TempPath.TempLogsDirFullName)) {
- FileInfo fileInfo = new FileInfo(fileFullName);
- if (fileInfo.LastWriteTime.AddDays(7) < DateTime.Now) {
- toRemoves.Add(fileFullName);
- }
- }
- if (toRemoves.Count == 0) {
- Logger.OkDebugLine("没有过期的Log");
- }
- else {
- foreach (var fileFullName in toRemoves) {
- try {
- File.Delete(fileFullName);
- }
- catch {
- }
- }
- Logger.OkDebugLine("过期Log清理完成");
- }
- }
- catch (Exception e) {
- Logger.ErrorDebugLine(e);
- }
- }
- }
- }
|