Hi Luke, I replaced my shell script with the one you wrote. Same old error message appeared again 'change from notrun to 0 failed: /tmp/QoS/QoS.sh returned 1 instead of o at /etc/puppet/manifests/site.pp' . Your script didn't generate any log at client machine. Now I am sure about one thing that there is no issue with the shell script itself. The exec command is having hiccup even before executing the shell. I even tried command paremeter in exec but no use. Do you know anyother way to execute bash shell in puppet?
Thanks much, Annie On Fri, Jun 17, 2011 at 4:30 PM, Annie Rana <annier...@gmail.com> wrote: > Hi Luke, > > I replaced my shell script with the one you wrote. Same old error message > appeared again 'change from notrun to 0 failed: /tmp/QoS/QoS.sh returned 1 > instead of o at /etc/puppet/manifests/site.pp'. Your script didn't generated > any log at client machine. Now I am sure about one thing that there is no > issue with the shell script itself. The exec command is having hiccup even > before executing the shell. I even tried command paremeter in exec but no > use. Do you know anyother way to execute bash shell in puppet? > > Thanks much, > > Annie > > On Fri, Jun 17, 2011 at 4:06 PM, Luke Bigum <luke.bi...@lmax.com> wrote: > >> I'm out of ideas and I'd resort to hacking the script a bit to get >> some debugging output. Try just this in QoS.sh to try identify what's >> failing: >> >> export LAN=eth1 >> export WAN=eth0 >> CMD="tc filter add dev ${WAN} parent 1:0 prio 4 protocol ip u32 match >> ip tos 0x880xff classid 1:12" >> OUT=$($CMD) > /tmp/QoS.out 2>&1 >> RET=$? >> print "Command $CMD returned $RET" >> /tmp/QoS.out 2>&1 >> CMD="iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p udp --sport >> 2345 -j TOS --set-tos 0x28" >> OUT=$($CMD) >> /tmp/QoS.out 2>&1 >> RET=$? >> print "Command $CMD returned $RET" >> /tmp/QoS.out 2>&1 >> CMD="iptables-save" >> OUT=$($CMD) >> /tmp/QoS.out 2>&1 >> RET=$? >> print "Command $CMD returned $RET" >> /tmp/QoS.out 2>&1 >> >> >> Or something like that. >> >> On Jun 17, 4:01 pm, Annie Rana <annier...@gmail.com> wrote: >> > Thanks again Peter but sorry it didn't work out either. >> > >> > On Fri, Jun 17, 2011 at 3:52 PM, Peter Bukowinski <pmb...@gmail.com> >> wrote: >> > > In your QoS.sh file, make sure to use explicit paths to executables, >> e.g: >> > >> > > use '/sbin/iptables -blah …' NOT 'iptables -blah …' >> > >> > > -- >> > > Peter M. Bukowinski >> > > Systems Engineer >> > > Janelia Farm Research Campus, HHMI >> > >> > > On Friday, June 17, 2011 at 10:44 AM, Annie Rana wrote: >> > >> > > > Hi Luke, >> > > > What's your shell script expected to >> > > > do? >> > > > The shell script would generate Iptables rules >> > >> > > > How do you know it didn't work? >> > > > I can check using ipatbles -L or iptables -t mangle -L commands >> > >> > > > If you run it by hand in a root shell, does it work then? >> > > > Yes >> > >> > > > If so, >> > > > there might be an environment problem when running from Puppet, like >> > > > $PATH or something. Try set the parameter "logoutput => true" in the >> > > > exec resource. >> > > > I did but no affect. >> > >> > > > Thanks again, much appreciated your help and time. >> > > > On Fri, Jun 17, 2011 at 3:26 PM, Luke Bigum <luke.bi...@lmax.com >> (mailto: >> > > luke.bi...@lmax.com)> wrote: >> > > > > How do you know it didn't work? What's your shell script expected >> to >> > > > > do? If you run it by hand in a root shell, does it work then? If >> so, >> > > > > there might be an environment problem when running from Puppet, >> like >> > > > > $PATH or something. Try set the parameter "logoutput => true" in >> the >> > > > > exec resource. >> > >> > > > > On Jun 17, 3:18 pm, Annie Rana <annier...@gmail.com (mailto: >> > > annier...@gmail.com)> wrote: >> > > > > > Thanks but it couldn't work though i got the message that shell >> > > script is >> > > > > > successfully executed. >> > >> > > > > > On Fri, Jun 17, 2011 at 2:44 PM, Luke Bigum < >> luke.bi...@lmax.com(mailto: >> > > luke.bi...@lmax.com)> wrote: >> > > > > > > Annie, >> > >> > > > > > >http://docs.puppetlabs.com/references/stable/type.html#exec >> > >> > > > > > > By default the expected return code is probably zero, your >> script >> > > is >> > > > > > > returning 1. Whether this is correct or not I don't know, but >> you >> > > can >> > > > > > > tell puppet to expect a different return code: >> > >> > > > > > > exec { '/etc/shell_file': >> > > > > > > require => File['/etc/shell_file'], >> > > > > > > returns => 1, >> > > > > > > } >> > >> > > > > > > On Jun 17, 2:36 pm, Annie Rana <annier...@gmail.com (mailto: >> > > annier...@gmail.com)> wrote: >> > > > > > > > I apologize for posting wrong log messages, here is the >> correct >> > > log: >> > >> > > > > > > > notice: Starting catalog run >> > > > > > > > notice: //File[/tmp/QoS/QoS.sh (http://QoS.sh)]/ensure: >> created >> > > > > > > > err: //Exec[/tmp/QoS/QoS.sh (http://QoS.sh)]/returns: >> change >> > > from notrun to 0 failed: >> > > > > > > > /tmp/QoS/QoS.sh (http://QoS.sh) returned 1 instead of 0 at >> > > > > > > /etc/puppet/manifests/site.pp:10 >> > > > > > > > notice: Finished catalog run in 0.46 seconds >> > >> > > > > > > > Any help please? >> > >> > > > > > > > On Fri, Jun 17, 2011 at 2:09 PM, Annie Rana < >> annier...@gmail.com(mailto: >> > > annier...@gmail.com)> wrote: >> > > > > > > > > Hi Peter, thanks for your reply. I managed to copy the >> shell >> > > file >> > > > > > > puppet >> > > > > > > > > client using the file resource recipe you specified but >> exec is >> > > > > > > throwing an >> > > > > > > > > error, which is as follows: >> > >> > > > > > > > > info: No classes to store >> > > > > > > > > info: Caching catalog at >> /var/lib/puppet/state/localconfig.yaml >> > > > > > > > > notice: Starting catalog run >> > > > > > > > > err: //File[/tmp/QoS/QoS.sh (http://QoS.sh)]/ensure: >> change >> > > from absent to file failed: >> > > > > > > > > Could not set file on ensure: No such file or directory - >> > > > > > > > > /tmp/QoS/QoS.sh.puppettmp at >> /etc/puppet/manifests/site.pp:7 >> > > > > > > > > notice: //Exec[/tmp/QoS/QoS.sh (http://QoS.sh)]: >> Dependency >> > > file[/tmp/QoS/QoS.sh (http://QoS.sh)] has 1 >> > > > > > > > > failures >> > > > > > > > > warning: //Exec[/tmp/QoS/QoS.sh (http://QoS.sh)]: >> Skipping >> > > because of failed >> > > > > > > dependencies >> > > > > > > > > notice: Finished catalog run in 0.38 seconds >> > >> > > > > > > > > When I tried running the shell script manually using the >> > > following >> > > > > > > command >> > >> > > > > > > > > '/tmp/QoS/QoS.sh (http://QoS.sh);echo $?' >> > >> > > > > > > > > , it worked fine printing 0 at the end. Any help what is >> wrong >> > > with >> > > > > > > exec >> > > > > > > > > resource recipe? >> > >> > > > > > > > > Thanks in advance for your time. >> > >> > > > > > > > > Regards, >> > >> > > > > > > > > A. >> > >> > > > > > > > > On Thu, Jun 16, 2011 at 8:42 PM, Peter Bukowinski < >> > > pmb...@gmail.com (mailto:pmb...@gmail.com) >> > > > > > > > wrote: >> > >> > > > > > > > > > It sounds like you haven't set up the puppet fileserver >> yet. >> > > Choose a >> > > > > > > > > > directory that will hold files you want to copy to >> clients. I >> > > use >> > > > > > > > > > /opt/files, so that's what is in my example. Create >> > > fileserver.conf in >> > > > > > > the >> > > > > > > > > > same directory as puppet.conf and add these lines: >> > >> > > > > > > > > > [files] >> > > > > > > > > > path /opt/files >> > > > > > > > > > allow *.client.domain >> > >> > > > > > > > > > Put your shell file in the path you specified. Now you >> just >> > > need to >> > > > > > > set up >> > > > > > > > > > a file and exec resource. Note the source item in the >> file >> > > resource >> > > > > > > and the >> > > > > > > > > > require item in exec. >> > >> > > > > > > > > > file { '/etc/shell_file': >> > > > > > > > > > ensure => present, >> > > > > > > > > > owner => 'root', >> > > > > > > > > > group => 'root', >> > > > > > > > > > mode => '0755', >> > > > > > > > > > source => 'puppet://puppet/files/shell_file', >> > > > > > > > > > } >> > >> > > > > > > > > > exec { '/etc/shell_file': require => >> File['/etc/shell_file'] >> > > } >> > >> > > > > > > > > > -- >> > > > > > > > > > Peter M. Bukowinski >> > > > > > > > > > Systems Engineer >> > > > > > > > > > Janelia Farm Research Campus, HHMI >> > >> > > > > > > > > > On Thursday, June 16, 2011 at 3:17 PM, annierana wrote: >> > >> > > > > > > > > > > Hi all, I am new to puppet. I need a sample recipe to >> > > write/copy a >> > > > > > > > > > > shell file on puppet client. The shell file exists on >> > > puppet server. >> > > > > > > > > > > Once the file is written, I also want to execute it. I >> have >> > > tried >> > > > > > > > > > > using file resource with ensure command to copy at >> /etc but >> > > > > > > permission >> > > > > > > > > > > was denied and moreover with a different directory >> path >> > > (\tmp) it >> > > > > > > just >> > > > > > > > > > > created an empty file. Can anyone please help? >> > >> > > > > > > > > > > Regards, >> > >> > > > > > > > > > > A. >> > >> > > > > > > > > > > -- >> > > > > > > > > > > You received this message because you are subscribed >> to the >> > > Google >> > > > > > > > > > Groups "Puppet Users" group. >> > > > > > > > > > > To post to this group, send email to >> > > puppet-users@googlegroups.com (mailto:puppet-users@googlegroups.com) >> > > > > > > (mailto: >> > > > > > > > > > puppet-users@googlegroups.com (mailto: >> > > puppet-users@googlegroups.com)). >> > > > > > > > > > > To unsubscribe from this group, send email to >> > > > > > > > > > puppet-users+unsubscr...@googlegroups.com (mailto: >> > > puppet-users%2bunsubscr...@googlegroups.com) (mailto: >> > > > > > > > > > puppet-users+unsubscr...@googlegroups.com (mailto: >> > > puppet-users%2bunsubscr...@googlegroups.com)). >> > > > > > > > > > > For more options, visit this group at >> > > > > > > > > >http://groups.google.com/group/puppet-users?hl=en. >> > >> > > > > > > > > > -- >> > > > > > > > > > You received this message because you are subscribed to >> the >> > > Google >> > > > > > > Groups >> > > > > > > > > > "Puppet Users" group. >> > > > > > > > > > To post to this group, send email to >> > > puppet-users@googlegroups.com (mailto:puppet-users@googlegroups.com). >> > > > > > > > > > To unsubscribe from this group, send email to >> > > > > > > > > > puppet-users+unsubscr...@googlegroups.com (mailto: >> > > puppet-users%2bunsubscr...@googlegroups.com). >> > > > > > > > > > For more options, visit this group at >> > > > > > > > > >http://groups.google.com/group/puppet-users?hl=en. >> > >> > > > > > > -- >> > > > > > > You received this message because you are subscribed to the >> Google >> > > Groups >> > > > > > > "Puppet Users" group. >> > > > > > > To post to this group, send email to >> puppet-users@googlegroups.com(mailto: >> > > puppet-users@googlegroups.com). >> > > > > > > To unsubscribe from this group, send email to >> > > > > > > puppet-users+unsubscr...@googlegroups.com (mailto: >> > > puppet-users%2bunsubscr...@googlegroups.com). >> > > > > > > For more options, visit this group at >> > > > > > >http://groups.google.com/group/puppet-users?hl=en. >> > >> > > > > -- >> > > > > You received this message because you are subscribed to the Google >> > > Groups "Puppet Users" group. >> > > > > To post to this group, send email to >> puppet-users@googlegroups.com(mailto: >> > > puppet-users@googlegroups.com). >> > > > > To unsubscribe from this group, send email to >> > > puppet-users+unsubscr...@googlegroups.com (mailto: >> > > puppet-users%2bunsubscr...@googlegroups.com). >> > > > > For more options, visit this group at >> > >http://groups.google.com/group/puppet-users?hl=en. >> > >> > > > -- >> > > > You received this message because you are subscribed to the Google >> > > Groups "Puppet Users" group. >> > > > To post to this group, send email to puppet-users@googlegroups.com >> (mailto: >> > > puppet-users@googlegroups.com). >> > > > To unsubscribe from this group, send email to >> > > puppet-users+unsubscr...@googlegroups.com (mailto: >> > > puppet-users+unsubscr...@googlegroups.com). >> > > > For more options, visit this group at >> > >http://groups.google.com/group/puppet-users?hl=en. >> > >> > > -- >> > > You received this message because you are subscribed to the Google >> Groups >> > > "Puppet Users" group. >> > > To post to this group, send email to puppet-users@googlegroups.com. >> > > To unsubscribe from this group, send email to >> > > puppet-users+unsubscr...@googlegroups.com. >> > > For more options, visit this group at >> > >http://groups.google.com/group/puppet-users?hl=en. >> > >> > >> >> -- >> You received this message because you are subscribed to the Google Groups >> "Puppet Users" group. >> To post to this group, send email to puppet-users@googlegroups.com. >> To unsubscribe from this group, send email to >> puppet-users+unsubscr...@googlegroups.com. >> For more options, visit this group at >> http://groups.google.com/group/puppet-users?hl=en. >> >> > -- You received this message because you are subscribed to the Google Groups "Puppet Users" group. To post to this group, send email to puppet-users@googlegroups.com. To unsubscribe from this group, send email to puppet-users+unsubscr...@googlegroups.com. For more options, visit this group at http://groups.google.com/group/puppet-users?hl=en.