<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40"><head><meta http-equiv=Content-Type content="text/html; charset=utf-8"><meta name=Generator content="Microsoft Word 15 (filtered medium)"><!--[if !mso]><style>v\:* {behavior:url(#default#VML);}
o\:* {behavior:url(#default#VML);}
w\:* {behavior:url(#default#VML);}
.shape {behavior:url(#default#VML);}
</style><![endif]--><style><!--
/* Font Definitions */
@font-face
{font-family:"Cambria Math";
panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
{font-family:Calibri;
panose-1:2 15 5 2 2 2 4 3 2 4;}
@font-face
{font-family:DokChampa;
panose-1:2 11 6 4 2 2 2 2 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
{margin:0cm;
font-size:11.0pt;
font-family:"Calibri",sans-serif;}
a:link, span.MsoHyperlink
{mso-style-priority:99;
color:#0563C1;
text-decoration:underline;}
span.EmailStyle21
{mso-style-type:personal-reply;
font-family:"Calibri",sans-serif;
color:windowtext;}
.MsoChpDefault
{mso-style-type:export-only;
font-size:10.0pt;}
@page WordSection1
{size:612.0pt 792.0pt;
margin:70.85pt 70.85pt 2.0cm 70.85pt;}
div.WordSection1
{page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]--></head><body lang=EN-GB link="#0563C1" vlink=purple style='word-wrap:break-word'><div class=WordSection1><p class=MsoNormal><span style='mso-fareast-language:EN-US'>Thanks Michael, set -e errexit is the same as setting #!/bin/bash -e as interpreter as far as I’m aware. As I mention in the original post, I would like to avoid that. It involves modifying scripts (although to a lesser extent), and it would end script execution for other runtime errors or non-0 exit codes, which may not be desirable. But mainly, it can have unintended consequences on script execution (<a href="http://mywiki.wooledge.org/BashFAQ/105">http://mywiki.wooledge.org/BashFAQ/105</a>), and altogether does not really do what it claims to, potentially causing other hard-to-debug runtime errors. I have officially discouraged our analysts from using it for these reasons, so I would prefer to use this as a very last resort solution.<o:p></o:p></span></p><p class=MsoNormal><span style='mso-fareast-language:EN-US'>Sbatch doesn’t seem to have a -K argument, only srun does, which means I’d have to sbatch scripts that launch sbatch commands, which also leads to a significant rewrite… I am starting to think that the feature I am after does not exist! Since several other people have inquired about this in the past, I think it’d be useful to request this as a feature. Is there a place similar to Github issues, where users can make these suggestions to SchedMD?<o:p></o:p></span></p><p class=MsoNormal><span style='mso-fareast-language:EN-US'><o:p> </o:p></span></p><p class=MsoNormal><span style='mso-fareast-language:EN-US'>Cheers,<o:p></o:p></span></p><p class=MsoNormal><span style='mso-fareast-language:EN-US'><br>A<o:p></o:p></span></p><p class=MsoNormal><span style='mso-fareast-language:EN-US'><o:p> </o:p></span></p><div><p class=MsoNormal>-------------------------------------------------------------<o:p></o:p></p><p class=MsoNormal>Dr. Arthur Gilly<o:p></o:p></p><p class=MsoNormal>Head of Analytics<o:p></o:p></p><p class=MsoNormal>Institute of Translational Genomics<o:p></o:p></p><p class=MsoNormal>Helmholtz-Centre Munich (HMGU)<o:p></o:p></p><p class=MsoNormal>-------------------------------------------------------------<o:p></o:p></p></div><p class=MsoNormal><span style='mso-fareast-language:EN-US'><o:p> </o:p></span></p><div><div style='border:none;border-top:solid #E1E1E1 1.0pt;padding:3.0pt 0cm 0cm 0cm'><p class=MsoNormal><b><span lang=EN-US>From:</span></b><span lang=EN-US> slurm-users <slurm-users-bounces@lists.schedmd.com> <b>On Behalf Of </b>Renfro, Michael<br><b>Sent:</b> Wednesday, 9 June 2021 19:32<br><b>To:</b> Slurm User Community List <slurm-users@lists.schedmd.com><br><b>Subject:</b> Re: [slurm-users] Kill job when child process gets OOM-killed<o:p></o:p></span></p></div></div><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><span lang=EN-US>Yep, those are reasons not to create the array of 100k jobs.<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US><o:p> </o:p></span></p><p class=MsoNormal><span lang=EN-US>From <a href="https://www.mail-archive.com/slurm-users@lists.schedmd.com/msg04092.html">https://www.mail-archive.com/slurm-users@lists.schedmd.com/msg04092.html</a> , deeper in the thread from one of your references, there's a mention of using both 'set -o errexit' inside the job script alongside setting an sbatch parameter of '-K' or '--kill-on-bad-exit' to have a job exit if any of its processes exit with a non-zero error code.<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US><o:p> </o:p></span></p><p class=MsoNormal><span lang=EN-US>Assuming all your processes exit with code 0 when things are running normally, that could be an option.<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US><o:p> </o:p></span></p><div style='border:none;border-top:solid #B5C4DF 1.0pt;padding:3.0pt 0cm 0cm 0cm'><p class=MsoNormal style='margin-bottom:12.0pt'><b><span lang=EN-US style='font-size:12.0pt;color:black'>From: </span></b><span lang=EN-US style='font-size:12.0pt;color:black'>slurm-users <<a href="mailto:slurm-users-bounces@lists.schedmd.com">slurm-users-bounces@lists.schedmd.com</a>> on behalf of Arthur Gilly <<a href="mailto:arthur.gilly@helmholtz-muenchen.de">arthur.gilly@helmholtz-muenchen.de</a>><br><b>Date: </b>Tuesday, June 8, 2021 at 10:00 PM<br><b>To: </b>'Slurm User Community List' <<a href="mailto:slurm-users@lists.schedmd.com">slurm-users@lists.schedmd.com</a>><br><b>Subject: </b>Re: [slurm-users] Kill job when child process gets OOM-killed<o:p></o:p></span></p></div><p align=center style='margin:0cm;text-align:center;background:white'><b><span lang=EN-US style='font-size:12.0pt;color:red;background:white'>External Email Warning</span></b><span lang=EN-US><o:p></o:p></span></p><p align=center style='mso-margin-top-alt:0cm;margin-right:12.0pt;margin-bottom:0cm;margin-left:12.0pt;text-align:center;background:white'><b><span lang=EN-US style='font-size:12.0pt;color:red'>This email originated from outside the university. Please use caution when opening attachments, clicking links, or responding to requests.</span></b><span lang=EN-US><o:p></o:p></span></p><div class=MsoNormal align=center style='text-align:center'><span lang=EN-US><hr size=1 width="100%" align=center></span></div><div><p class=MsoNormal><span lang=EN-US>I could say that the limit on max array sizes is lower on our cluster, and we start to see I/O problems very fast as parallelism scales (which we can limit with % as you mention). But the actual reason is simpler, as I mentioned we have an entire collection of scripts which were written for a previous LSF system where the “kill job on OOM†setting was active. What you are suggesting would lead to us rewriting all these scripts so that each submitted job is granular (executes only 1 atomic task) and orchestrate all of it using SLURM dependencies etc. This is a huge undertaking and I’d rather just find this setting, which I’m sure exists.<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US> <o:p></o:p></span></p><div><p class=MsoNormal><span lang=EN-US>-------------------------------------------------------------<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US>Dr. Arthur Gilly<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US>Head of Analytics<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US>Institute of Translational Genomics<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US>Helmholtz-Centre Munich (HMGU)<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US>-------------------------------------------------------------<o:p></o:p></span></p></div><p class=MsoNormal><span lang=EN-US> <o:p></o:p></span></p><div><div style='border:none;border-top:solid #E1E1E1 1.0pt;padding:3.0pt 0cm 0cm 0cm'><p class=MsoNormal><b><span lang=EN-US>From:</span></b><span lang=EN-US> slurm-users <<a href="mailto:slurm-users-bounces@lists.schedmd.com">slurm-users-bounces@lists.schedmd.com</a>> <b>On Behalf Of </b>Renfro, Michael<br><b>Sent:</b> Tuesday, 8 June 2021 20:12<br><b>To:</b> Slurm User Community List <<a href="mailto:slurm-users@lists.schedmd.com">slurm-users@lists.schedmd.com</a>><br><b>Subject:</b> Re: [slurm-users] Kill job when child process gets OOM-killed<o:p></o:p></span></p></div></div><p class=MsoNormal><span lang=EN-US> <o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US>Any reason *not* to create an array of 100k jobs and let the scheduler just handle things? Current versions of Slurm support arrays of up to 4M jobs, and you can limit the number of jobs running simultaneously with the '%' specifier in your array= sbatch parameter.<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US> <o:p></o:p></span></p><div style='border:none;border-top:solid #B5C4DF 1.0pt;padding:3.0pt 0cm 0cm 0cm'><p class=MsoNormal style='margin-bottom:12.0pt'><b><span lang=EN-US style='font-size:12.0pt;color:black'>From: </span></b><span lang=EN-US style='font-size:12.0pt;color:black'>slurm-users <<a href="mailto:slurm-users-bounces@lists.schedmd.com">slurm-users-bounces@lists.schedmd.com</a>> on behalf of Arthur Gilly <<a href="mailto:arthur.gilly@helmholtz-muenchen.de">arthur.gilly@helmholtz-muenchen.de</a>><br><b>Date: </b>Tuesday, June 8, 2021 at 4:12 AM<br><b>To: </b>'Slurm User Community List' <<a href="mailto:slurm-users@lists.schedmd.com">slurm-users@lists.schedmd.com</a>><br><b>Subject: </b>Re: [slurm-users] Kill job when child process gets OOM-killed</span><span lang=EN-US><o:p></o:p></span></p></div><p align=center style='margin:0cm;text-align:center;background:white'><b><span lang=EN-US style='font-size:12.0pt;color:red;background:white'>External Email Warning</span></b><span lang=EN-US><o:p></o:p></span></p><p align=center style='mso-margin-top-alt:0cm;margin-right:12.0pt;margin-bottom:0cm;margin-left:12.0pt;text-align:center;background:white'><b><span lang=EN-US style='font-size:12.0pt;color:red'>This email originated from outside the university. Please use caution when opening attachments, clicking links, or responding to requests.</span></b><span lang=EN-US><o:p></o:p></span></p><div class=MsoNormal align=center style='text-align:center'><span lang=EN-US><hr size=1 width="100%" align=center></span></div><div><p class=MsoNormal><span lang=EN-US>Thank you Loris!<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US> <o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US>Like many of our jobs, this is an embarrassingly parallel analysis, where we have to strike a compromise between what would be a completely granular array of >100,000 small jobs or some kind of serialisation through loops. So the individual jobs where I noticed this behaviour are actually already part of an array :)<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US> <o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US>Cheers,<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US><br>Arthur<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US> <o:p></o:p></span></p><div><p class=MsoNormal><span lang=EN-US>-------------------------------------------------------------<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US>Dr. Arthur Gilly<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US>Head of Analytics<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US>Institute of Translational Genomics<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US>Helmholtz-Centre Munich (HMGU)<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US>-------------------------------------------------------------<o:p></o:p></span></p></div><p class=MsoNormal><span lang=EN-US> <o:p></o:p></span></p><div><div style='border:none;border-top:solid #E1E1E1 1.0pt;padding:3.0pt 0cm 0cm 0cm'><p class=MsoNormal><b><span lang=EN-US>From:</span></b><span lang=EN-US> slurm-users <<a href="mailto:slurm-users-bounces@lists.schedmd.com">slurm-users-bounces@lists.schedmd.com</a>> <b>On Behalf Of </b>Loris Bennett<br><b>Sent:</b> Tuesday, 8 June 2021 16:05<br><b>To:</b> Slurm User Community List <<a href="mailto:slurm-users@lists.schedmd.com">slurm-users@lists.schedmd.com</a>><br><b>Subject:</b> Re: [slurm-users] Kill job when child process gets OOM-killed<o:p></o:p></span></p></div></div><p class=MsoNormal><span lang=EN-US> <o:p></o:p></span></p><p class=MsoNormal style='margin-bottom:12.0pt'><span lang=EN-US>Dear Arthur,<br><br>Arthur Gilly <<a href="mailto:arthur.gilly@helmholtz-muenchen.de">arthur.gilly@helmholtz-muenchen.de</a>> writes:<br><br>> Dear Slurm users,<br>><br>> <br>><br>> I am looking for a SLURM setting that will kill a job immediately when any subprocess of that job hits an OOM limit. Several posts have touched upon that, e.g: <a href="https://nam11.safelinks.protection.outlook.com/?url=https%3A%2F%2Fwww.mail-archive.com%2Fslurm-users%40lists.schedmd.com%2Fmsg04091.html&data=04%7C01%7Crenfro%40tntech.edu%7Cc3bc0c4af2fe4eacf38808d92af2ad25%7C66fecaf83dc04d2cb8b8eff0ddea46f0%7C1%7C0%7C637588044490972285%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000&sdata=AmfXDtCVNH5EbxNAnkkiLimt6g5ZXP4eSJFhV0J9Qo4%3D&reserved=0">https://www.mail-archive.com/slurm-users@lists.schedmd.com/msg04091.html</a> and<br>> <a href="https://nam11.safelinks.protection.outlook.com/?url=https%3A%2F%2Fwww.mail-archive.com%2Fslurm-users%40lists.schedmd.com%2Fmsg04190.html&data=04%7C01%7Crenfro%40tntech.edu%7Cc3bc0c4af2fe4eacf38808d92af2ad25%7C66fecaf83dc04d2cb8b8eff0ddea46f0%7C1%7C0%7C637588044490982280%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000&sdata=GvBruGVoTdrwFB4dlJSPbI%2Fd2ExywZuMtFq%2ByyF2ias%3D&reserved=0">https://www.mail-archive.com/slurm-users@lists.schedmd.com/msg04190.html</a> or <a href="https://nam11.safelinks.protection.outlook.com/?url=https%3A%2F%2Fbugs.schedmd.com%2Fshow_bug.cgi%3Fid%3D3216&data=04%7C01%7Crenfro%40tntech.edu%7Cc3bc0c4af2fe4eacf38808d92af2ad25%7C66fecaf83dc04d2cb8b8eff0ddea46f0%7C1%7C0%7C637588044490992273%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000&sdata=Nfas0jKpRq1mMfTGYEGuvChPZhcm1ASAnghek0%2BxEG4%3D&reserved=0">https://bugs.schedmd.com/show_bug.cgi?id=3216</a> but I cannot find an answer that works in our setting.<br>><br>> <br>><br>> The two options I have found are:<br>><br>> 1 Set shebang to #!/bin/bash -e, which we don’t want to do as we’d need to change this for hundreds of scripts from another cluster where we had a different scheduler, AND it would kill tasks for other runtime errors (e.g. if one command in the<br>> script doesn’t find a file).<br>><br>> 2 Set KillOnBadExit=1. I am puzzled by this one. This is supposed to be overridden by srun’s -K option. Using the example below, srun -K --mem=1G ./multalloc.sh would be expected to kill the job at the first OOM. But it doesn’t, and happily<br>> keeps reporting 3 oom-kill events. So, will this work?<br>><br>> <br>><br>> The reason we want this is that we have script that execute programs in loops. These programs are slow and memory intensive. When the first one crashes for OOM, the next iterations also crash. In the current setup, we are wasting days<br>> executing loops where every iteration crashes after an hour or so due to OOM.<br><br>Not an answer to your question, but if your runs are independent, would<br>using a job array help you here?<br><br>Cheers,<br><br>Loris<br><br>> We are using cgroups (and we want to keep them) with the following config:<br>><br>> CgroupAutomount=yes<br>><br>> ConstrainCores=yes<br>><br>> ConstrainDevices=yes<br>><br>> ConstrainKmemSpace=no<br>><br>> ConstrainRAMSpace=yes<br>><br>> ConstrainSwapSpace=yes<br>><br>> MaxSwapPercent=10<br>><br>> TaskAffinity=no<br>><br>> <br>><br>> Relevant bits from slurm.conf:<br>><br>> SelectTypeParameters=CR_Core_Memory,CR_ONE_TASK_PER_CORE<br>><br>> SelectType=select/cons_tres<br>><br>> GresTypes=gpu,mps,bandwidth<br>><br>> <br>><br>> <br>><br>> Very simple example:<br>><br>> #!/bin/bash<br>><br>> # multalloc.sh – each line is a very simple cpp program that allocates a 8Gb vector and fills it with random floats<br>><br>> echo one<br>><br>> ./alloc8Gb<br>><br>> echo two<br>><br>> ./alloc8Gb<br>><br>> echo three<br>><br>> ./alloc8Gb<br>><br>> echo done.<br>><br>> <br>><br>> This is submitted as follows:<br>><br>> <br>><br>> sbatch --mem=1G ./multalloc.sh<br>><br>> <br>><br>> The log is :<br>><br>> one<br>><br>> ./multalloc.sh: line 4: 231155 Killed ./alloc8Gb<br>><br>> two<br>><br>> ./multalloc.sh: line 6: 231181 Killed ./alloc8Gb<br>><br>> three<br>><br>> ./multalloc.sh: line 8: 231263 Killed ./alloc8Gb<br>><br>> done.<br>><br>> slurmstepd: error: Detected 3 oom-kill event(s) in StepId=3130111.batch cgroup. Some of your processes may have been killed by the cgroup out-of-memory handler.<br>><br>> <br>><br>> I am expecting an OOM job kill right before “twoâ€.<br>><br>> <br>><br>> Any help appreciated.<br>><br>> <br>><br>> Best regards,<br>><br>> <br>><br>> Arthur<br>><br>> <br>><br>> <br>><br>> -------------------------------------------------------------<br>><br>> Dr. Arthur Gilly<br>><br>> Head of Analytics<br>><br>> Institute of Translational Genomics<br>><br>> Helmholtz-Centre Munich (HMGU)<br>><br>> -------------------------------------------------------------<br>><br>> <br>><br>> Helmholtz Zentrum München <br>> Deutsches Forschungszentrum für Gesundheit und Umwelt (GmbH) <br>> Ingolstädter Landstr. 1 <br>> 85764 Neuherberg <br>> <a href="https://nam11.safelinks.protection.outlook.com/?url=http%3A%2F%2Fwww.helmholtz-muenchen.de%2F&data=04%7C01%7Crenfro%40tntech.edu%7Cc3bc0c4af2fe4eacf38808d92af2ad25%7C66fecaf83dc04d2cb8b8eff0ddea46f0%7C1%7C0%7C637588044490992273%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000&sdata=IrZ35zKCA2jhZY8N9r%2F2uLDxnTW1eAp5AnuiG3jq5s4%3D&reserved=0">www.helmholtz-muenchen.de</a> <br>> Aufsichtsratsvorsitzende: MinDir.in Prof. Dr. Veronika von Messling <br>> Geschäftsführung: Prof. Dr. med. Dr. h.c. Matthias Tschöp, Kerstin Günther<br>> Registergericht: Amtsgericht München HRB 6466 <br>> USt-IdNr: DE 129521671 <br>><br>-- <br>Dr. Loris Bennett (Hr./Mr.)<br>ZEDAT, Freie Universität Berlin Email <a href="mailto:loris.bennett@fu-berlin.de">loris.bennett@fu-berlin.de</a><o:p></o:p></span></p><p class=MsoNormal style='margin-bottom:12.0pt'><span lang=EN-US><br>Helmholtz Zentrum München <br>Deutsches Forschungszentrum für Gesundheit und Umwelt (GmbH) <br>Ingolstädter Landstr. 1 <br>85764 Neuherberg <br><a href="https://nam11.safelinks.protection.outlook.com/?url=http%3A%2F%2Fwww.helmholtz-muenchen.de%2F&data=04%7C01%7Crenfro%40tntech.edu%7Cc3bc0c4af2fe4eacf38808d92af2ad25%7C66fecaf83dc04d2cb8b8eff0ddea46f0%7C1%7C0%7C637588044491002268%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000&sdata=H5PgH5ce%2BFzn4hfH1l7Xu9OXDXg5DLfp8yImREU4klU%3D&reserved=0">www.helmholtz-muenchen.de</a> <br>Aufsichtsratsvorsitzende: MinDir.in Prof. Dr. Veronika von Messling <br>Geschäftsführung: Prof. Dr. med. Dr. h.c. Matthias Tschöp, Kerstin Günther<br>Registergericht: Amtsgericht München HRB 6466 <br>USt-IdNr: DE 129521671 <br><br><br><o:p></o:p></span></p></div><p class=MsoNormal style='margin-bottom:12.0pt'><span lang=EN-US><br>Helmholtz Zentrum München <br>Deutsches Forschungszentrum für Gesundheit und Umwelt (GmbH) <br>Ingolstädter Landstr. 1 <br>85764 Neuherberg <br><a href="http://www.helmholtz-muenchen.de">www.helmholtz-muenchen.de</a> <br>Aufsichtsratsvorsitzende: MinDir.in Prof. Dr. Veronika von Messling <br>Geschäftsführung: Prof. Dr. med. Dr. h.c. Matthias Tschöp, Kerstin Günther<br>Registergericht: Amtsgericht München HRB 6466 <br>USt-IdNr: DE 129521671 <br><br><br><o:p></o:p></span></p></div></div>
<br><html><body>Helmholtz Zentrum München <br>
Deutsches Forschungszentrum für Gesundheit und Umwelt (GmbH) <br>
Ingolstädter Landstr. 1 <br>
85764 Neuherberg <br>
www.helmholtz-muenchen.de <br>
Aufsichtsratsvorsitzende: MinDir.in Prof. Dr. Veronika von Messling <br>
Geschäftsführung: Prof. Dr. med. Dr. h.c. Matthias Tschöp, Kerstin Günther<br>
Registergericht: Amtsgericht München HRB 6466 <br>
USt-IdNr: DE 129521671
<br>
<br></body></html>
<br>
<br>
<br></body></html>