[ 
https://issues.apache.org/jira/browse/YARN-11919?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=18051410#comment-18051410
 ] 

ASF GitHub Bot commented on YARN-11919:
---------------------------------------

edwardcapriolo commented on PR #8177:
URL: https://github.com/apache/hadoop/pull/8177#issuecomment-3741526716

   Ok I have it sorted:
   
   https://man7.org/linux/man-pages/man3/getpwnam.3p.html
   
   
          Note that sysconf(_SC_GETPW_R_SIZE_MAX) may return -1 if there is
          no hard limit on the size of the buffer needed to store all the
          groups returned. This example shows how an application can
          allocate a buffer of sufficient size to work with getpwnam_r().
          
    Both examples are wrong. You need to detect error and grow the buffer. Yikes
         
           while ((e = getpwnam_r("someuser", &result, buffer, len, &resultp))
                      == ERANGE)




> linux-container-executor segfault with get_user_info
> ----------------------------------------------------
>
>                 Key: YARN-11919
>                 URL: https://issues.apache.org/jira/browse/YARN-11919
>             Project: Hadoop YARN
>          Issue Type: Bug
>    Affects Versions: 3.4.2
>            Reporter: Edward Capriolo
>            Priority: Major
>              Labels: pull-request-available
>
> The code in container executor for getting user information is slightly 
> different then the recipe in the documentation. On alpine it repeatedly 
> segfaults
> {code:java}
> rvn package -Pnative -Dmaven.skip.test=true -DskipTests -Dtar
> cp target/native/target/usr/local/bin/container-executor /usr/local/bin/
> chmod 6050 /usr/local/bin/container-executor
> chgrp hadoop /usr/local/bin/container-executor
> chmod 6050 /usr/local/bin/container-executor
> /usr/local/bin/container-executor nobody nobody 0 
> application_1766935260716_0004  container_1766935260716_0004_02_000001 
> /yarn-root/nm-local-dir/nmPriv
>  {code}
> Result:
> {code:java}
> edgy
> main : command provided 0
> main : run as user is nobody
> main : requested yarn user is nobody
> main : validate_container_id 
> main : huh 
> validated command: INITIALIZE_CONTAINER
> init : set_user 
> maybe free_user 
> going to check user 
> min id 
> min id 1000
> Get user info 
> passwd info 
> got pwd 
> Segmentation fault (core dumped)
>  {code}
> The recipe here: 
> [https://linux.die.net/man/3/getpwnam_r]
> has better success.



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to