mirror of
https://github.com/ChristianLight/tutor.git
synced 2025-01-05 23:20:40 +00:00
fix: change kubectl wait to look at deployments not pods
When waiting for pods, it's possible that the deployment may be complete but, because other pods may have been Evicted or Killed, the wait wait condition completes.
This commit is contained in:
parent
0ae59a82a6
commit
55bc4c63fa
@ -20,6 +20,7 @@ Every user-facing change should have an entry in this changelog. Please respect
|
|||||||
|
|
||||||
- [Fix] `tutor dev quickstart` would fail under certain versions of docker-compose due to a bug in the logic that handled volume mounting. (by @kdmccormick)
|
- [Fix] `tutor dev quickstart` would fail under certain versions of docker-compose due to a bug in the logic that handled volume mounting. (by @kdmccormick)
|
||||||
- [Bugfix] The `tutor k8s start` command will succeed even when `k8s-override` and `kustomization-patches-strategic-merge` are not specified. (by @edazzocaisser)
|
- [Bugfix] The `tutor k8s start` command will succeed even when `k8s-override` and `kustomization-patches-strategic-merge` are not specified. (by @edazzocaisser)
|
||||||
|
- [Fix] `kubectl wait` checks deployments instead of pods as it could hang indefinitely if there are extra pods in a broken state. (by @keithgg)
|
||||||
|
|
||||||
## v14.0.3 (2022-07-09)
|
## v14.0.3 (2022-07-09)
|
||||||
|
|
||||||
|
@ -332,10 +332,10 @@ def delete(context: K8sContext, yes: bool) -> None:
|
|||||||
def init(context: K8sContext, limit: Optional[str]) -> None:
|
def init(context: K8sContext, limit: Optional[str]) -> None:
|
||||||
config = tutor_config.load(context.root)
|
config = tutor_config.load(context.root)
|
||||||
runner = context.job_runner(config)
|
runner = context.job_runner(config)
|
||||||
wait_for_pod_ready(config, "caddy")
|
wait_for_deployment_ready(config, "caddy")
|
||||||
for name in ["elasticsearch", "mysql", "mongodb"]:
|
for name in ["elasticsearch", "mysql", "mongodb"]:
|
||||||
if tutor_config.is_service_activated(config, name):
|
if tutor_config.is_service_activated(config, name):
|
||||||
wait_for_pod_ready(config, name)
|
wait_for_deployment_ready(config, name)
|
||||||
jobs.initialise(runner, limit_to=limit)
|
jobs.initialise(runner, limit_to=limit)
|
||||||
|
|
||||||
|
|
||||||
@ -458,7 +458,7 @@ def logs(
|
|||||||
@click.pass_obj
|
@click.pass_obj
|
||||||
def wait(context: K8sContext, name: str) -> None:
|
def wait(context: K8sContext, name: str) -> None:
|
||||||
config = tutor_config.load(context.root)
|
config = tutor_config.load(context.root)
|
||||||
wait_for_pod_ready(config, name)
|
wait_for_deployment_ready(config, name)
|
||||||
|
|
||||||
|
|
||||||
@click.command(
|
@click.command(
|
||||||
@ -536,14 +536,14 @@ def kubectl_exec(config: Config, service: str, command: List[str]) -> int:
|
|||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
def wait_for_pod_ready(config: Config, service: str) -> None:
|
def wait_for_deployment_ready(config: Config, service: str) -> None:
|
||||||
fmt.echo_info(f"Waiting for a {service} pod to be ready...")
|
fmt.echo_info(f"Waiting for a {service} deployment to be ready...")
|
||||||
utils.kubectl(
|
utils.kubectl(
|
||||||
"wait",
|
"wait",
|
||||||
*resource_selector(config, f"app.kubernetes.io/name={service}"),
|
*resource_selector(config, f"app.kubernetes.io/name={service}"),
|
||||||
"--for=condition=ContainersReady",
|
"--for=condition=Available=True",
|
||||||
"--timeout=600s",
|
"--timeout=600s",
|
||||||
"pod",
|
"deployment",
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
@ -120,7 +120,7 @@ def upgrade_from_maple(context: Context, config: Config) -> None:
|
|||||||
"--selector",
|
"--selector",
|
||||||
"app.kubernetes.io/name=mysql",
|
"app.kubernetes.io/name=mysql",
|
||||||
)
|
)
|
||||||
k8s.wait_for_pod_ready(config, "mysql")
|
k8s.wait_for_deployment_ready(config, "mysql")
|
||||||
|
|
||||||
# lms upgrade
|
# lms upgrade
|
||||||
k8s.kubectl_apply(
|
k8s.kubectl_apply(
|
||||||
@ -128,7 +128,7 @@ def upgrade_from_maple(context: Context, config: Config) -> None:
|
|||||||
"--selector",
|
"--selector",
|
||||||
"app.kubernetes.io/name=lms",
|
"app.kubernetes.io/name=lms",
|
||||||
)
|
)
|
||||||
k8s.wait_for_pod_ready(config, "lms")
|
k8s.wait_for_deployment_ready(config, "lms")
|
||||||
|
|
||||||
# Command backpopulate_user_tours
|
# Command backpopulate_user_tours
|
||||||
k8s.kubectl_exec(
|
k8s.kubectl_exec(
|
||||||
@ -144,7 +144,7 @@ def upgrade_from_maple(context: Context, config: Config) -> None:
|
|||||||
"--selector",
|
"--selector",
|
||||||
"app.kubernetes.io/name=cms",
|
"app.kubernetes.io/name=cms",
|
||||||
)
|
)
|
||||||
k8s.wait_for_pod_ready(config, "cms")
|
k8s.wait_for_deployment_ready(config, "cms")
|
||||||
|
|
||||||
# Command backfill_course_tabs
|
# Command backfill_course_tabs
|
||||||
k8s.kubectl_exec(
|
k8s.kubectl_exec(
|
||||||
|
Loading…
Reference in New Issue
Block a user