林炳文Evankaka原创作品。转载请注明出处http://blog.csdn.net/evankaka

一、   Quartz存储与持久化

         Quartz提供两种基本作业存储类型。第一种类型叫做RAMJobStore,第二种类型叫做JDBC作业存储。在默认情况下Quartz将任务调度的运行信息保存在内存中,这种方法提供了最佳的性能,因为内存中数据访问最快。不足之处是缺乏数据的持久性,当程序路途停止或系统崩溃时,所有运行的信息都会丢失。

         比如我们希望安排一个执行100次的任务,如果执行到50次时系统崩溃了,系统重启时任务的执行计数器将从0开始。在大多数实际的应用中,我们往往并不需要保存任务调度的现场数据,因为很少需要规划一个指定执行次数的任务。对于仅执行一次的任务来说,其执行条件信息本身应该是已经持久化的业务数据(如锁定到期解锁任务,解锁的时间应该是业务数据),当执行完成后,条件信息也会相应改变。当然调度现场信息不仅仅是记录运行次数,还包括调度规则、JobDataMap中的数据等等。

        如果确实需要持久化任务调度信息,Quartz允许你通过调整其属性文件,将这些信息保存到数据库中。使用数据库保存任务调度信息后,即使系统崩溃后重新启动,任务的调度信息将得到恢复。如前面所说的例子,执行50次崩溃后重新运行,计数器将从51开始计数。使用了数据库保存信息的任务称为持久化任务。

对比

类型

优点

缺点

RAMJobStore

不要外部数据库,配置容易,运行速度快

因为调度程序信息是存储在被分配给JVM的内存里面,所以,当应用程序停止运行时,所有调度信息将被丢失。另外因为存储到JVM内存里面,所以可以存储多少个JobTrigger将会受到限制

JDBC作业存储

支持集群,因为所有的任务信息都会保存到数据库中,可以控制事物,还有就是如果应用服务器关闭或者重启,任务信息都不会丢失,并且可以恢复因服务器关闭或者重启而导致执行失败的任务

运行速度的快慢取决与连接数据库的快慢


二、Quartz存储实例

本文工程免费下载

下面开始说实现的步骤吧:


2.1、建立数据存储表

        因为需要把quartz的数据保存到数据库,所以要建立相关的数据库。这个可以从下载到的quartz包里面找到对应的sql脚本,目前可以支持mysql,DB2,oracle等主流的数据库,自己可以根据项目需要选择合适的脚本运行。

        我的项目是mysql的,就在数据中建立了一个quartz的database,然后执行tables_mysql_innodb.sql脚本建表。其中脚本 文件位于:E:\JarCom\quartz-2.2.1\docs\dbTables(根据你Quartz放置的目录会不同)

然后打开MySql的终端:

先建立一个数据库,名为quartz;

然后执行脚本:

运行结果:

首先会出现如下错误:

这里有四张数据表创建失败。

解决方法:

将tables_mysql_innodb.sql中的TYENGINEPE=InnoDB全部都替换成ENGINE=InnoDB;

再次执行:


表示数据库表创建成功了


表建立好后可以看到相关的table

+————————–+
| Tables_in_quartz         |
+————————–+
| QRTZ_BLOB_TRIGGERS       |
| QRTZ_CALENDARS           |
| QRTZ_CRON_TRIGGERS       |
| QRTZ_FIRED_TRIGGERS      |
| QRTZ_JOB_DETAILS         |
| QRTZ_LOCKS               |
| QRTZ_PAUSED_TRIGGER_GRPS |
| QRTZ_SCHEDULER_STATE     |
| QRTZ_SIMPLE_TRIGGERS     |
| QRTZ_SIMPROP_TRIGGERS    |
| QRTZ_TRIGGERS            |
+————————–+

2.2、新建工程并导入包

新建一个java工程,导入相关的jar包

这里我就不多说了,可以到官网上去下载,本文使用的是最新的2,2.1

quartz:http://www.quartz-scheduler.org/

及mySql操作的包,和一个commons-lang包,整个工作最终目录如下:



然后,需要在项目中加上对应的配置。

2.3、首先是quartz.properties的配置

  1. # Default Properties file for use by StdSchedulerFactory  
  2. # to create a Quartz Scheduler Instance, if a different  
  3. # properties file is not explicitly specified.  
  4. #  
  5.    
  6. #集群配置  
  7. org.quartz.scheduler.instanceName: DefaultQuartzScheduler  
  8. org.quartz.scheduler.rmi.export: false  
  9. org.quartz.scheduler.rmi.proxy: false  
  10. org.quartz.scheduler.wrapJobExecutionInUserTransaction: false  
  11.    
  12. org.quartz.threadPool.class: org.quartz.simpl.SimpleThreadPool  
  13. org.quartz.threadPool.threadCount: 10  
  14. org.quartz.threadPool.threadPriority: 5  
  15. org.quartz.threadPool.threadsInheritContextClassLoaderOfInitializingThread: true  
  16.    
  17. org.quartz.jobStore.misfireThreshold: 60000  
  18.    
  19. #============================================================================  
  20. # Configure JobStore  
  21. #============================================================================  
  22.    
  23. #默认配置,数据保存到内存  
  24. #org.quartz.jobStore.class: org.quartz.simpl.RAMJobStore  
  25. #持久化配置  
  26. org.quartz.jobStore.class:org.quartz.impl.jdbcjobstore.JobStoreTX  
  27. org.quartz.jobStore.driverDelegateClass:org.quartz.impl.jdbcjobstore.StdJDBCDelegate  
  28. org.quartz.jobStore.useProperties:true  
  29. #数据库表前缀  
  30. #org.quartz.jobStore.tablePrefix:qrtz_  
  31. #org.quartz.jobStore.dataSource:qzDS  
  32.    
  33. #============================================================================  
  34. # Configure Datasources  
  35. #============================================================================  
  36. #JDBC驱动  
  37. #org.quartz.dataSource.qzDS.driver:com.mysql.jdbc.Driver  
  38. #org.quartz.dataSource.qzDS.URL:jdbc:mysql://localhost:3306/quartz  
  39. #org.quartz.dataSource.qzDS.user:root  
  40. #org.quartz.dataSource.qzDS.password:christmas258@  
  41. #org.quartz.dataSource.qzDS.maxConnection:10  
