-
Notifications
You must be signed in to change notification settings - Fork 25k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Make it possible to use Stack logging in Docker #65778
Changes from 2 commits
f0b1243
a978be7
74ab274
580bc0b
288ac14
044929f
2520719
9f31d88
e2e9b47
ab73850
96536fd
d1bb242
6cff1aa
bfc4748
b9c420a
199a550
4d120f3
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -30,6 +30,24 @@ dependencies { | |
ossDockerSource project(path: ":distribution:archives:oss-linux-tar", configuration:"default") | ||
} | ||
|
||
/** | ||
* Used in the Dockerfile template to wrap commands in a retry loop. It can't be | ||
* a closure because Gradle can't effectively cache those. | ||
*/ | ||
class Retry { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. In general I'm in favour to have class definitions living in buildSrc somewhere no matter how small they are. To keep our build scripts a bit cleaner and smaller. Also these classes should change less often than the script itself. |
||
static String loop(name, command, indentSize = 4, exitKeyword = 'exit') { | ||
String indent = ' ' * indentSize | ||
String commandWithRetry = """for iter in {1..10}; do | ||
${indent} ${command} && | ||
${indent} exit_code=0 && break || | ||
${indent} exit_code=\$? && echo "${name} error: retry \$iter in 10s" && sleep 10; | ||
${indent}done; | ||
${indent}${exitKeyword} \$exit_code""" | ||
|
||
return commandWithRetry.replaceAll(" *\n", " \\\\\n") | ||
} | ||
} | ||
|
||
ext.expansions = { Architecture architecture, boolean oss, DockerBase base, boolean local -> | ||
String classifier | ||
if (local) { | ||
|
@@ -75,18 +93,6 @@ RUN curl --retry 8 -S -L \\ | |
|
||
def (major,minor) = VersionProperties.elasticsearch.split("\\.") | ||
|
||
def retry_loop = { name, command, indentSize = 4, exitKeyword = 'exit' -> | ||
String indent = ' ' * indentSize | ||
String commandWithRetry = """for iter in {1..10}; do | ||
${indent} ${command} && | ||
${indent} exit_code=0 && break || | ||
${indent} exit_code=\$? && echo "${name} error: retry \$iter in 10s" && sleep 10; | ||
${indent}done; | ||
${indent}${exitKeyword} \$exit_code""" | ||
|
||
return commandWithRetry.replaceAll(" *\n", " \\\\\n") | ||
} | ||
|
||
return [ | ||
'base_image' : base.getImage(), | ||
'bin_dir' : base == DockerBase.IRON_BANK ? 'scripts' : 'bin', | ||
|
@@ -100,7 +106,7 @@ ${indent}${exitKeyword} \$exit_code""" | |
'docker_base' : base.name().toLowerCase(), | ||
'version' : VersionProperties.elasticsearch, | ||
'major_minor_version' : "${major}.${minor}", | ||
'retry_loop' : retry_loop | ||
'retry' : Retry, | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I think the , is too much here |
||
] | ||
} | ||
|
||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can you elaborate what can't be cached here?