use of com.vip.saturn.job.console.domain.JobConfig in project Saturn by vipshop.
the class ShardingIT method test_A_JAVA.
@Test
public void test_A_JAVA() throws Exception {
int shardCount = 3;
final String jobName = "test_A_JAVA";
for (int i = 0; i < shardCount; i++) {
String key = jobName + "_" + i;
SimpleJavaJob.statusMap.put(key, 0);
}
JobConfig jobConfig = new JobConfig();
jobConfig.setJobName(jobName);
jobConfig.setCron("9 9 9 9 9 ? 2099");
jobConfig.setJobType(JobType.JAVA_JOB.toString());
jobConfig.setJobClass(SimpleJavaJob.class.getCanonicalName());
jobConfig.setShardingTotalCount(shardCount);
jobConfig.setShardingItemParameters("0=0,1=1,2=2");
addJob(jobConfig);
Thread.sleep(1000);
enableJob(jobName);
Thread.sleep(1000);
// 启动第1台executor
Main executor1 = startOneNewExecutorList();
runAtOnce(jobName);
Thread.sleep(1000);
assertThat(regCenter.getDirectly(SaturnExecutorsNode.SHARDING_COUNT_PATH)).isEqualTo("4");
waitForFinish(new FinishCheck() {
@Override
public boolean isOk() {
if (isNeedSharding(jobName)) {
return false;
}
return true;
}
}, 10);
List<Integer> items = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(jobName, ShardingNode.getShardingNode(executor1.getExecutorName()))));
assertThat(items).contains(0, 1, 2);
// 启动第2台executor
Main executor2 = startOneNewExecutorList();
Thread.sleep(1000);
runAtOnce(jobName);
Thread.sleep(1000);
waitForFinish(new FinishCheck() {
@Override
public boolean isOk() {
if (isNeedSharding(jobName)) {
return false;
}
return true;
}
}, 10);
items = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(jobName, ShardingNode.getShardingNode(executor1.getExecutorName()))));
assertThat(items).isNotEmpty();
System.out.println(items);
items = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(jobName, ShardingNode.getShardingNode(executor2.getExecutorName()))));
System.out.println(items);
assertThat(items).isNotEmpty();
// 启动第3台executor
Main executor3 = startOneNewExecutorList();
Thread.sleep(1000);
runAtOnce(jobName);
Thread.sleep(1000);
items = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(jobName, ShardingNode.getShardingNode(executor3.getExecutorName()))));
System.out.println(items);
assertThat(items).hasSize(1);
// 停第1个executor
stopExecutorGracefully(0);
Thread.sleep(1000);
assertThat(regCenter.getDirectly(SaturnExecutorsNode.SHARDING_COUNT_PATH)).isEqualTo("10");
Thread.sleep(1000);
runAtOnce(jobName);
Thread.sleep(1000);
waitForFinish(new FinishCheck() {
@Override
public boolean isOk() {
if (isNeedSharding(jobName)) {
return false;
}
return true;
}
}, 10);
items = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(jobName, ShardingNode.getShardingNode(executor1.getExecutorName()))));
System.out.println(items);
assertThat(items).isEmpty();
// 停第2个executor
stopExecutorGracefully(1);
Thread.sleep(1000);
runAtOnce(jobName);
Thread.sleep(1000);
waitForFinish(new FinishCheck() {
@Override
public boolean isOk() {
if (isNeedSharding(jobName)) {
return false;
}
return true;
}
}, 10);
items = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(jobName, ShardingNode.getShardingNode(executor2.getExecutorName()))));
System.out.println(items);
assertThat(items).isEmpty();
// 分片全部落到第3个executor
items = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(jobName, ShardingNode.getShardingNode(executor3.getExecutorName()))));
assertThat(items).contains(0, 1, 2);
disableJob(jobName);
Thread.sleep(1000);
removeJob(jobName);
stopExecutorListGracefully();
}
use of com.vip.saturn.job.console.domain.JobConfig in project Saturn by vipshop.
the class ShardingWithLoadIT method multiJobSharding.
public void multiJobSharding(String preferListJob3) throws Exception {
// 作业1,负荷为1,分片数为2
final String jobName1 = "JOB_LOAD1_SHARDING2";
final JobConfig jobConfig1 = new JobConfig();
jobConfig1.setJobName(jobName1);
jobConfig1.setCron("9 9 9 9 9 ? 2099");
jobConfig1.setJobType(JobType.JAVA_JOB.toString());
jobConfig1.setJobClass(SimpleJavaJob.class.getCanonicalName());
jobConfig1.setLoadLevel(1);
jobConfig1.setShardingItemParameters("0=0,1=1,2=2");
addSimpleJavaJob(jobName1, 2, jobConfig1);
// 作业2,负荷为2,分片数为2
final String jobName2 = "JOB_LOAD2_SHARDING2";
final JobConfig jobConfig2 = new JobConfig();
jobConfig2.setJobName(jobName2);
jobConfig2.setCron("9 9 9 9 9 ? 2099");
jobConfig2.setJobType(JobType.JAVA_JOB.toString());
jobConfig2.setJobClass(SimpleJavaJob.class.getCanonicalName());
jobConfig2.setLoadLevel(2);
jobConfig2.setShardingItemParameters("0=0,1=1");
addSimpleJavaJob(jobName2, 2, jobConfig2);
// 作业3,负荷为1,分片数为3
final String jobName3 = "JOB_LOAD1_SHARDING3";
final JobConfig jobConfig3 = new JobConfig();
jobConfig3.setJobName(jobName3);
jobConfig3.setCron("9 9 9 9 9 ? 2099");
jobConfig3.setJobType(JobType.JAVA_JOB.toString());
jobConfig3.setJobClass(SimpleJavaJob.class.getCanonicalName());
jobConfig3.setLoadLevel(1);
jobConfig3.setShardingItemParameters("0=0,1=1,2=2");
// 没有preferlist or 设置preferlist1,2
if (null != preferListJob3) {
jobConfig3.setPreferList(preferListJob3);
}
addSimpleJavaJob(jobName3, 3, jobConfig3);
Thread.sleep(1000);
// 启用作业1,2,3
enableJob(jobName1);
enableJob(jobName2);
enableJob(jobName3);
Thread.sleep(1000);
// 启动第1台executor
Main executor1 = startOneNewExecutorList();
Thread.sleep(1000);
runAtOnce(jobName1);
runAtOnce(jobName2);
runAtOnce(jobName3);
Thread.sleep(1000);
waitForFinish(new FinishCheck() {
@Override
public boolean isOk() {
if (isNeedSharding(jobName1) || isNeedSharding(jobName2) || isNeedSharding(jobName3)) {
return false;
}
return true;
}
}, 30);
List<Integer> itemsJob1Exe1 = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(jobName1, ShardingNode.getShardingNode(executor1.getExecutorName()))));
assertThat(itemsJob1Exe1).contains(0, 1);
List<Integer> itemsJob2Exe1 = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(jobName2, ShardingNode.getShardingNode(executor1.getExecutorName()))));
assertThat(itemsJob2Exe1).contains(0, 1);
List<Integer> itemsJob3Exe1 = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(jobName3, ShardingNode.getShardingNode(executor1.getExecutorName()))));
assertThat(itemsJob3Exe1).contains(0, 1, 2);
// 启动第2台executor
Main executor2 = startOneNewExecutorList();
Thread.sleep(1000);
runAtOnce(jobName1);
runAtOnce(jobName2);
runAtOnce(jobName3);
Thread.sleep(1000);
waitForFinish(new FinishCheck() {
@Override
public boolean isOk() {
if (isNeedSharding(jobName1) || isNeedSharding(jobName2) || isNeedSharding(jobName3)) {
return false;
}
return true;
}
}, 60);
// 大负荷作业Job2分片都到节点2
List<Integer> itemsJob2Exe2 = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(jobName2, ShardingNode.getShardingNode(executor2.getExecutorName()))));
System.out.println("job2 at exe2 :" + itemsJob2Exe2);
List<Integer> itemsJob1Exe2 = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(jobName1, ShardingNode.getShardingNode(executor2.getExecutorName()))));
System.out.println("job1 at exe2:" + itemsJob1Exe2);
List<Integer> itemsJob3Exe2 = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(jobName3, ShardingNode.getShardingNode(executor2.getExecutorName()))));
System.out.println("job3 at exe2:" + itemsJob3Exe2);
int totalLoadOfExe2 = itemsJob2Exe2.size() * 2 + itemsJob1Exe2.size() + itemsJob3Exe2.size();
assertEquals("total load of exe2 not equal", 4, totalLoadOfExe2);
// 启动第3台executor
Main executor3 = startOneNewExecutorList();
Thread.sleep(1000);
runAtOnce(jobName1);
runAtOnce(jobName2);
runAtOnce(jobName3);
Thread.sleep(1000);
List<Integer> itemsJob1Exe3 = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(jobName1, ShardingNode.getShardingNode(executor3.getExecutorName()))));
List<Integer> itemsJob2Exe3 = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(jobName2, ShardingNode.getShardingNode(executor3.getExecutorName()))));
List<Integer> itemsJob3Exe3 = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(jobName3, ShardingNode.getShardingNode(executor3.getExecutorName()))));
System.out.println("itemsJob1Exe3 : " + itemsJob1Exe3);
System.out.println("itemsJob2Exe3 : " + itemsJob2Exe3);
System.out.println("itemsJob3Exe3 : " + itemsJob3Exe3);
// 节点3应该有分片
Assert.assertFalse("The exe3 has no sharding. ", itemsJob1Exe3.isEmpty() && itemsJob2Exe3.isEmpty() && itemsJob3Exe3.isEmpty());
// 当job3设置优先节点的情况下
if (null != preferListJob3) {
// 节点3不应该有job3的分片
Assert.assertTrue("The exe3 should have no sharding of job3. ", itemsJob3Exe3.isEmpty());
}
// 停节点1前先获取节点1上所有作业分片
itemsJob1Exe1 = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(jobName1, ShardingNode.getShardingNode(executor1.getExecutorName()))));
itemsJob2Exe1 = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(jobName2, ShardingNode.getShardingNode(executor1.getExecutorName()))));
itemsJob3Exe1 = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(jobName3, ShardingNode.getShardingNode(executor1.getExecutorName()))));
// 停第1个executor
stopExecutorGracefully(0);
Thread.sleep(1000);
runAtOnce(jobName1);
runAtOnce(jobName2);
runAtOnce(jobName3);
Thread.sleep(1000);
waitForFinish(new FinishCheck() {
@Override
public boolean isOk() {
if (isNeedSharding(jobName1) || isNeedSharding(jobName2) || isNeedSharding(jobName3)) {
return false;
}
return true;
}
}, 10);
if (!itemsJob1Exe1.isEmpty()) {
itemsJob1Exe2 = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(jobName1, ShardingNode.getShardingNode(executor2.getExecutorName()))));
itemsJob1Exe3 = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(jobName1, ShardingNode.getShardingNode(executor3.getExecutorName()))));
for (Integer i : itemsJob1Exe1) {
Assert.assertTrue("the sharding of exe1 should be shift to exe2 or exe3", itemsJob1Exe2.contains(i) || itemsJob1Exe3.contains(i));
}
}
if (!itemsJob2Exe1.isEmpty()) {
itemsJob2Exe2 = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(jobName2, ShardingNode.getShardingNode(executor2.getExecutorName()))));
itemsJob2Exe3 = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(jobName2, ShardingNode.getShardingNode(executor3.getExecutorName()))));
for (Integer i : itemsJob2Exe1) {
Assert.assertTrue("the sharding of exe1 should be shift to exe2 or exe3", itemsJob2Exe2.contains(i) || itemsJob2Exe3.contains(i));
}
}
if (!itemsJob3Exe1.isEmpty()) {
itemsJob3Exe2 = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(jobName3, ShardingNode.getShardingNode(executor2.getExecutorName()))));
itemsJob3Exe3 = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(jobName3, ShardingNode.getShardingNode(executor3.getExecutorName()))));
for (Integer i : itemsJob3Exe1) {
Assert.assertTrue("the sharding of exe1 should be shift to exe2 or exe3", itemsJob3Exe2.contains(i) || itemsJob3Exe3.contains(i));
}
}
disableJob(jobName1);
disableJob(jobName2);
disableJob(jobName3);
Thread.sleep(1000);
removeJob(jobName1);
removeJob(jobName2);
removeJob(jobName3);
Thread.sleep(1000);
stopExecutorListGracefully();
}
use of com.vip.saturn.job.console.domain.JobConfig in project Saturn by vipshop.
the class ShardingWithLoadIT method C_jobAverage.
@Test
public void C_jobAverage() throws Exception {
if (!AbstractAsyncShardingTask.ENABLE_JOB_BASED_SHARDING) {
return;
}
// 启动第2台executor
Main executor1 = startOneNewExecutorList();
Main executor2 = startOneNewExecutorList();
// 添加第1个作业,负荷设置2,设置优先节点是executor1
final String job1 = "test_B_JobAverage_job1";
{
final JobConfig jobConfig = new JobConfig();
jobConfig.setJobName(job1);
jobConfig.setCron("0/1 * * * * ?");
jobConfig.setJobType(JobType.JAVA_JOB.toString());
jobConfig.setJobClass(SimpleJavaJob.class.getCanonicalName());
jobConfig.setShardingTotalCount(1);
jobConfig.setShardingItemParameters("0=0");
jobConfig.setLoadLevel(2);
jobConfig.setPreferList(executor1.getExecutorName());
addJob(jobConfig);
Thread.sleep(1000);
}
// 添加第2个作业,负荷设置1,设置优先节点为executor2
final String job2 = "test_B_JobAverage_job2";
{
final JobConfig jobConfig = new JobConfig();
jobConfig.setJobName(job2);
jobConfig.setCron("0/1 * * * * ?");
jobConfig.setJobType(JobType.JAVA_JOB.toString());
jobConfig.setJobClass(SimpleJavaJob.class.getCanonicalName());
jobConfig.setShardingTotalCount(1);
jobConfig.setShardingItemParameters("0=0");
jobConfig.setPreferList(executor2.getExecutorName());
addJob(jobConfig);
Thread.sleep(1000);
}
// 启用job1、job2
enableJob(job1);
enableJob(job2);
Thread.sleep(2000);
// 校验
Map<String, List<Integer>> shardingItems = namespaceShardingContentService.getShardingItems(job1);
assertThat(shardingItems.get(executor1.getExecutorName())).hasSize(1).contains(0);
assertThat(shardingItems.get(executor2.getExecutorName())).isEmpty();
shardingItems = namespaceShardingContentService.getShardingItems(job2);
assertThat(shardingItems.get(executor1.getExecutorName())).isEmpty();
assertThat(shardingItems.get(executor2.getExecutorName())).hasSize(1).contains(0);
List<Integer> items = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(job1, ShardingNode.getShardingNode(executor1.getExecutorName()))));
assertThat(items).hasSize(1).contains(0);
items = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(job1, ShardingNode.getShardingNode(executor2.getExecutorName()))));
assertThat(items).isEmpty();
items = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(job2, ShardingNode.getShardingNode(executor1.getExecutorName()))));
assertThat(items).isEmpty();
items = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(job2, ShardingNode.getShardingNode(executor2.getExecutorName()))));
assertThat(items).hasSize(1).contains(0);
// 新增job3
final String job3 = "test_B_JobAverage_job3";
{
final JobConfig jobConfig = new JobConfig();
jobConfig.setJobName(job3);
jobConfig.setCron("0/1 * * * * ?");
jobConfig.setJobType(JobType.JAVA_JOB.toString());
jobConfig.setJobClass(SimpleJavaJob.class.getCanonicalName());
jobConfig.setShardingTotalCount(1);
jobConfig.setShardingItemParameters("0=0");
addJob(jobConfig);
Thread.sleep(1000);
}
// 启用job3
enableJob(job3);
Thread.sleep(2000);
// 校验,job1、job2保持不变,job3一定是被分配到executor2,因为executor2的总负荷小于executor1
shardingItems = namespaceShardingContentService.getShardingItems(job1);
assertThat(shardingItems.get(executor1.getExecutorName())).hasSize(1).contains(0);
assertThat(shardingItems.get(executor2.getExecutorName())).isEmpty();
shardingItems = namespaceShardingContentService.getShardingItems(job2);
assertThat(shardingItems.get(executor1.getExecutorName())).isEmpty();
assertThat(shardingItems.get(executor2.getExecutorName())).hasSize(1).contains(0);
shardingItems = namespaceShardingContentService.getShardingItems(job3);
assertThat(shardingItems.get(executor1.getExecutorName())).isEmpty();
assertThat(shardingItems.get(executor2.getExecutorName())).hasSize(1).contains(0);
items = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(job1, ShardingNode.getShardingNode(executor1.getExecutorName()))));
assertThat(items).hasSize(1).contains(0);
items = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(job1, ShardingNode.getShardingNode(executor2.getExecutorName()))));
assertThat(items).isEmpty();
items = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(job2, ShardingNode.getShardingNode(executor1.getExecutorName()))));
assertThat(items).isEmpty();
items = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(job2, ShardingNode.getShardingNode(executor2.getExecutorName()))));
assertThat(items).hasSize(1).contains(0);
items = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(job3, ShardingNode.getShardingNode(executor1.getExecutorName()))));
assertThat(items).isEmpty();
items = ItemUtils.toItemList(regCenter.getDirectly(JobNodePath.getNodeFullPath(job3, ShardingNode.getShardingNode(executor2.getExecutorName()))));
assertThat(items).hasSize(1).contains(0);
// 关闭
disableJob(job1);
disableJob(job2);
disableJob(job3);
Thread.sleep(1000);
removeJob(job1);
removeJob(job2);
removeJob(job3);
stopExecutorListGracefully();
}
use of com.vip.saturn.job.console.domain.JobConfig in project Saturn by vipshop.
the class UpdateConfigIT method updateCron.
@Test
public void updateCron() throws Exception {
int shardCount = 1;
String jobName = "updateCron";
for (int i = 0; i < shardCount; i++) {
String key = jobName + "_" + i;
SimpleJavaJob.statusMap.put(key, 0);
}
JobConfig jobConfig = new JobConfig();
jobConfig.setJobName(jobName);
jobConfig.setTimeZone(TimeZone.getDefault().getID());
jobConfig.setCron("*/2 * * * * ?");
jobConfig.setJobType(JobType.JAVA_JOB.toString());
jobConfig.setJobClass(SimpleJavaJob.class.getCanonicalName());
jobConfig.setShardingTotalCount(shardCount);
jobConfig.setShardingItemParameters("0=0");
addJob(jobConfig);
Thread.sleep(1000);
enableJob(jobName);
Thread.sleep(3 * 1000);
disableJob(jobName);
Thread.sleep(2 * 1000);
for (int i = 0; i < shardCount; i++) {
String key = jobName + "_" + i;
assertThat(SimpleJavaJob.statusMap.get(key)).isGreaterThanOrEqualTo(1);
}
zkUpdateJobNode(jobConfig.getJobName(), "config/cron", "0/1 * * * * ?");
Thread.sleep(1000);
enableJob(jobName);
Thread.sleep(2 * 1000);
for (int i = 0; i < shardCount; i++) {
String key = jobName + "_" + i;
assertThat(SimpleJavaJob.statusMap.get(key)).isGreaterThanOrEqualTo(2);
}
SimpleJavaJob.statusMap.clear();
disableJob(jobName);
Thread.sleep(1000);
removeJob(jobName);
Thread.sleep(2000);
}
use of com.vip.saturn.job.console.domain.JobConfig in project Saturn by vipshop.
the class UpdateConfigIT method updateShowNormalLog.
/**
* 作业配置正常显示日志时,zk的jobLog会有执行日志的IT
*/
@Test
public void updateShowNormalLog() throws Exception {
final int shardCount = 1;
final String jobName = "updateShowNormalLog";
JobConfig jobConfig = new JobConfig();
jobConfig.setJobName(jobName);
jobConfig.setTimeZone(TimeZone.getDefault().getID());
jobConfig.setCron("*/1 * * * * ?");
jobConfig.setJobType(JobType.JAVA_JOB.toString());
jobConfig.setJobClass(SimpleJavaJob.class.getCanonicalName());
jobConfig.setShardingTotalCount(shardCount);
jobConfig.setShardingItemParameters("0=0");
addJob(jobConfig);
Thread.sleep(1000);
enableJob(jobName);
Thread.sleep(2 * 1000);
for (int i = 0; i < shardCount; i++) {
String path = JobNodePath.getNodeFullPath(jobName, ExecutionNode.getJobLog(i));
assertThat(regCenter.isExisted(path)).isEqualTo(false);
}
disableJob(jobName);
Thread.sleep(2 * 1000);
zkUpdateJobNode(jobName, "config/showNormalLog", "true");
Thread.sleep(1 * 1000);
enableJob(jobName);
Thread.sleep(4000);
doReport(jobName);
try {
waitForFinish(new FinishCheck() {
@Override
public boolean isOk() {
for (int i = 0; i < shardCount; i++) {
String path = JobNodePath.getNodeFullPath(jobName, ExecutionNode.getJobLog(i));
if (regCenter.isExisted(path)) {
assertThat(regCenter.getDirectly(path)).isNotEmpty();
continue;
}
return false;
}
return true;
}
}, 10);
} catch (Exception e) {
e.printStackTrace();
fail(e.getMessage());
}
disableJob(jobName);
Thread.sleep(1000);
removeJob(jobName);
Thread.sleep(2000);
}
Aggregations