提交 41a1a935 编写于 作者: Z zhongjiang-ali 提交者: Xu Yu

alinux: oom: add ratelimit printk to prevent softlockup

fix #26198457

Due to some pressure case, it is easier to triggers oom, which will
result in more printk message. we limit the dump_header printk by
ratelimit in memory cgroup further, but the single printk should be
limited in that cases, Otherwise, softlockup will triggers.

[xuyu: replace printk_ratelimit with __ratelimit, and fix warning on
quoted string split across lines]
Reviewed-by: NXunlei Pang <xlpang@linux.alibaba.com>
Signed-off-by: Nzhongjiang-ali <zhongjiang-ali@linux.alibaba.com>
Signed-off-by: NXu Yu <xuyu@linux.alibaba.com>
上级 a4229072
...@@ -855,12 +855,15 @@ static bool task_will_free_mem(struct task_struct *task) ...@@ -855,12 +855,15 @@ static bool task_will_free_mem(struct task_struct *task)
return ret; return ret;
} }
static void __oom_kill_process(struct task_struct *victim) static void __oom_kill_process(struct task_struct *victim, bool is_memcg)
{ {
struct task_struct *p; struct task_struct *p;
struct mm_struct *mm; struct mm_struct *mm;
bool can_oom_reap = true; bool can_oom_reap = true;
bool suppress_print = false;
if (is_memcg && __ratelimit(&printk_ratelimit_state))
suppress_print = true;
p = find_lock_task_mm(victim); p = find_lock_task_mm(victim);
if (!p) { if (!p) {
put_task_struct(victim); put_task_struct(victim);
...@@ -886,8 +889,10 @@ static void __oom_kill_process(struct task_struct *victim) ...@@ -886,8 +889,10 @@ static void __oom_kill_process(struct task_struct *victim)
*/ */
do_send_sig_info(SIGKILL, SEND_SIG_FORCED, victim, PIDTYPE_TGID); do_send_sig_info(SIGKILL, SEND_SIG_FORCED, victim, PIDTYPE_TGID);
mark_oom_victim(victim); mark_oom_victim(victim);
if (!suppress_print)
pr_err("Killed process %d (%s) total-vm:%lukB, anon-rss:%lukB, file-rss:%lukB, shmem-rss:%lukB\n", pr_err("Killed process %d (%s) total-vm:%lukB, anon-rss:%lukB, file-rss:%lukB, shmem-rss:%lukB\n",
task_pid_nr(victim), victim->comm, K(victim->mm->total_vm), task_pid_nr(victim), victim->comm,
K(victim->mm->total_vm),
K(get_mm_counter(victim->mm, MM_ANONPAGES)), K(get_mm_counter(victim->mm, MM_ANONPAGES)),
K(get_mm_counter(victim->mm, MM_FILEPAGES)), K(get_mm_counter(victim->mm, MM_FILEPAGES)),
K(get_mm_counter(victim->mm, MM_SHMEMPAGES))); K(get_mm_counter(victim->mm, MM_SHMEMPAGES)));
...@@ -943,7 +948,7 @@ static int oom_kill_memcg_member(struct task_struct *task, void *unused) ...@@ -943,7 +948,7 @@ static int oom_kill_memcg_member(struct task_struct *task, void *unused)
if (task->signal->oom_score_adj != OOM_SCORE_ADJ_MIN && if (task->signal->oom_score_adj != OOM_SCORE_ADJ_MIN &&
!is_global_init(task)) { !is_global_init(task)) {
get_task_struct(task); get_task_struct(task);
__oom_kill_process(task); __oom_kill_process(task, true);
} }
return 0; return 0;
} }
...@@ -961,6 +966,7 @@ static void oom_kill_process(struct oom_control *oc, const char *message) ...@@ -961,6 +966,7 @@ static void oom_kill_process(struct oom_control *oc, const char *message)
unsigned int victim_points = 0; unsigned int victim_points = 0;
static DEFINE_RATELIMIT_STATE(oom_global_rs, DEFAULT_RATELIMIT_INTERVAL, static DEFINE_RATELIMIT_STATE(oom_global_rs, DEFAULT_RATELIMIT_INTERVAL,
DEFAULT_RATELIMIT_BURST); DEFAULT_RATELIMIT_BURST);
bool suppress_print = false;
/* /*
* If the task is already exiting, don't alarm the sysadmin or kill * If the task is already exiting, don't alarm the sysadmin or kill
...@@ -982,6 +988,15 @@ static void oom_kill_process(struct oom_control *oc, const char *message) ...@@ -982,6 +988,15 @@ static void oom_kill_process(struct oom_control *oc, const char *message)
else if (!is_memcg_oom(oc) && __ratelimit(&oom_global_rs)) else if (!is_memcg_oom(oc) && __ratelimit(&oom_global_rs))
dump_global_header(oc, p); dump_global_header(oc, p);
/*
* Prevent too much printk to result in softlock in memory cgroup oom.
* Meanwhile, Use printk_ratelimit_state rather than oom_memcg_rs to
* not suppress important print message overly.
*/
if (is_memcg_oom(oc) && __ratelimit(&printk_ratelimit_state))
suppress_print = true;
if (!suppress_print)
pr_err("%s: Kill process %d (%s) score %u or sacrifice child\n", pr_err("%s: Kill process %d (%s) score %u or sacrifice child\n",
message, task_pid_nr(p), p->comm, points); message, task_pid_nr(p), p->comm, points);
...@@ -1028,7 +1043,7 @@ static void oom_kill_process(struct oom_control *oc, const char *message) ...@@ -1028,7 +1043,7 @@ static void oom_kill_process(struct oom_control *oc, const char *message)
*/ */
oom_group = mem_cgroup_get_oom_group(victim, oc->memcg); oom_group = mem_cgroup_get_oom_group(victim, oc->memcg);
__oom_kill_process(victim); __oom_kill_process(victim, is_memcg_oom(oc));
/* /*
* If necessary, kill all tasks in the selected memory cgroup. * If necessary, kill all tasks in the selected memory cgroup.
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册