# Default Properties file for use by StdSchedulerFactory
# to create a Quartz Scheduler Instance, if a different# properties file is not explicitly specified. ##集群配置 org.quartz.scheduler.instanceName: DefaultQuartzScheduler org.quartz.scheduler.rmi.export: false org.quartz.scheduler.rmi.proxy: false org.quartz.scheduler.wrapJobExecutionInUserTransaction: falseorg.quartz.threadPool.class: org.quartz.simpl.SimpleThreadPool org.quartz.threadPool.threadCount: 10 org.quartz.threadPool.threadPriority: 5 org.quartz.threadPool.threadsInheritContextClassLoaderOfInitializingThread: trueorg.quartz.jobStore.misfireThreshold: 60000#============================================================================# Configure JobStore#============================================================================#默认配置,数据保存到内存#org.quartz.jobStore.class: org.quartz.simpl.RAMJobStore#持久化配置 org.quartz.jobStore.class:org.quartz.impl.jdbcjobstore.JobStoreTX org.quartz.jobStore.driverDelegateClass:org.quartz.impl.jdbcjobstore.StdJDBCDelegate org.quartz.jobStore.useProperties:true#数据库表前缀#org.quartz.jobStore.tablePrefix:qrtz_#org.quartz.jobStore.dataSource:qzDS#============================================================================# Configure Datasources#============================================================================#JDBC驱动#org.quartz.dataSource.qzDS.driver:com.mysql.jdbc.Driver#org.quartz.dataSource.qzDS.URL:jdbc:mysql://localhost:3306/quartz#org.quartz.dataSource.qzDS.user:root#org.quartz.dataSource.qzDS.password:christmas258@#org.quartz.dataSource.qzDS.maxConnection:10
其中org.quartz.jobStore.class是指明quartz的持久化用数据库来保存,

而org.quartz.jobStore.driverDelegateClass是根据选择的数据库类型不同而不同,我这里的是mysql,所以是org.quartz.impl.jdbcjobstore.StdJDBCDelegate。

Quartz的属性配置文件主要包括三方面的信息:

1)集群信息;

2)调度器线程池;

3)任务调度现场数据的保存。

·调度器属性

第一部分有两行,分别设置调度器的实例名(instanceName) 和实例 ID (instanceId)。属性 org.quartz.scheduler.instanceName 可以是你喜欢的任何字符串。它用来在用到多个调度器区分特定的调度器实例。多个调度器通常用在集群环境中。现在的话,设置如下的一个字符串就行:org.quartz.scheduler.instanceName :DefaultQuartzScheduler实际上,这也是当你没有该属性配置时的默认值。

调度器的第二个属性是 org.quartz.scheduler.instanceId。和 instaneName 属性一样,instanceId 属性也允许任何字符串。这个值必须是在所有调度器实例中是唯一的,尤其是在一个集群当中。假如你想 Quartz 帮你生成这个值的话,可以设置为 AUTO。如果 Quartz 框架是运行在非集群环境中,那么自动产生的值将会是 NON_CLUSTERED。假如是在集群环境下使用 Quartz,这个值将会是主机名加上当前的日期和时间。大多情况下,设置为 AUTO 即可。
·线程池属性

接下来的部分是设置有关线程必要的属性值,这些线程在 Quartz 中是运行在后台担当重任的。threadCount 属性控制了多少个工作者线程被创建用来处理 Job。原则上是,要处理的 Job 越多,那么需要的工作者线程也就越多。threadCount 的数值至少为 1。Quartz 没有限定你设置工作者线程的最大值,但是在多数机器上设置该值超过100的话就会显得相当不实用了,特别是在你的 Job 执行时间较长的情况下。这项没有默认值,所以你必须为这个属性设定一个值。

threadPriority 属性设置工作者线程的优先级。优先级别高的线程比级别低的线程更优先得到执行。threadPriority 属性的最大值是常量 java.lang.Thread.MAX_PRIORITY,等于10。最小值为常量 java.lang.Thread.MIN_PRIORITY,为1。这个属性的正常值是 Thread.NORM_PRIORITY,为5。大多情况下,把它设置为5,这也是没指定该属性的默认值。

最后一个要设置的线程池属性是 org.quartz.threadPool.class。这个值是一个实现了 org.quartz.spi.ThreadPool 接口的类的全限名称。Quartz 自带的线程池实现类是 org.quartz.smpl.SimpleThreadPool,它能够满足大多数用户的需求。这个线程池实现具备简单的行为,并经很好的测试过。它在调度器的生命周期中提供固定大小的线程池。你能根据需求创建自己的线程池实现,如果你想要一个随需可伸缩的线程池时也许需要这么做。这个属性没有默认值,你必须为其指定值。

·作业存储设置

作业存储部分的设置描述了在调度器实例的生命周期中,Job 和 Trigger 信息是如何被存储的。我们还没有谈论到作业存储和它的目的;因为对当前例子是非必的,所以我们留待以后说明。现在的话,你所要了解的就是我们存储调度器信息在内存中而不是在关系型数据库中就行了。

把调度器信息存储在内存中非常的快也易于配置。当调度器进程一旦被终止,所有的 Job 和 Trigger 的状态就丢失了。要使 Job 存储在内存中需通过设置  org.quartz.jobStrore.class 属性为 org.quartz.simpl.RAMJobStore。假如我们不希望在 JVM 退出之后丢失调度器的状态信息的话,我们可以使用关系型数据库来存储这些信息。这需要另一个作业存储(JobStore) 实现,我们在后面将会讨论到。第五章“Cron Trigger 和其他”和第六章“作业存储和持久化”会提到你需要用到的不同类型的作业存储实现。

2.4、创建Job类

package com.mucfc;import java.text.SimpleDateFormat;
import java.util.Date;import org.apache.log4j.Logger;
import org.quartz.Job;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;public class MyJob implements Job{private static final Logger logger = Logger.getLogger(MyJob.class);  @Overridepublic void execute(JobExecutionContext context)throws JobExecutionException {System.out.println("Hello quzrtz  "+new SimpleDateFormat("yyyy-MM-dd HH:mm:ss ").format(new Date()));}}

