Para manter a variável de ambiente JAVA_HOME ao usar sudo, você deve adicionar Defaults env_keep +="JAVA_HOME"
ao seu arquivo sudoers.
Por favor, ajude-me a executar o comando abaixo da conta user2. Não consigo descobrir qual é o problema com isso.
[user2@localhost bin]# sudo -u user1 /opt/Tomcat/bin/shutdown.sh
Neither the JAVA_HOME nor the JRE_HOME environment variable is defined
At least one of these environment variable is needed to run this program
[user2@localhost bin]$ echo $JAVA_HOME
/opt/Java_7
A entrada para o arquivo user2 in sudoers é a seguinte:
%user2 ALL=(user1) NOPASSWD:/opt/Tomcat/bin/startup.sh,/opt/Tomcat/bin/shutdown.sh
No entanto, as variáveis de ambiente estão definidas. Eu corro o mesmo script com usuário root e funciona bem.
[root@localhost bin]# /opt/Tomcat/bin/shutdown.sh
Using CATALINA_BASE: /opt/Tomcat/
Using CATALINA_HOME: /opt/Tomcat/
Using CATALINA_TMPDIR: /opt/Tomcat//temp
Using JRE_HOME: /opt/Java_7
Using CLASSPATH: /opt/Tomcat//bin/bootstrap.jar:/opt/Tomcat//bin/tomcat-juli.jar
Eu verifiquei mais. JAVA_HOME está definido para os dois usuários.
[root@localhost bin]# pwd
/opt/Tomcat/bin
[root@localhost bin]# echo $JAVA_HOME
/opt/Java_7
[root@localhost bin]# su user1
[user1@localhost bin]$ echo $JAVA_HOME
/opt/Java_7
[user1@localhost bin]$ exit
[root@localhost bin]# su user2
[user2@localhost bin]$ echo $JAVA_HOME
/opt/Java_7
[user2@localhost bin]$ ps aux | grep java
user1 47066 0.1 10.9 1004608 77364 pts/2 Sl Jun12 0:15 /opt/Java_7/bin/java -Djava.util.logging.config.file=/opt/Tomcat//conf/logging.properties -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.endorsed.dirs=/opt/Tomcat//endorsed -classpath /opt/Tomcat//bin/bootstrap.jar:/opt/Tomcat//bin/tomcat-juli.jar -Dcatalina.base=/opt/Tomcat/ -Dcatalina.home=/opt/Tomcat/ -Djava.io.tmpdir=/opt/Tomcat//temp org.apache.catalina.startup.Bootstrap start
user2 49318 0.0 0.1 103240 840 pts/2 S+ 02:11 0:00 grep java
[user2@localhost bin]$ sudo -u user1 /opt/Tomcat/bin/shutdown.sh
Neither the JAVA_HOME nor the JRE_HOME environment variable is defined
At least one of these environment variable is needed to run this program
Se você usar sudo -u user1
, nem o caminho JAVA_HOME do usuário2 nem o caminho da raiz serão usados, será necessário configurar o caminho JAVA_HOME do usuário1. Do jeito que parece, você não configurou o caminho JAVA_HOME do user1