Esempio n. 1
0
        public void NewTask(SpiderSettings settings)
        {
            DateTime beforWorkDt = DateTime.Now;

            string typeName = $"{this.GetType().Namespace}.{settings.ClassName}";

            // 实例化 Spider 对象
            var spider = (Spider)Activator.CreateInstance(Type.GetType(typeName));

            spider.importSettings(settings);

            // 开始任务工作
            try
            {
                spider.BeginWork();
            }
            catch (ThreadAbortException)
            {
                // 进程正在被中止
                // 不进行操作
            }
            catch (Exception e)
            {
                // 任务执行中抛出的错误被接住了...
                spider.LogError(e.Message);
                Logging.Error(e.ToString()); // 保存错误详情
            }

            // 任务执行完毕
            DateTime afterWorkDt = DateTime.Now;
            double   timeSpent   = afterWorkDt.Subtract(beforWorkDt).TotalSeconds;

            spider.Log("\n");
            spider.Log($">> 任务执行完毕 (执行耗时:{timeSpent.ToString()}s)");
            settings.BrowserJsRunFunc($"Task.get('{settings.TaskId}').taskIsEnd();"); // 报告JS任务结束

            Utils.ReleaseMemory(true);
        }
Esempio n. 2
0
 /// <summary>
 /// 任务日志表显示一条日志
 /// </summary>
 /// <param name="content"></param>
 /// <param name="level"></param>
 public void _Log(string content, string level = "")
 {
     Logging.Info("[" + TaskId + "]" + (!string.IsNullOrEmpty(level) ? $"[{level}]" : "") + " " + content);
     spiderSettings.BrowserJsRunFunc($"Task.log('{TaskId}', '{Utils.Base64Encode(content)}', '{level}', '{Utils.GetTimeStamp()}', true);");
 }