Jenkins sudo: no tty present and no askpass program specified with NOPASSWD

后端 未结 3 1264
不思量自难忘°
不思量自难忘° 2021-02-04 00:47

I spend several days setting up the file /etc/sudoers to be able to give permissions to root to the user jenkins. I have Jenkins installed on my server

相关标签:
3条回答
  • 2021-02-04 01:16

    This is just a response to elaborate on the steps to take to fix the issue.

    First thing, figure out which user Jenkins GUI is using to execute the bash shell script.

    select the project > Configure > enter whoami in the executable shell > save and Build Now. View result in build history > click console output

    User may be tomcat or jenkins or whatever.

    SSH into Jenkins server

    1. sudo su
    2. visudo
    3. tomcat ALL=(ALL) NOPASSWD: ALL #if user displayed is tomcat
    0 讨论(0)
  • 2021-02-04 01:25

    This is quite possible that you are adding a wrong user to the sudoers file. This happened to me as well and the solution to add an entry in sudoers file wasn't working for me. You will need to know the actual user that your jenkins is using to execute commands. For this purpose you can add a build step (Execute shell) within your jenkins with the following command:

    whoami
    

    Then try running the jenkins job again and in the console output, you will see the user that jenkins is using to execute commands. You will then need to add this user to your sudoers file. For example if the user was 'tomcat', you will add the following line to the end of your sudoers file:

    tomcat ALL=(ALL) NOPASSWD: ALL
    

    Ref: http://techrofile.com/jenkins-sudo-no-tty-present-and-no-askpass-program-specified-with-nopasswd/

    0 讨论(0)
  • 2021-02-04 01:34

    I've tested the solution described by @Jayan in the comments of the question. You must include the new line at the end of the file:

    Solution: https://stackoverflow.com/a/24648413/54506

    #
    # This file MUST be edited with the 'visudo' command as root.
    #
    # Please consider adding local content in /etc/sudoers.d/ instead of
    # directly modifying this file.
    #
    # See the man page for details on how to write a sudoers file.
    #
    Defaults    env_reset
    Defaults    mail_badpass
    Defaults    secure_path="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"
    
    # Host alias specification
    
    # User alias specification
    
    # Cmnd alias specification
    
    # User privilege specification
    root    ALL=(ALL:ALL) ALL
    
    # Allow members of group sudo to execute any command
    %sudo   ALL=(ALL:ALL) ALL
    jenkins ALL=(ALL) NOPASSWD: ALL
    
    0 讨论(0)
提交回复
热议问题