Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
LinuxSuRen
jenkins
提交
80b515e9
J
jenkins
项目概览
LinuxSuRen
/
jenkins
与 Fork 源项目一致
从无法访问的项目Fork
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
J
jenkins
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
未验证
提交
80b515e9
编写于
11月 27, 2017
作者:
O
Oleg Nenashev
提交者:
GitHub
11月 27, 2017
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #3157 from Jimilian/optimise_start_of_workflow_job
If task can be run only on master, use shortcut
上级
2e920c7d
00ccd23f
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
26 addition
and
8 deletion
+26
-8
core/src/main/java/hudson/model/Queue.java
core/src/main/java/hudson/model/Queue.java
+26
-8
未找到文件。
core/src/main/java/hudson/model/Queue.java
浏览文件 @
80b515e9
...
...
@@ -1691,6 +1691,17 @@ public class Queue extends ResourceController implements Saveable {
//we double check if this is a flyweight task
if
(
p
.
task
instanceof
FlyweightTask
)
{
Jenkins
h
=
Jenkins
.
getInstance
();
Label
lbl
=
p
.
getAssignedLabel
();
if
(
lbl
!=
null
&&
lbl
.
equals
(
h
.
getSelfLabel
()))
{
if
(
h
.
canTake
(
p
)
==
null
)
{
return
createFlyWeightTaskRunnable
(
p
,
h
.
toComputer
());
}
else
{
return
null
;
}
}
Map
<
Node
,
Integer
>
hashSource
=
new
HashMap
<
Node
,
Integer
>(
h
.
getNodes
().
size
());
// Even if master is configured with zero executors, we may need to run a flyweight task like MatrixProject on it.
...
...
@@ -1703,7 +1714,6 @@ public class Queue extends ResourceController implements Saveable {
ConsistentHash
<
Node
>
hash
=
new
ConsistentHash
<
Node
>(
NODE_HASH
);
hash
.
addAll
(
hashSource
);
Label
lbl
=
p
.
getAssignedLabel
();
String
fullDisplayName
=
p
.
task
.
getFullDisplayName
();
for
(
Node
n
:
hash
.
list
(
fullDisplayName
))
{
final
Computer
c
=
n
.
toComputer
();
...
...
@@ -1717,18 +1727,25 @@ public class Queue extends ResourceController implements Saveable {
continue
;
}
LOGGER
.
log
(
Level
.
FINEST
,
"Creating flyweight task {0} for computer {1}"
,
new
Object
[]{
fullDisplayName
,
c
.
getName
()});
return
new
Runnable
()
{
@Override
public
void
run
()
{
c
.
startFlyWeightTask
(
new
WorkUnitContext
(
p
).
createWorkUnit
(
p
.
task
));
makePending
(
p
);
}
};
return
createFlyWeightTaskRunnable
(
p
,
c
);
}
}
return
null
;
}
private
Runnable
createFlyWeightTaskRunnable
(
final
BuildableItem
p
,
final
Computer
c
)
{
if
(
LOGGER
.
isLoggable
(
Level
.
FINEST
))
{
LOGGER
.
log
(
Level
.
FINEST
,
"Creating flyweight task {0} for computer {1}"
,
new
Object
[]{
p
.
task
.
getFullDisplayName
(),
c
.
getName
()});
}
return
new
Runnable
()
{
@Override
public
void
run
()
{
c
.
startFlyWeightTask
(
new
WorkUnitContext
(
p
).
createWorkUnit
(
p
.
task
));
makePending
(
p
);
}
};
}
private
static
Hash
<
Node
>
NODE_HASH
=
new
Hash
<
Node
>()
{
public
String
hash
(
Node
node
)
{
return
node
.
getNodeName
();
...
...
@@ -2104,6 +2121,7 @@ public class Queue extends ResourceController implements Saveable {
* <p>
* This code takes {@link LabelAssignmentAction} into account, then fall back to {@link SubTask#getAssignedLabel()}
*/
@CheckForNull
public
Label
getAssignedLabel
()
{
for
(
LabelAssignmentAction
laa
:
getActions
(
LabelAssignmentAction
.
class
))
{
Label
l
=
laa
.
getAssignedLabel
(
task
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录