2.5、创建Job的执行类:

  1. package com.mucfc;  
  2.   
  3. import java.text.ParseException;  
  4. import java.util.List;  
  5.   
  6. import org.apache.commons.lang.StringUtils;  
  7. import org.quartz.CronScheduleBuilder;  
  8. import org.quartz.Job;  
  9. import org.quartz.JobBuilder;  
  10. import org.quartz.JobDetail;  
  11. import org.quartz.JobKey;  
  12. import org.quartz.Scheduler;  
  13. import org.quartz.SchedulerException;  
  14. import org.quartz.SchedulerFactory;  
  15. import org.quartz.SimpleScheduleBuilder;  
  16. import org.quartz.SimpleTrigger;  
  17. import org.quartz.Trigger;  
  18. import org.quartz.TriggerBuilder;  
  19. import org.quartz.TriggerKey;  
  20. import org.quartz.impl.StdSchedulerFactory;  
  21. import org.springframework.beans.factory.annotation.Autowired;  
  22. import org.springframework.context.ApplicationContext;  
  23. import org.springframework.context.support.ClassPathXmlApplicationContext;  
  24.   
  25. public class QuartzTest {  
  26.   
  27.     private static SchedulerFactory sf = new StdSchedulerFactory();  
  28.     private static String JOB_GROUP_NAME = “ddlib”;  
  29.     private static String TRIGGER_GROUP_NAME = “ddlibTrigger”;  
  30.     public static void main(String[] args) throws SchedulerException,  
  31.             ParseException {  
  32.         startSchedule();  
  33.         //resumeJob();  
  34.     }  
  35.     /** 
  36.      * 开始一个simpleSchedule()调度 
  37.      */  
  38.     public static void startSchedule() {  
  39.         try {  
  40.             // 1、创建一个JobDetail实例,指定Quartz  
  41.             JobDetail jobDetail = JobBuilder.newJob(MyJob.class)  
  42.             // 任务执行类  
  43.                     .withIdentity(”job1_1”“jGroup1”)  
  44.                     // 任务名,任务组  
  45.                     .build();  
  46.             // 2、创建Trigger  
  47.             SimpleScheduleBuilder builder = SimpleScheduleBuilder  
  48.                     .simpleSchedule()  
  49.                     // 设置执行次数  
  50.                     .repeatSecondlyForTotalCount(100);  
  51.             Trigger trigger = TriggerBuilder.newTrigger()  
  52.                     .withIdentity(”trigger1_1”“tGroup1”).startNow()  
  53.                     .withSchedule(builder).build();  
  54.             // 3、创建Scheduler  
  55.             Scheduler scheduler = StdSchedulerFactory.getDefaultScheduler();  
  56.             scheduler.start();  
  57.             // 4、调度执行  
  58.             scheduler.scheduleJob(jobDetail, trigger);  
  59.             try {  
  60.                 Thread.sleep(60000);  
  61.             } catch (InterruptedException e) {  
  62.                 e.printStackTrace();  
  63.             }  
  64.   
  65.             scheduler.shutdown();  
  66.   
  67.         } catch (SchedulerException e) {  
  68.             e.printStackTrace();  
  69.         }  
  70.     }  
  71.   
  72.     /** 
  73.      * 从数据库中找到已经存在的job,并重新开户调度 
  74.      */  
  75.     public static void resumeJob() {  
  76.         try {  
  77.   
  78.             SchedulerFactory schedulerFactory = new StdSchedulerFactory();  
  79.             Scheduler scheduler = schedulerFactory.getScheduler();  
  80.             // ①获取调度器中所有的触发器组  
  81.             List<String> triggerGroups = scheduler.getTriggerGroupNames();  
  82.             // ②重新恢复在tgroup1组中,名为trigger1_1触发器的运行  
  83.             for (int i = 0; i < triggerGroups.size(); i++) {  
  84.                 List<String> triggers = scheduler.getTriggerGroupNames();  
  85.                 for (int j = 0; j < triggers.size(); j++) {  
  86.                     Trigger tg = scheduler.getTrigger(new TriggerKey(triggers  
  87.                             .get(j), triggerGroups.get(i)));  
  88.                     // ②-1:根据名称判断  
  89.                     if (tg instanceof SimpleTrigger  
  90.                             && tg.getDescription().equals(”tgroup1.trigger1_1”)) {  
  91.                         // ②-1:恢复运行  
  92.                         scheduler.resumeJob(new JobKey(triggers.get(j),  
  93.                                 triggerGroups.get(i)));  
  94.                     }  
  95.                 }  
  96.   
  97.             }  
  98.             scheduler.start();  
  99.         } catch (Exception e) {  
  100.             e.printStackTrace();  
  101.   
  102.         }  
  103.     }  
  104. }  
