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.

Reply via email to