Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
iSulad
提交
967651c3
I
iSulad
项目概览
openeuler
/
iSulad
通知
15
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
I
iSulad
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
967651c3
编写于
5月 08, 2020
作者:
W
wujing
提交者:
lifeng68
7月 25, 2020
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Query image newly added return top field && Health check field adaptation
Signed-off-by:
N
wujing
<
wujing50@huawei.com
>
上级
aa494a55
变更
7
隐藏空白更改
内联
并排
Showing
7 changed file
with
60 addition
and
60 deletion
+60
-60
src/connect/client/pack_config.c
src/connect/client/pack_config.c
+4
-4
src/image/oci/oci_config_merge.c
src/image/oci/oci_config_merge.c
+15
-15
src/image/oci/storage/image_store/image_store.c
src/image/oci/storage/image_store/image_store.c
+11
-11
src/services/execution/execute/execution_information.c
src/services/execution/execute/execution_information.c
+12
-12
src/services/execution/manager/health_check.c
src/services/execution/manager/health_check.c
+12
-12
src/services/execution/spec/verify.c
src/services/execution/spec/verify.c
+5
-5
test/image/oci/storage/images/data/resources/ffc8ef7968a2acb7545006bed022001addaa262c0f760883146c4a4fae54e689/=c2hhMjU2OmZmYzhlZjc5NjhhMmFjYjc1NDUwMDZiZWQwMjIwMDFhZGRhYTI2MmMwZjc2MDg4MzE0NmM0YTRmYWU1NGU2ODk=
...iZWQwMjIwMDFhZGRhYTI2MmMwZjc2MDg4MzE0NmM0YTRmYWU1NGU2ODk=
+1
-1
未找到文件。
src/connect/client/pack_config.c
浏览文件 @
967651c3
...
...
@@ -2005,7 +2005,7 @@ static int pack_custom_no_health_check(container_config *container_spec, bool ha
goto
out
;
}
health_config
->
test
[
health_config
->
test_len
++
]
=
util_strdup_s
(
"NONE"
);
container_spec
->
health
_
check
=
health_config
;
container_spec
->
healthcheck
=
health_config
;
out:
return
ret
;
...
...
@@ -2035,10 +2035,10 @@ static int pack_custom_with_health_check(container_config *container_spec,
health_config
->
start_period
=
custom_conf
->
health_start_period
;
health_config
->
retries
=
custom_conf
->
health_retries
;
health_config
->
exit_on_unhealthy
=
custom_conf
->
exit_on_unhealthy
;
if
(
container_spec
->
health
_
check
!=
NULL
)
{
free_defs_health_check
(
container_spec
->
health
_
check
);
if
(
container_spec
->
healthcheck
!=
NULL
)
{
free_defs_health_check
(
container_spec
->
healthcheck
);
}
container_spec
->
health
_
check
=
health_config
;
container_spec
->
healthcheck
=
health_config
;
out:
return
ret
;
...
...
src/image/oci/oci_config_merge.c
浏览文件 @
967651c3
...
...
@@ -272,7 +272,7 @@ static int dup_health_check_from_image(const defs_health_check *image_health_che
health_check
->
retries
=
image_health_check
->
retries
;
health_check
->
exit_on_unhealthy
=
image_health_check
->
exit_on_unhealthy
;
container_spec
->
health
_
check
=
health_check
;
container_spec
->
healthcheck
=
health_check
;
health_check
=
NULL
;
...
...
@@ -283,34 +283,34 @@ out:
static
int
update_health_check_from_image
(
const
defs_health_check
*
image_health_check
,
container_config
*
container_spec
)
{
if
(
container_spec
->
health
_
check
->
test_len
==
0
)
{
if
(
container_spec
->
healthcheck
->
test_len
==
0
)
{
size_t
i
;
if
(
image_health_check
->
test_len
>
SIZE_MAX
/
sizeof
(
char
*
))
{
ERROR
(
"invalid health check commands!"
);
return
-
1
;
}
container_spec
->
health
_
check
->
test
=
util_common_calloc_s
(
sizeof
(
char
*
)
*
image_health_check
->
test_len
);
if
(
container_spec
->
health
_
check
->
test
==
NULL
)
{
container_spec
->
healthcheck
->
test
=
util_common_calloc_s
(
sizeof
(
char
*
)
*
image_health_check
->
test_len
);
if
(
container_spec
->
healthcheck
->
test
==
NULL
)
{
ERROR
(
"Out of memory"
);
return
-
1
;
}
for
(
i
=
0
;
i
<
image_health_check
->
test_len
;
i
++
)
{
container_spec
->
health
_
check
->
test
[
i
]
=
util_strdup_s
(
image_health_check
->
test
[
i
]);
container_spec
->
health
_
check
->
test_len
++
;
container_spec
->
healthcheck
->
test
[
i
]
=
util_strdup_s
(
image_health_check
->
test
[
i
]);
container_spec
->
healthcheck
->
test_len
++
;
}
}
if
(
container_spec
->
health
_
check
->
interval
==
0
)
{
container_spec
->
health
_
check
->
interval
=
image_health_check
->
interval
;
if
(
container_spec
->
healthcheck
->
interval
==
0
)
{
container_spec
->
healthcheck
->
interval
=
image_health_check
->
interval
;
}
if
(
container_spec
->
health
_
check
->
timeout
==
0
)
{
container_spec
->
health
_
check
->
timeout
=
image_health_check
->
timeout
;
if
(
container_spec
->
healthcheck
->
timeout
==
0
)
{
container_spec
->
healthcheck
->
timeout
=
image_health_check
->
timeout
;
}
if
(
container_spec
->
health
_
check
->
start_period
==
0
)
{
container_spec
->
health
_
check
->
start_period
=
image_health_check
->
start_period
;
if
(
container_spec
->
healthcheck
->
start_period
==
0
)
{
container_spec
->
healthcheck
->
start_period
=
image_health_check
->
start_period
;
}
if
(
container_spec
->
health
_
check
->
retries
==
0
)
{
container_spec
->
health
_
check
->
retries
=
image_health_check
->
retries
;
if
(
container_spec
->
healthcheck
->
retries
==
0
)
{
container_spec
->
healthcheck
->
retries
=
image_health_check
->
retries
;
}
return
0
;
...
...
@@ -324,7 +324,7 @@ static int oci_image_merge_health_check(const defs_health_check *image_health_ch
return
0
;
}
if
(
container_spec
->
health
_
check
==
NULL
)
{
if
(
container_spec
->
healthcheck
==
NULL
)
{
if
(
dup_health_check_from_image
(
image_health_check
,
container_spec
)
!=
0
)
{
ret
=
-
1
;
goto
out
;
...
...
src/image/oci/storage/image_store/image_store.c
浏览文件 @
967651c3
...
...
@@ -2432,7 +2432,7 @@ static int pack_health_check_from_image(const docker_image_config_v2 *config_v2,
size_t
i
;
defs_health_check
*
healthcheck
=
NULL
;
if
(
config_v2
->
config
->
health
_check
==
NULL
||
config_v2
->
config
->
health_
check
->
test_len
==
0
)
{
if
(
config_v2
->
config
->
health
check
==
NULL
||
config_v2
->
config
->
health
check
->
test_len
==
0
)
{
return
0
;
}
...
...
@@ -2443,21 +2443,21 @@ static int pack_health_check_from_image(const docker_image_config_v2 *config_v2,
goto
out
;
}
healthcheck
->
test
=
util_common_calloc_s
(
sizeof
(
char
*
)
*
config_v2
->
config
->
health
_
check
->
test_len
);
healthcheck
->
test
=
util_common_calloc_s
(
sizeof
(
char
*
)
*
config_v2
->
config
->
healthcheck
->
test_len
);
if
(
healthcheck
->
test
==
NULL
)
{
ERROR
(
"Out of memory"
);
ret
=
-
1
;
goto
out
;
}
for
(
i
=
0
;
i
<
config_v2
->
config
->
health
_
check
->
test_len
;
i
++
)
{
healthcheck
->
test
[
i
]
=
util_strdup_s
(
config_v2
->
config
->
health
_
check
->
test
[
i
]);
for
(
i
=
0
;
i
<
config_v2
->
config
->
healthcheck
->
test_len
;
i
++
)
{
healthcheck
->
test
[
i
]
=
util_strdup_s
(
config_v2
->
config
->
healthcheck
->
test
[
i
]);
}
healthcheck
->
test_len
=
config_v2
->
config
->
health
_
check
->
test_len
;
healthcheck
->
interval
=
config_v2
->
config
->
health
_
check
->
interval
;
healthcheck
->
retries
=
config_v2
->
config
->
health
_
check
->
retries
;
healthcheck
->
start_period
=
config_v2
->
config
->
health
_
check
->
start_period
;
healthcheck
->
timeout
=
config_v2
->
config
->
health
_
check
->
timeout
;
healthcheck
->
exit_on_unhealthy
=
config_v2
->
config
->
health
_
check
->
exit_on_unhealthy
;
healthcheck
->
test_len
=
config_v2
->
config
->
healthcheck
->
test_len
;
healthcheck
->
interval
=
config_v2
->
config
->
healthcheck
->
interval
;
healthcheck
->
retries
=
config_v2
->
config
->
healthcheck
->
retries
;
healthcheck
->
start_period
=
config_v2
->
config
->
healthcheck
->
start_period
;
healthcheck
->
timeout
=
config_v2
->
config
->
healthcheck
->
timeout
;
healthcheck
->
exit_on_unhealthy
=
config_v2
->
config
->
healthcheck
->
exit_on_unhealthy
;
info
->
healthcheck
=
healthcheck
;
healthcheck
=
NULL
;
...
...
@@ -2581,6 +2581,7 @@ static imagetool_image *get_image_info(image_t *img)
info
->
created
=
util_strdup_s
(
img
->
simage
->
created
);
info
->
loaded
=
util_strdup_s
(
img
->
simage
->
loaded
);
info
->
size
=
img
->
simage
->
size
;
info
->
top_layer
=
util_strdup_s
(
img
->
simage
->
layer
);
if
(
pack_image_tags_and_repo_digest
(
img
,
info
)
!=
0
)
{
ERROR
(
"Failed to pack image tags and repo digest"
);
...
...
@@ -2600,7 +2601,6 @@ out:
return
info
;
}
// TODO: add toplayer field to imagetool_image
imagetool_image
*
image_store_get_image
(
const
char
*
id
)
{
image_t
*
img
=
NULL
;
...
...
src/services/execution/execute/execution_information.c
浏览文件 @
967651c3
...
...
@@ -905,7 +905,7 @@ static int dup_health_check_config(const container_config *src, container_inspec
int
ret
=
0
;
size_t
i
=
0
;
if
(
src
==
NULL
||
src
->
health
_
check
==
NULL
||
dest
==
NULL
)
{
if
(
src
==
NULL
||
src
->
healthcheck
==
NULL
||
dest
==
NULL
)
{
return
0
;
}
dest
->
health_check
=
util_common_calloc_s
(
sizeof
(
defs_health_check
));
...
...
@@ -914,34 +914,34 @@ static int dup_health_check_config(const container_config *src, container_inspec
ret
=
-
1
;
goto
out
;
}
if
(
src
->
health
_check
->
test
!=
NULL
&&
src
->
health_
check
->
test_len
!=
0
)
{
if
(
src
->
health
_
check
->
test_len
>
SIZE_MAX
/
sizeof
(
char
*
))
{
if
(
src
->
health
check
->
test
!=
NULL
&&
src
->
health
check
->
test_len
!=
0
)
{
if
(
src
->
healthcheck
->
test_len
>
SIZE_MAX
/
sizeof
(
char
*
))
{
ERROR
(
"health check test is too much!"
);
ret
=
-
1
;
goto
out
;
}
dest
->
health_check
->
test
=
util_common_calloc_s
(
src
->
health
_
check
->
test_len
*
sizeof
(
char
*
));
dest
->
health_check
->
test
=
util_common_calloc_s
(
src
->
healthcheck
->
test_len
*
sizeof
(
char
*
));
if
(
dest
->
health_check
->
test
==
NULL
)
{
ERROR
(
"Out of memory"
);
ret
=
-
1
;
goto
out
;
}
for
(
i
=
0
;
i
<
src
->
health
_
check
->
test_len
;
i
++
)
{
if
(
src
->
health
_
check
->
test
[
i
]
==
NULL
)
{
for
(
i
=
0
;
i
<
src
->
healthcheck
->
test_len
;
i
++
)
{
if
(
src
->
healthcheck
->
test
[
i
]
==
NULL
)
{
ERROR
(
"Input value of src health check test is null"
);
ret
=
-
1
;
goto
out
;
}
dest
->
health_check
->
test
[
i
]
=
util_strdup_s
(
src
->
health
_
check
->
test
[
i
]);
dest
->
health_check
->
test
[
i
]
=
util_strdup_s
(
src
->
healthcheck
->
test
[
i
]);
dest
->
health_check
->
test_len
++
;
}
dest
->
health_check
->
interval
=
timeout_with_default
(
src
->
health
_
check
->
interval
,
DEFAULT_PROBE_INTERVAL
);
dest
->
health_check
->
start_period
=
timeout_with_default
(
src
->
health
_
check
->
start_period
,
DEFAULT_START_PERIOD
);
dest
->
health_check
->
timeout
=
timeout_with_default
(
src
->
health
_
check
->
timeout
,
DEFAULT_PROBE_TIMEOUT
);
dest
->
health_check
->
retries
=
src
->
health
_check
->
retries
!=
0
?
src
->
health_
check
->
retries
dest
->
health_check
->
interval
=
timeout_with_default
(
src
->
healthcheck
->
interval
,
DEFAULT_PROBE_INTERVAL
);
dest
->
health_check
->
start_period
=
timeout_with_default
(
src
->
healthcheck
->
start_period
,
DEFAULT_START_PERIOD
);
dest
->
health_check
->
timeout
=
timeout_with_default
(
src
->
healthcheck
->
timeout
,
DEFAULT_PROBE_TIMEOUT
);
dest
->
health_check
->
retries
=
src
->
health
check
->
retries
!=
0
?
src
->
health
check
->
retries
:
DEFAULT_PROBE_RETRIES
;
dest
->
health_check
->
exit_on_unhealthy
=
src
->
health
_
check
->
exit_on_unhealthy
;
dest
->
health_check
->
exit_on_unhealthy
=
src
->
healthcheck
->
exit_on_unhealthy
;
}
out:
return
ret
;
...
...
src/services/execution/manager/health_check.c
浏览文件 @
967651c3
...
...
@@ -243,11 +243,11 @@ static char **health_check_cmds(const container_config *config)
}
shell_len
=
util_array_len
((
const
char
**
)
shell
);
if
(
shell_len
>
(
SIZE_MAX
/
sizeof
(
char
*
))
-
config
->
health
_
check
->
test_len
)
{
if
(
shell_len
>
(
SIZE_MAX
/
sizeof
(
char
*
))
-
config
->
healthcheck
->
test_len
)
{
ERROR
(
"Invalid shell length"
);
goto
out
;
}
cmd_slice
=
util_common_calloc_s
((
shell_len
+
config
->
health
_
check
->
test_len
)
*
sizeof
(
char
*
));
cmd_slice
=
util_common_calloc_s
((
shell_len
+
config
->
healthcheck
->
test_len
)
*
sizeof
(
char
*
));
if
(
cmd_slice
==
NULL
)
{
ERROR
(
"out of memory"
);
goto
out
;
...
...
@@ -256,8 +256,8 @@ static char **health_check_cmds(const container_config *config)
cmd_slice
[
i
]
=
util_strdup_s
(
shell
[
i
]);
}
for
(
i
=
shell_len
;
i
<
(
shell_len
+
config
->
health
_
check
->
test_len
)
-
1
;
i
++
)
{
cmd_slice
[
i
]
=
util_strdup_s
(
config
->
health
_
check
->
test
[(
i
-
shell_len
)
+
1
]);
for
(
i
=
shell_len
;
i
<
(
shell_len
+
config
->
healthcheck
->
test_len
)
-
1
;
i
++
)
{
cmd_slice
[
i
]
=
util_strdup_s
(
config
->
healthcheck
->
test
[(
i
-
shell_len
)
+
1
]);
}
out:
...
...
@@ -338,7 +338,7 @@ static int handle_increment_streak(container_t *cont, int retries)
health
->
failing_streak
++
;
if
(
health
->
failing_streak
>=
retries
)
{
set_health_status
(
cont
->
state
,
UNHEALTHY
);
if
(
cont
->
common_config
->
config
->
health
_
check
->
exit_on_unhealthy
)
{
if
(
cont
->
common_config
->
config
->
healthcheck
->
exit_on_unhealthy
)
{
// kill container when exit on unhealthy flag is set
ret
=
stop_container
(
cont
,
3
,
true
,
false
);
if
(
ret
!=
0
)
{
...
...
@@ -362,7 +362,7 @@ static int handle_unhealthy_case(container_t *cont, const defs_health_log_elemen
health_status
=
get_health_status
(
cont
->
state
);
if
(
strcmp
(
health_status
,
HEALTH_STARTING
)
==
0
)
{
int64_t
start_period
=
timeout_with_default
(
cont
->
common_config
->
config
->
health
_
check
->
start_period
,
int64_t
start_period
=
timeout_with_default
(
cont
->
common_config
->
config
->
healthcheck
->
start_period
,
DEFAULT_START_PERIOD
);
int64_t
first
,
last
;
if
(
to_unix_nanos_from_str
(
cont
->
state
->
state
->
started_at
,
&
first
))
{
...
...
@@ -437,7 +437,7 @@ static int handle_probe_result(const char *container_id, const defs_health_log_e
if
(
get_health_check_monitor_state
(
cont
->
health_check
)
==
MONITOR_STOP
)
{
goto
out
;
}
retries
=
cont
->
common_config
->
config
->
health
_
check
->
retries
;
retries
=
cont
->
common_config
->
config
->
healthcheck
->
retries
;
if
(
retries
<=
0
)
{
retries
=
DEFAULT_PROBE_RETRIES
;
}
...
...
@@ -563,7 +563,7 @@ void *health_check_run(void *arg)
container_req
->
attach_stdin
=
false
;
container_req
->
attach_stdout
=
true
;
container_req
->
attach_stderr
=
true
;
container_req
->
timeout
=
timeout_with_default
(
config
->
health
_
check
->
timeout
,
DEFAULT_PROBE_TIMEOUT
)
/
Time_Second
;
container_req
->
timeout
=
timeout_with_default
(
config
->
healthcheck
->
timeout
,
DEFAULT_PROBE_TIMEOUT
)
/
Time_Second
;
container_req
->
container_id
=
util_strdup_s
(
cont
->
common_config
->
id
);
container_req
->
argv
=
cmd_slice
;
container_req
->
argv_len
=
util_array_len
((
const
char
**
)
cmd_slice
);
...
...
@@ -613,7 +613,7 @@ out:
// Nil will be returned if no healthcheck was configured or NONE was set.
static
health_probe_t
get_probe
(
const
container_t
*
cont
)
{
defs_health_check
*
config
=
cont
->
common_config
->
config
->
health
_
check
;
defs_health_check
*
config
=
cont
->
common_config
->
config
->
healthcheck
;
if
(
config
==
NULL
||
config
->
test_len
==
0
)
{
return
HEALTH_NONE
;
...
...
@@ -713,7 +713,7 @@ static void *health_check_monitor(void *arg)
ERROR
(
"Failed to monitor start time stamp"
);
goto
out
;
}
probe_interval
=
timeout_with_default
(
cont
->
common_config
->
config
->
health
_
check
->
interval
,
probe_interval
=
timeout_with_default
(
cont
->
common_config
->
config
->
healthcheck
->
interval
,
DEFAULT_PROBE_INTERVAL
);
set_monitor_idle_status
(
cont
->
health_check
);
while
(
true
)
{
...
...
@@ -804,8 +804,8 @@ void init_health_monitor(const char *id)
return
;
}
if
(
cont
->
common_config
->
config
->
health
_
check
==
NULL
||
cont
->
common_config
->
config
->
health
_
check
->
test
==
NULL
)
{
if
(
cont
->
common_config
->
config
->
healthcheck
==
NULL
||
cont
->
common_config
->
config
->
healthcheck
->
test
==
NULL
)
{
goto
out
;
}
...
...
src/services/execution/spec/verify.c
浏览文件 @
967651c3
...
...
@@ -2009,29 +2009,29 @@ int verify_health_check_parameter(const container_config *container_spec)
{
int
ret
=
0
;
if
(
container_spec
==
NULL
||
container_spec
->
health
_
check
==
NULL
)
{
if
(
container_spec
==
NULL
||
container_spec
->
healthcheck
==
NULL
)
{
return
ret
;
}
if
(
is_less_than_one_second
(
container_spec
->
health
_
check
->
interval
))
{
if
(
is_less_than_one_second
(
container_spec
->
healthcheck
->
interval
))
{
ERROR
(
"Interval in Healthcheck cannot be less than one second"
);
isulad_set_error_message
(
"Interval in Healthcheck cannot be less than one second"
);
ret
=
-
1
;
goto
out
;
}
if
(
is_less_than_one_second
(
container_spec
->
health
_
check
->
timeout
))
{
if
(
is_less_than_one_second
(
container_spec
->
healthcheck
->
timeout
))
{
ERROR
(
"Timeout in Healthcheck cannot be less than one second"
);
isulad_set_error_message
(
"Timeout in Healthcheck cannot be less than one second"
);
ret
=
-
1
;
goto
out
;
}
if
(
is_less_than_one_second
(
container_spec
->
health
_
check
->
start_period
))
{
if
(
is_less_than_one_second
(
container_spec
->
healthcheck
->
start_period
))
{
ERROR
(
"StartPeriod in Healthcheck cannot be less than one second"
);
isulad_set_error_message
(
"StartPeriod in Healthcheck cannot be less than one second"
);
ret
=
-
1
;
goto
out
;
}
if
(
container_spec
->
health
_
check
->
retries
<
0
)
{
if
(
container_spec
->
healthcheck
->
retries
<
0
)
{
ERROR
(
"--health-retries cannot be negative"
);
isulad_set_error_message
(
"--health-retries cannot be negative"
);
ret
=
-
1
;
...
...
test/image/oci/storage/images/data/resources/ffc8ef7968a2acb7545006bed022001addaa262c0f760883146c4a4fae54e689/=c2hhMjU2OmZmYzhlZjc5NjhhMmFjYjc1NDUwMDZiZWQwMjIwMDFhZGRhYTI2MmMwZjc2MDg4MzE0NmM0YTRmYWU1NGU2ODk=
浏览文件 @
967651c3
{"architecture":"amd64","config":{"Hostname":"","Domainname":"","User":"","AttachStdin":false,"AttachStdout":false,"AttachStderr":false,"Tty":false,"OpenStdin":false,"StdinOnce":false,"Env":["PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"],"Cmd":["sh"],"Health
Check":{"Test":["CMD-SHELL","date \u003e\u003e /tmp/health_check || exit 1"],"Interval":3000000000,"Timeout":3000000000,"StartPeriod":1000000000,"Retries":3,"ExitOnUnhealthy":true},"ArgsEscaped":true,"Image":"sha256:e4db68de4ff27c2adfea0c54bbb73a61a42f5b667c326de4d7d5b19ab71c6a3b","Volumes":null,"WorkingDir":"","Entrypoint":null,"OnBuild":null,"Labels":null,"Annotations":null},"container":"ed0b5c882c5b98b9f67a6dff3be078658d45d49540c8d8778b878d68a75bd8b7","container_config":{"Hostname":"ed0b5c882c5b","Domainname":"","User":"","AttachStdin":false,"AttachStdout":false,"AttachStderr":false,"Tty":false,"OpenStdin":false,"StdinOnce":false,"Env":["PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"],"Cmd":["/bin/sh","-c","#(nop) ","HEALTHCHECK \u0026{[\"CMD-SHELL\" \"date \u003e\u003e /tmp/health_check || exit 1\"] \"3s\" \"3s\" \"1s\" '\\x03' %!q(bool=true)}"],"HealthC
heck":{"Test":["CMD-SHELL","date \u003e\u003e /tmp/health_check || exit 1"],"Interval":3000000000,"Timeout":3000000000,"StartPeriod":1000000000,"Retries":3,"ExitOnUnhealthy":true},"ArgsEscaped":true,"Image":"sha256:e4db68de4ff27c2adfea0c54bbb73a61a42f5b667c326de4d7d5b19ab71c6a3b","Volumes":null,"WorkingDir":"","Entrypoint":null,"OnBuild":null,"Labels":{},"Annotations":{"native.umask":"secure"}},"created":"2020-03-30T08:02:50.586247435Z","docker_version":"dev","history":[{"created":"2019-06-15T00:19:54.271494486Z","created_by":"/bin/sh -c #(nop) ADD file:b265aa0ea2ef7ff1f4a3e087217e75aca2c90f5c345406299664cc7969b2b28e in / "},{"created":"2019-06-15T00:19:54.402459069Z","created_by":"/bin/sh -c #(nop) CMD [\"sh\"]","empty_layer":true},{"created":"2020-03-30T08:02:50.586247435Z","created_by":"/bin/sh -c #(nop) HEALTHCHECK \u0026{[\"CMD-SHELL\" \"date \u003e\u003e /tmp/health_check || exit 1\"] \"3s\" \"3s\" \"1s\" '\\x03' %!q(bool=true)}","empty_layer":true}],"os":"linux","rootfs":{"type":"layers","diff_ids":["sha256:6194458b07fcf01f1483d96cd6c34302ffff7f382bb151a6d023c4e80ba3050a"]}}
{"architecture":"amd64","config":{"Hostname":"","Domainname":"","User":"","AttachStdin":false,"AttachStdout":false,"AttachStderr":false,"Tty":false,"OpenStdin":false,"StdinOnce":false,"Env":["PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"],"Cmd":["sh"],"Health
check":{"Test":["CMD-SHELL","date \u003e\u003e /tmp/health_check || exit 1"],"Interval":3000000000,"Timeout":3000000000,"StartPeriod":1000000000,"Retries":3,"ExitOnUnhealthy":true},"ArgsEscaped":true,"Image":"sha256:e4db68de4ff27c2adfea0c54bbb73a61a42f5b667c326de4d7d5b19ab71c6a3b","Volumes":null,"WorkingDir":"","Entrypoint":null,"OnBuild":null,"Labels":null,"Annotations":null},"container":"ed0b5c882c5b98b9f67a6dff3be078658d45d49540c8d8778b878d68a75bd8b7","container_config":{"Hostname":"ed0b5c882c5b","Domainname":"","User":"","AttachStdin":false,"AttachStdout":false,"AttachStderr":false,"Tty":false,"OpenStdin":false,"StdinOnce":false,"Env":["PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"],"Cmd":["/bin/sh","-c","#(nop) ","HEALTHCHECK \u0026{[\"CMD-SHELL\" \"date \u003e\u003e /tmp/health_check || exit 1\"] \"3s\" \"3s\" \"1s\" '\\x03' %!q(bool=true)}"],"Healthc
heck":{"Test":["CMD-SHELL","date \u003e\u003e /tmp/health_check || exit 1"],"Interval":3000000000,"Timeout":3000000000,"StartPeriod":1000000000,"Retries":3,"ExitOnUnhealthy":true},"ArgsEscaped":true,"Image":"sha256:e4db68de4ff27c2adfea0c54bbb73a61a42f5b667c326de4d7d5b19ab71c6a3b","Volumes":null,"WorkingDir":"","Entrypoint":null,"OnBuild":null,"Labels":{},"Annotations":{"native.umask":"secure"}},"created":"2020-03-30T08:02:50.586247435Z","docker_version":"dev","history":[{"created":"2019-06-15T00:19:54.271494486Z","created_by":"/bin/sh -c #(nop) ADD file:b265aa0ea2ef7ff1f4a3e087217e75aca2c90f5c345406299664cc7969b2b28e in / "},{"created":"2019-06-15T00:19:54.402459069Z","created_by":"/bin/sh -c #(nop) CMD [\"sh\"]","empty_layer":true},{"created":"2020-03-30T08:02:50.586247435Z","created_by":"/bin/sh -c #(nop) HEALTHCHECK \u0026{[\"CMD-SHELL\" \"date \u003e\u003e /tmp/health_check || exit 1\"] \"3s\" \"3s\" \"1s\" '\\x03' %!q(bool=true)}","empty_layer":true}],"os":"linux","rootfs":{"type":"layers","diff_ids":["sha256:6194458b07fcf01f1483d96cd6c34302ffff7f382bb151a6d023c4e80ba3050a"]}}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录