package com.mucfc;import java.text.ParseException;
import java.util.List;import org.apache.commons.lang.StringUtils;
import org.quartz.CronScheduleBuilder;
import org.quartz.Job;
import org.quartz.JobBuilder;
import org.quartz.JobDetail;
import org.quartz.JobKey;
import org.quartz.Scheduler;
import org.quartz.SchedulerException;
import org.quartz.SchedulerFactory;
import org.quartz.SimpleScheduleBuilder;
import org.quartz.SimpleTrigger;
import org.quartz.Trigger;
import org.quartz.TriggerBuilder;
import org.quartz.TriggerKey;
import org.quartz.impl.StdSchedulerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;public class QuartzTest {private static SchedulerFactory sf = new StdSchedulerFactory();private static String JOB_GROUP_NAME = "ddlib";private static String TRIGGER_GROUP_NAME = "ddlibTrigger";public static void main(String[] args) throws SchedulerException,ParseException {startSchedule();//resumeJob();}/*** 开始一个simpleSchedule()调度*/public static void startSchedule() {try {// 1、创建一个JobDetail实例,指定QuartzJobDetail jobDetail = JobBuilder.newJob(MyJob.class)// 任务执行类.withIdentity("job1_1", "jGroup1")// 任务名,任务组.build();// 2、创建TriggerSimpleScheduleBuilder builder = SimpleScheduleBuilder.simpleSchedule()// 设置执行次数.repeatSecondlyForTotalCount(100);Trigger trigger = TriggerBuilder.newTrigger().withIdentity("trigger1_1", "tGroup1").startNow().withSchedule(builder).build();// 3、创建SchedulerScheduler scheduler = StdSchedulerFactory.getDefaultScheduler();scheduler.start();// 4、调度执行scheduler.scheduleJob(jobDetail, trigger);try {Thread.sleep(60000);} catch (InterruptedException e) {e.printStackTrace();}scheduler.shutdown();} catch (SchedulerException e) {e.printStackTrace();}}/*** 从数据库中找到已经存在的job,并重新开户调度*/public static void resumeJob() {try {SchedulerFactory schedulerFactory = new StdSchedulerFactory();Scheduler scheduler = schedulerFactory.getScheduler();// ①获取调度器中所有的触发器组List<String> triggerGroups = scheduler.getTriggerGroupNames();// ②重新恢复在tgroup1组中,名为trigger1_1触发器的运行for (int i = 0; i < triggerGroups.size(); i++) {List<String> triggers = scheduler.getTriggerGroupNames();for (int j = 0; j < triggers.size(); j++) {Trigger tg = scheduler.getTrigger(new TriggerKey(triggers.get(j), triggerGroups.get(i)));// ②-1:根据名称判断if (tg instanceof SimpleTrigger&& tg.getDescription().equals("tgroup1.trigger1_1")) {// ②-1:恢复运行scheduler.resumeJob(new JobKey(triggers.get(j),triggerGroups.get(i)));}}}scheduler.start();} catch (Exception e) {e.printStackTrace();}}
}

2.6、执行:

然后打开数据库,输入

use quartz;
select* from QRTZ_SIMPLE_TRIGGERS

然后把上面的程序停了,点击右上角的红框框

把主代码改成:

[java] view plain copy
print?
  1. public static void main(String[] args) throws SchedulerException,  
  2.             ParseException {  
  3.         //startSchedule();  
  4.         resumeJob();  
  5.     }  
public static void main(String[] args) throws SchedulerException,ParseException {//startSchedule();resumeJob();}

输出结果:


同时,查找数据中的表:

发现有变化 了。。TRIGGER_GROUP表示的执行的次数,TRIGGER_GROUP表示被激发的次数

来回的不断停止程序再重新开始程序,结果如下。

重新停止再打开后,TRIGGER_GROUP变为39,他会减去上一次运行中TRIGGER_GROUP的次数,TRIGGER_GROUP每次运行都会从0开始计算


然后等100次执行完后,这个调度就会从数据表中删除:

结果如下:


这时,该表中的记录已经变空。

值得注意的是,如果你使用JDBC保存任务调度数据时,当你运行代码

[java] view plain copy
print?
  1. startSchedule();  
  2. //resumeJob();  
startSchedule();
//resumeJob();
然后退出,当再次希望运行

[java] view plain copy
print?
  1. startSchedule();  
  2. //resumeJob();  
startSchedule();
//resumeJob();

时,系统将抛出JobDetail重名的异常:Unable to store Job with name: ‘job1_1’ and group: ‘jGroup1’, because one already exists with this identification.因为每次调用Scheduler#scheduleJob()时,Quartz都会将JobDetailTrigger的信息保存到数据库中,如果数据表中已经同名的JobDetailTrigger,异常就产生了。

这里再次运行应该这样做:

[java] view plain copy
print?
  1. //startSchedule();  
  2. resumeJob();  
//startSchedule();
resumeJob();


三、一些说明

一些相关的意义:

QRTZ_CALENDARS 以 Blob 类型存储 Quartz 的 Calendar 信息 
QRTZ_CRON_TRIGGERS 存储 Cron Trigger,包括Cron表达式和时区信息 
QRTZ_FIRED_TRIGGERS 存储与已触发的 Trigger 相关的状态信息,以及相联 Job的执行信息QRTZ_PAUSED_TRIGGER_GRPS 存储已暂停的 Trigger组的信息 
QRTZ_SCHEDULER_STATE 存储少量的有关 Scheduler 的状态信息,和别的Scheduler实例(假如是用于一个集群中) 
QRTZ_LOCKS 存储程序的悲观锁的信息(假如使用了悲观锁) 
QRTZ_JOB_DETAILS 存储每一个已配置的 Job 的详细信息 
QRTZ_JOB_LISTENERS 存储有关已配置的 JobListener的信息 
QRTZ_SIMPLE_TRIGGERS存储简单的Trigger,包括重复次数,间隔,以及已触的次数 
QRTZ_BLOG_TRIGGERS Trigger 作为 Blob 类型存储(用于 Quartz 用户用JDBC创建他们自己定制的 Trigger 类型,JobStore并不知道如何存储实例的时候) 
QRTZ_TRIGGER_LISTENERS 存储已配置的 TriggerListener的信息 
QRTZ_TRIGGERS 存储已配置的 Trigger 的信息 

————————————————————————————————–

quartz 持久化数据库表格字段解释
建表,SQL语句在dbTables文件夹中可以找到,介绍下主要的几张表: 
[sql] view plain copy
print?
  1. 表qrtz_job_details:保存job详细信息,该表需要用户根据实际情况初始化   
  2. job_name:集群中job的名字,该名字用户自己可以随意定制,无强行要求   
  3. job_group:集群中job的所属组的名字,该名字用户自己随意定制,无强行要求   
  4. job_class_name:集群中个notejob实现类的完全包名,quartz就是根据这个路径到classpath找到该job类   
  5. is_durable:是否持久化,把该属性设置为1,quartz会把job持久化到数据库中   
  6. job_data:一个blob字段,存放持久化job对象   
  7.   
  8. 表qrtz_triggers: 保存trigger信息   
  9. trigger_name:trigger的名字,该名字用户自己可以随意定制,无强行要求   
  10. trigger_group:trigger所属组的名字,该名字用户自己随意定制,无强行要求   
  11. job_name:qrtz_job_details表job_name的外键   
  12. job_group:qrtz_job_details表job_group的外键   
  13. trigger_state:当前trigger状态,设置为ACQUIRED,如果设置为WAITING,则job不会触发   
  14. trigger_cron:触发器类型,使用cron表达式   
  15.   
  16. 表qrtz_cron_triggers:存储cron表达式表   
  17. trigger_name:qrtz_triggers表trigger_name的外键   
  18. trigger_group:qrtz_triggers表trigger_group的外键   
  19. cron_expression:cron表达式   
  20.    
  21. 表qrtz_scheduler_state:存储集群中note实例信息,quartz会定时读取该表的信息判断集群中每个实例的当前状态   
  22. instance_name:之前配置文件中org.quartz.scheduler.instanceId配置的名字,就会写入该字段,如果设置为AUTO,quartz会根据物理机名和当前时间产生一个名字   
  23. last_checkin_time:上次检查时间   
  24. checkin_interval:检查间隔时间   
      表qrtz_job_details:保存job详细信息,该表需要用户根据实际情况初始化 job_name:集群中job的名字,该名字用户自己可以随意定制,无强行要求 job_group:集群中job的所属组的名字,该名字用户自己随意定制,无强行要求 job_class_name:集群中个notejob实现类的完全包名,quartz就是根据这个路径到classpath找到该job类 is_durable:是否持久化,把该属性设置为1,quartz会把job持久化到数据库中 job_data:一个blob字段,存放持久化job对象 表qrtz_triggers: 保存trigger信息 trigger_name:trigger的名字,该名字用户自己可以随意定制,无强行要求 trigger_group:trigger所属组的名字,该名字用户自己随意定制,无强行要求 job_name:qrtz_job_details表job_name的外键 job_group:qrtz_job_details表job_group的外键 trigger_state:当前trigger状态,设置为ACQUIRED,如果设置为WAITING,则job不会触发 trigger_cron:触发器类型,使用cron表达式 表qrtz_cron_triggers:存储cron表达式表 trigger_name:qrtz_triggers表trigger_name的外键 trigger_group:qrtz_triggers表trigger_group的外键 cron_expression:cron表达式 表qrtz_scheduler_state:存储集群中note实例信息,quartz会定时读取该表的信息判断集群中每个实例的当前状态 instance_name:之前配置文件中org.quartz.scheduler.instanceId配置的名字,就会写入该字段,如果设置为AUTO,quartz会根据物理机名和当前时间产生一个名字 last_checkin_time:上次检查时间 checkin_interval:检查间隔时间 


配置quartz.properties文件:
[html] view plain copy
print?
  1. #调度标识名 集群中每一个实例都必须使用相同的名称 org.quartz.scheduler.instanceName:scheduler  
  2. #ID设置为自动获取 每一个必须不同 org.quartz.scheduler.instanceId :AUTO  
  3. #数据保存方式为持久化 org.quartz.jobStore.class :org.quartz.impl.jdbcjobstore.JobStoreTX  
  4. #数据库平台 org.quartz.jobStore.driverDelegateClass:org.quartz.impl.jdbcjobstore.oracle.weblogic.WebLogicOracleDelegate#数据库别名 随便取org.quartz.jobStore.dataSource : myXADS  
  5. #表的前缀 org.quartz.jobStore.tablePrefix : QRTZ_  
  6. #设置为TRUE不会出现序列化非字符串类到 BLOB 时产生的类版本问题org.quartz.jobStore.useProperties : true  
  7. #加入集群 org.quartz.jobStore.isClustered : true  
  8. #调度实例失效的检查时间间隔 org.quartz.jobStore.clusterCheckinInterval:20000   
  9. #容许的最大作业延长时间 org.quartz.jobStore.misfireThreshold :60000  
  10. #ThreadPool 实现的类名 org.quartz.threadPool.class:org.quartz.simpl.SimpleThreadPool  
  11. #线程数量 org.quartz.threadPool.threadCount : 10  
  12. #线程优先级 org.quartz.threadPool.threadPriority : 5  
  13. #自创建父线程org.quartz.threadPool.threadsInheritContextClassLoaderOfInitializingThread: true   
  14. #设置数据源org.quartz.dataSource.myXADS.jndiURL: CT  
  15. #jbdi类名 org.quartz.dataSource.myXADS.java.naming.factory.initial :weblogic.jndi.WLInitialContextFactory#URLorg.quartz.dataSource.myXADS.java.naming.provider.url:=t3://localhost:7001  
  16. 【注】:在J2EE工程中如果想用数据库管理Quartz的相关信息,就一定要配置数据源,这是Quartz的要求。  
#调度标识名 集群中每一个实例都必须使用相同的名称 org.quartz.scheduler.instanceName:scheduler
#ID设置为自动获取 每一个必须不同 org.quartz.scheduler.instanceId :AUTO#数据保存方式为持久化 org.quartz.jobStore.class :org.quartz.impl.jdbcjobstore.JobStoreTX#数据库平台 org.quartz.jobStore.driverDelegateClass:org.quartz.impl.jdbcjobstore.oracle.weblogic.WebLogicOracleDelegate#数据库别名 随便取org.quartz.jobStore.dataSource : myXADS#表的前缀 org.quartz.jobStore.tablePrefix : QRTZ_#设置为TRUE不会出现序列化非字符串类到 BLOB 时产生的类版本问题org.quartz.jobStore.useProperties : true#加入集群 org.quartz.jobStore.isClustered : true#调度实例失效的检查时间间隔 org.quartz.jobStore.clusterCheckinInterval:20000 #容许的最大作业延长时间 org.quartz.jobStore.misfireThreshold :60000#ThreadPool 实现的类名 org.quartz.threadPool.class:org.quartz.simpl.SimpleThreadPool#线程数量 org.quartz.threadPool.threadCount : 10#线程优先级 org.quartz.threadPool.threadPriority : 5#自创建父线程org.quartz.threadPool.threadsInheritContextClassLoaderOfInitializingThread: true #设置数据源org.quartz.dataSource.myXADS.jndiURL: CT#jbdi类名 org.quartz.dataSource.myXADS.java.naming.factory.initial :weblogic.jndi.WLInitialContextFactory#URLorg.quartz.dataSource.myXADS.java.naming.provider.url:=t3://localhost:7001 【注】:在J2EE工程中如果想用数据库管理Quartz的相关信息,就一定要配置数据源,这是Quartz的要求。

林炳文Evankaka原创作品。转载请注明出处http://blog.csdn.net/evankaka

本文工程免费下载

查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. crontab命令参数详解

    crontab文件的含义:用户所建立的crontab文件中,每一行都代表一项任务,每行的每个字段代表一项设置,它的格式共分为六个字段,前五段是时间设定段,第六段是要执行的命令段,格式如下:minute hour day month week command其中:minute: 表示分钟,可以是从0到59…...

    2024/4/15 18:32:28
  2. 【Android 开发入门】我为什么要在Android找工作越来越难的时候开始学习它

    首先,Android是不是真的找工作越来越难呢?这个可能是大家最关心的。这个受大的经济环境以及行业发展前景的影响,同时也和个人因素有关。2016-08-26近期一方面是所在的公司招聘Java开发人员很难招到合适的,投简历的人很少;而另一方面,经常听身边的人说Android、iOS方面找工…...

    2024/4/21 0:48:50
  3. 通俗易懂的三极管工作原理

    1晶体三极管简介晶体三极管是p型和n型半导体的有机结合,两个pn结之间的相互影响,使pn结的功能发生了质的飞跃,具有电流放大作用。晶体三极管按结构粗分有npn型和pnp型两种类型。如图2-17所示。(用Q、VT、PQ表示)三极管之所以具有电流放大作用,首先,制造工艺上的两个特点:…...

    2024/4/20 4:39:25
  4. 【Quartz实战】quartz-2.2.3源码分析

    一、quartz简介Quartz是OpenSymphony开源组织在Job scheduling领域又一个开源项目,它可以与J2EE与J2SE应用程序相结合(Spring集成Quartz的介绍)也可以单独使用。Quartz可以用来创建简单或为运行十个,百个,甚至是好几万个Jobs这样复杂的程序。Jobs可以做成标准的Java组件或…...

    2024/4/28 17:45:33
  5. crontab定时任务不执行的解决办法

    1、查看crontab执行记录如果出现了crontab定时任务不执行的情况,首先需要定位问题,那么就需要通过日志来确定问题所在。crontab的日志位置一般位于/var/log/cron,利用下面的语句即可查看日志。1 tail -f /var/log/cron上面的/var/log/cron只会记录是否执行了某些计划的脚本,…...

    2024/5/3 14:10:45
  6. 三极管原理及贴片封装注意

    三极管目录 1 三极管 2 晶体三极管的结构和类型 3 三极管的材料 4 三极管的封装形式和管脚识别 5 晶体三极管的电流放大作用 6 使用多用电表检测三极管 7 半导体三极管的参数 8 半导体三极管的型号 9 三极管的选用 10 三极管的其他应用 11 中、小功率三极管的检测 1…...

    2024/4/25 10:16:42
  7. Quartz使用-入门使用(java定时任务实现)

    注:这里使用的是Quartz1.6.5版本(包:quartz-1.6.5.jar)//测试main函数 //QuartzTest.java package quartzPackage;import java.text.SimpleDateFormat; import java.util.Date;public class QuartzTest {/** *//*** @param args*/public static void main(String[] args) {//…...

    2024/5/3 12:32:43
  8. 恋爱指南----《强迫的爱》

    《强迫的爱》| 关于作者苏珊福沃德,国际知名心理治疗师,拥有20多年的心理治疗经验。是婚姻关系,恋爱关系及人际关系研究领域的顶级专家。她的代表作曾连续44周在《纽约时报》畅销书榜单排行第一,仅在美国就卖出了200多万册。在心理学方面,苏珊福沃德最擅长的就是剖析人物心…...

    2024/4/21 0:48:44
  9. Crontab的简单使用和创建第一个自动定时任务执行python脚本

    在LINUX中,周期执行的任务一般由cron这个守护进程来处理[ps -ef|grep cron]。cron读取一个或多个配置文件,这些配置文件中包含了命令行及其调用时间。cron的配置文件称为“crontab”,是“cron table”的简写。crontab是一个命令,常见于Unix和类Unix的操作系统之中,用于设置…...

    2024/4/21 0:48:44
  10. crond和crontab的简单概念和应用

    今天我们来分享一下关于crond和crontab的简单概念和应用。crond是工具,是linux的一个定时执行的服务项,可以通过crontab 命令添加或者编辑需要定时执行的任务。crontab是一个命令qs,常见于Unix和类Unix的操作系统之中,用于设置周期性被执行的指令。该命令从标准输入设备读取…...

    2024/5/3 14:40:45
  11. Quartz+spring任务调度

    一、到官网下载quartz相应的压缩包,maven引用如下: <!-- 添加quartz定时任务包 --><dependency><groupId>org.quartz-scheduler</groupId><artifactId>quartz</artifactId><version>2.2.3</version></dep…...

    2024/4/21 0:48:43
  12. 全球60个线上学习资源网站分享!

    说明, 这个我没有把网站都复制出来,自己可以谷歌搜索,基本上第一个结果出来就是的。我看到这个觉得不错,就整理一下分享到博客里面,觉得需要的可以看看,日后自己需要也方便寻找。觉得有帮助,可以给我点个赞O(∩_∩)O哈哈~ 如果你不能访问谷歌的话,可以使用下面俩个搜索…...

    2024/5/3 14:36:20
  13. 三极管的工作原理-1

    对三极管放大作用的理解,切记一点:能量不会无缘无故的产生,所以,三极管一定不会产生能量。 但三极管厉害的地方在于:它可以通过小电流去控制大电流。 放大的原理就在于:通过小的交流输入,控制大的静态直流。 假设三极管是个大坝,这个大坝奇怪的地方是,有两个阀门,一个…...

    2024/4/21 0:48:39
  14. linxu添加crontab定时器

    使用crontab创建定时器任务1.安装crontab yum install vixie -cronyum install crontabs 2.安装后,开启crontab服务service crond start查看crontab服务状态:service crond status 在命令行输入: crontab -e 然后添加相应的任务,wq存盘退出。举例,每十分钟执行一次test.sh 如…...

    2024/4/21 0:48:38
  15. Quartz动态改变任务时间

    基于quartz-2.2 的动态任务调度 Quartz是一个完全由java编写的开源作业调度框架。 调度器 Quartz框架的核心是调度器。调度器负责管理Quartz应用运行时环境。调度器不是靠自己做所有的工作,而是依赖框架内一些非常重要的部件。Quartz不仅仅是线程和线程管理。为确保可伸缩性,…...

    2024/4/21 0:48:37
  16. 好的生活习惯,带来好的身体

    威力午睡。越来越多医学报告证实,工作日下午抽空睡20-30分钟,有助于提升工作效率、降低错误以及减少人际冲突。这种短而有效的充电方法。 学习新嗜好。抽空报名学习一种新语言、球类运动或是乐器,给你不随意加班的正当理由,又可以认识新朋友,灵活你的大脑与创意,提…...

    2024/5/3 13:30:12
  17. DSP_F28335入门(5)——通用数字量输入/输出GPIO

    通用价格数字量输入/输出接口,简称GPIO。 方向寄存器GPxDIR配置数字量I/O的方向。 GPxQUAL对信号进行量化限制,从而可以消除数字量I/O引脚的噪声干扰。 GPxQSEL配置信号采样次数为3或6,当输入信号经过3个或6个采样周期都保持一致,输入信号才被认为是个有效的信号,否则保持…...

    2024/4/20 20:56:33
  18. 三极管工作原理二

    一、很多初学者都会认为三极管是两个 PN 结的简单凑合(如图1)。这种想法是错误的,两个二极管的组合不能形成一个三极管。我们以 NPN 型三极管为例(见图 2 ),两个 PN 结共用了一个 P 区 —— 基区,基区做得极薄,只有几微米到几十微米,正是靠着它把两个 PN 结有机地结合…...

    2024/4/26 15:53:25
  19. quartz数据库方式配置

    项目中一般都会用到定时任务,spring在定时任务这块有很好的封装,早起版本,quartz的jar是独立出来的,现在spring将quartz的jar包集成了进去,springBoot也只需引入spring-boot-starter-quartz就ok了,非常简便,但也不得不服源代码开发大牛,我们想要知道底层,得自己去研究…...

    2024/4/20 20:56:30
  20. KeyStone 架构DSP C66x系列高端研发平台

    革命性的新架构 TI推出的TMS320C665x系列,采用KeyStone 架构,使用灵活,可以混合使用单核或多核 DSP(定点和浮点),可实现有针对性的协处理和硬件加速以及优化的内核间/元件间通信。TI称C665x为“高斯”,由数学家高斯的名字而来。该多核平台的处理和低功耗能力特别适用于市…...

    2024/4/20 4:43:28

最新文章

  1. Windows Server 2019虚拟机安装

    目录 第一步、准备工作 第二步、部署虚拟机 第三步、 Windows Server 2019系统启动配置 第一步、准备工作 下载Windows Server 2019系统镜像 官网下载地址&#xff1a;Windows Server 2019 | Microsoft Evaluation Center VMware Workstation 17下载地址&#xff1a; 链…...

    2024/5/8 17:41:34
  2. 梯度消失和梯度爆炸的一些处理方法

    在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言&#xff0c;在此感激不尽。 权重和梯度的更新公式如下&#xff1a; w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...

    2024/5/7 10:36:02
  3. 【超简单】基于PaddleSpeech搭建个人语音听写服务

    一、【超简单】之基于PaddleSpeech搭建个人语音听写服务 1.需求分析 亲们,你们要写会议纪要嘛?亲们,你们要写会议纪要嘛?亲们,你们要写会议纪要嘛?当您面对成吨的会议录音,着急写会议纪要而不得不愚公移山、人海战术?听的头晕眼花,听的漏洞百出,听的怀疑人生,那么你…...

    2024/5/8 8:00:20
  4. ChatGPT 初学者指南

    原文&#xff1a;ChatGPT for Beginners 译者&#xff1a;飞龙 协议&#xff1a;CC BY-NC-SA 4.0 介绍 如果您一直关注新闻和趋势&#xff0c;您可能已经在某个地方读到或听到过&#xff0c;Sam Altman 的生成式人工智能平台 ChatGPT 已经将人工智能推向了一个新的高度 - 许多…...

    2024/5/8 7:48:14
  5. 【外汇早评】美通胀数据走低,美元调整

    原标题:【外汇早评】美通胀数据走低,美元调整昨日美国方面公布了新一期的核心PCE物价指数数据,同比增长1.6%,低于前值和预期值的1.7%,距离美联储的通胀目标2%继续走低,通胀压力较低,且此前美国一季度GDP初值中的消费部分下滑明显,因此市场对美联储后续更可能降息的政策…...

    2024/5/8 6:01:22
  6. 【原油贵金属周评】原油多头拥挤,价格调整

    原标题:【原油贵金属周评】原油多头拥挤,价格调整本周国际劳动节,我们喜迎四天假期,但是整个金融市场确实流动性充沛,大事频发,各个商品波动剧烈。美国方面,在本周四凌晨公布5月份的利率决议和新闻发布会,维持联邦基金利率在2.25%-2.50%不变,符合市场预期。同时美联储…...

    2024/5/7 9:45:25
  7. 【外汇周评】靓丽非农不及疲软通胀影响

    原标题:【外汇周评】靓丽非农不及疲软通胀影响在刚结束的周五,美国方面公布了新一期的非农就业数据,大幅好于前值和预期,新增就业重新回到20万以上。具体数据: 美国4月非农就业人口变动 26.3万人,预期 19万人,前值 19.6万人。 美国4月失业率 3.6%,预期 3.8%,前值 3…...

    2024/5/4 23:54:56
  8. 【原油贵金属早评】库存继续增加,油价收跌

    原标题:【原油贵金属早评】库存继续增加,油价收跌周三清晨公布美国当周API原油库存数据,上周原油库存增加281万桶至4.692亿桶,增幅超过预期的74.4万桶。且有消息人士称,沙特阿美据悉将于6月向亚洲炼油厂额外出售更多原油,印度炼油商预计将每日获得至多20万桶的额外原油供…...

    2024/5/7 14:25:14
  9. 【外汇早评】日本央行会议纪要不改日元强势

    原标题:【外汇早评】日本央行会议纪要不改日元强势近两日日元大幅走强与近期市场风险情绪上升,避险资金回流日元有关,也与前一段时间的美日贸易谈判给日本缓冲期,日本方面对汇率问题也避免继续贬值有关。虽然今日早间日本央行公布的利率会议纪要仍然是支持宽松政策,但这符…...

    2024/5/4 23:54:56
  10. 【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响

    原标题:【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响近日伊朗局势升温,导致市场担忧影响原油供给,油价试图反弹。此时OPEC表态稳定市场。据消息人士透露,沙特6月石油出口料将低于700万桶/日,沙特已经收到石油消费国提出的6月份扩大出口的“适度要求”,沙特将满…...

    2024/5/4 23:55:05
  11. 【外汇早评】美欲与伊朗重谈协议

    原标题:【外汇早评】美欲与伊朗重谈协议美国对伊朗的制裁遭到伊朗的抗议,昨日伊朗方面提出将部分退出伊核协议。而此行为又遭到欧洲方面对伊朗的谴责和警告,伊朗外长昨日回应称,欧洲国家履行它们的义务,伊核协议就能保证存续。据传闻伊朗的导弹已经对准了以色列和美国的航…...

    2024/5/4 23:54:56
  12. 【原油贵金属早评】波动率飙升,市场情绪动荡

    原标题:【原油贵金属早评】波动率飙升,市场情绪动荡因中美贸易谈判不安情绪影响,金融市场各资产品种出现明显的波动。随着美国与中方开启第十一轮谈判之际,美国按照既定计划向中国2000亿商品征收25%的关税,市场情绪有所平复,已经开始接受这一事实。虽然波动率-恐慌指数VI…...

    2024/5/7 11:36:39
  13. 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试

    原标题:【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试美国和伊朗的局势继续升温,市场风险情绪上升,避险黄金有向上突破阻力的迹象。原油方面稍显平稳,近期美国和OPEC加大供给及市场需求回落的影响,伊朗局势并未推升油价走强。近期中美贸易谈判摩擦再度升级,美国对中…...

    2024/5/4 23:54:56
  14. 【原油贵金属早评】市场情绪继续恶化,黄金上破

    原标题:【原油贵金属早评】市场情绪继续恶化,黄金上破周初中国针对于美国加征关税的进行的反制措施引发市场情绪的大幅波动,人民币汇率出现大幅的贬值动能,金融市场受到非常明显的冲击。尤其是波动率起来之后,对于股市的表现尤其不安。隔夜美国股市出现明显的下行走势,这…...

    2024/5/6 1:40:42
  15. 【外汇早评】美伊僵持,风险情绪继续升温

    原标题:【外汇早评】美伊僵持,风险情绪继续升温昨日沙特两艘油轮再次发生爆炸事件,导致波斯湾局势进一步恶化,市场担忧美伊可能会出现摩擦生火,避险品种获得支撑,黄金和日元大幅走强。美指受中美贸易问题影响而在低位震荡。继5月12日,四艘商船在阿联酋领海附近的阿曼湾、…...

    2024/5/4 23:54:56
  16. 【原油贵金属早评】贸易冲突导致需求低迷,油价弱势

    原标题:【原油贵金属早评】贸易冲突导致需求低迷,油价弱势近日虽然伊朗局势升温,中东地区几起油船被袭击事件影响,但油价并未走高,而是出于调整结构中。由于市场预期局势失控的可能性较低,而中美贸易问题导致的全球经济衰退风险更大,需求会持续低迷,因此油价调整压力较…...

    2024/5/4 23:55:17
  17. 氧生福地 玩美北湖(上)——为时光守候两千年

    原标题:氧生福地 玩美北湖(上)——为时光守候两千年一次说走就走的旅行,只有一张高铁票的距离~ 所以,湖南郴州,我来了~ 从广州南站出发,一个半小时就到达郴州西站了。在动车上,同时改票的南风兄和我居然被分到了一个车厢,所以一路非常愉快地聊了过来。 挺好,最起…...

    2024/5/7 9:26:26
  18. 氧生福地 玩美北湖(中)——永春梯田里的美与鲜

    原标题:氧生福地 玩美北湖(中)——永春梯田里的美与鲜一觉醒来,因为大家太爱“美”照,在柳毅山庄去寻找龙女而错过了早餐时间。近十点,向导坏坏还是带着饥肠辘辘的我们去吃郴州最富有盛名的“鱼头粉”。说这是“十二分推荐”,到郴州必吃的美食之一。 哇塞!那个味美香甜…...

    2024/5/4 23:54:56
  19. 氧生福地 玩美北湖(下)——奔跑吧骚年!

    原标题:氧生福地 玩美北湖(下)——奔跑吧骚年!让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 啊……啊……啊 两…...

    2024/5/4 23:55:06
  20. 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!

    原标题:扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!扒开伪装医用面膜,翻六倍价格宰客!当行业里的某一品项火爆了,就会有很多商家蹭热度,装逼忽悠,最近火爆朋友圈的医用面膜,被沾上了污点,到底怎么回事呢? “比普通面膜安全、效果好!痘痘、痘印、敏感肌都能用…...

    2024/5/5 8:13:33
  21. 「发现」铁皮石斛仙草之神奇功效用于医用面膜

    原标题:「发现」铁皮石斛仙草之神奇功效用于医用面膜丽彦妆铁皮石斛医用面膜|石斛多糖无菌修护补水贴19大优势: 1、铁皮石斛:自唐宋以来,一直被列为皇室贡品,铁皮石斛生于海拔1600米的悬崖峭壁之上,繁殖力差,产量极低,所以古代仅供皇室、贵族享用 2、铁皮石斛自古民间…...

    2024/5/4 23:55:16
  22. 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者

    原标题:丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者【公司简介】 广州华彬企业隶属香港华彬集团有限公司,专注美业21年,其旗下品牌: 「圣茵美」私密荷尔蒙抗衰,产后修复 「圣仪轩」私密荷尔蒙抗衰,产后修复 「花茵莳」私密荷尔蒙抗衰,产后修复 「丽彦妆」专注医学护…...

    2024/5/4 23:54:58
  23. 广州械字号面膜生产厂家OEM/ODM4项须知!

    原标题:广州械字号面膜生产厂家OEM/ODM4项须知!广州械字号面膜生产厂家OEM/ODM流程及注意事项解读: 械字号医用面膜,其实在我国并没有严格的定义,通常我们说的医美面膜指的应该是一种「医用敷料」,也就是说,医用面膜其实算作「医疗器械」的一种,又称「医用冷敷贴」。 …...

    2024/5/6 21:42:42
  24. 械字号医用眼膜缓解用眼过度到底有无作用?

    原标题:械字号医用眼膜缓解用眼过度到底有无作用?医用眼膜/械字号眼膜/医用冷敷眼贴 凝胶层为亲水高分子材料,含70%以上的水分。体表皮肤温度传导到本产品的凝胶层,热量被凝胶内水分子吸收,通过水分的蒸发带走大量的热量,可迅速地降低体表皮肤局部温度,减轻局部皮肤的灼…...

    2024/5/4 23:54:56
  25. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

    解析如下&#xff1a;1、长按电脑电源键直至关机&#xff0c;然后再按一次电源健重启电脑&#xff0c;按F8健进入安全模式2、安全模式下进入Windows系统桌面后&#xff0c;按住“winR”打开运行窗口&#xff0c;输入“services.msc”打开服务设置3、在服务界面&#xff0c;选中…...

    2022/11/19 21:17:18
  26. 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。

    %读入6幅图像&#xff08;每一幅图像的大小是564*564&#xff09; f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...

    2022/11/19 21:17:16
  27. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

    win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面&#xff0c;在等待界面中我们需要等待操作结束才能关机&#xff0c;虽然这比较麻烦&#xff0c;但是对系统进行配置和升级…...

    2022/11/19 21:17:15
  28. 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...

    有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows&#xff0c;请勿关闭计算机”的提示&#xff0c;要过很久才能进入系统&#xff0c;有的用户甚至几个小时也无法进入&#xff0c;下面就教大家这个问题的解决方法。第一种方法&#xff1a;我们首先在左下角的“开始…...

    2022/11/19 21:17:14
  29. win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...

    置信有很多用户都跟小编一样遇到过这样的问题&#xff0c;电脑时发现开机屏幕显现“正在配置Windows Update&#xff0c;请勿关机”(如下图所示)&#xff0c;而且还需求等大约5分钟才干进入系统。这是怎样回事呢&#xff1f;一切都是正常操作的&#xff0c;为什么开时机呈现“正…...

    2022/11/19 21:17:13
  30. 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...

    Win7系统开机启动时总是出现“配置Windows请勿关机”的提示&#xff0c;没过几秒后电脑自动重启&#xff0c;每次开机都这样无法进入系统&#xff0c;此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一&#xff1a;开机按下F8&#xff0c;在出现的Windows高级启动选…...

    2022/11/19 21:17:12
  31. 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...

    有不少windows10系统用户反映说碰到这样一个情况&#xff0c;就是电脑提示正在准备windows请勿关闭计算机&#xff0c;碰到这样的问题该怎么解决呢&#xff0c;现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法&#xff1a;1、2、依次…...

    2022/11/19 21:17:11
  32. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...

    今天和大家分享一下win7系统重装了Win7旗舰版系统后&#xff0c;每次关机的时候桌面上都会显示一个“配置Windows Update的界面&#xff0c;提示请勿关闭计算机”&#xff0c;每次停留好几分钟才能正常关机&#xff0c;导致什么情况引起的呢&#xff1f;出现配置Windows Update…...

    2022/11/19 21:17:10
  33. 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...

    只能是等着&#xff0c;别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚&#xff0c;只能是考虑备份数据后重装系统了。解决来方案一&#xff1a;管理员运行cmd&#xff1a;net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...

    2022/11/19 21:17:09
  34. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

    原标题&#xff1a;电脑提示“配置Windows Update请勿关闭计算机”怎么办&#xff1f;win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢&#xff1f;一般的方…...

    2022/11/19 21:17:08
  35. 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...

    关机提示 windows7 正在配置windows 请勿关闭计算机 &#xff0c;然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;关机提示 windows7 正在配…...

    2022/11/19 21:17:05
  36. 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...

    钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...

    2022/11/19 21:17:05
  37. 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...

    前几天班里有位学生电脑(windows 7系统)出问题了&#xff0c;具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面&#xff0c;长时间没反应&#xff0c;无法进入系统。这个问题原来帮其他同学也解决过&#xff0c;网上搜了不少资料&#x…...

    2022/11/19 21:17:04
  38. 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...

    本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法&#xff0c;并在最后教给你1种保护系统安全的好方法&#xff0c;一起来看看&#xff01;电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中&#xff0c;添加了1个新功能在“磁…...

    2022/11/19 21:17:03
  39. 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...

    许多用户在长期不使用电脑的时候&#xff0c;开启电脑发现电脑显示&#xff1a;配置windows更新失败&#xff0c;正在还原更改&#xff0c;请勿关闭计算机。。.这要怎么办呢&#xff1f;下面小编就带着大家一起看看吧&#xff01;如果能够正常进入系统&#xff0c;建议您暂时移…...

    2022/11/19 21:17:02
  40. 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...

    配置windows update失败 还原更改 请勿关闭计算机&#xff0c;电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;配置windows update失败 还原更改 请勿关闭计算机&#x…...

    2022/11/19 21:17:01
  41. 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...

    不知道大家有没有遇到过这样的一个问题&#xff0c;就是我们的win7系统在关机的时候&#xff0c;总是喜欢显示“准备配置windows&#xff0c;请勿关机”这样的一个页面&#xff0c;没有什么大碍&#xff0c;但是如果一直等着的话就要两个小时甚至更久都关不了机&#xff0c;非常…...

    2022/11/19 21:17:00
  42. 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...

    当电脑出现正在准备配置windows请勿关闭计算机时&#xff0c;一般是您正对windows进行升级&#xff0c;但是这个要是长时间没有反应&#xff0c;我们不能再傻等下去了。可能是电脑出了别的问题了&#xff0c;来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...

    2022/11/19 21:16:59
  43. 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...

    我们使用电脑的过程中有时会遇到这种情况&#xff0c;当我们打开电脑之后&#xff0c;发现一直停留在一个界面&#xff1a;“配置Windows Update失败&#xff0c;还原更改请勿关闭计算机”&#xff0c;等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢&#xff0…...

    2022/11/19 21:16:58
  44. 如何在iPhone上关闭“请勿打扰”

    Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...

    2022/11/19 21:16:57