Here is site.pp ==============================
file {"/tmp/QoS/QoS.sh": ensure =>present, owner=>'root', group=>'root', mode=>'777', source=>'puppet://puppet/files/QoS.sh', } exec {"/tmp/QoS/QoS.sh": require=>File['/tmp/QoS/QoS.sh'], } ================================ Here is the QoS.sh Script: ================================ #!/bin/bash #create alias for interfaces to avoid confusion export LAN=eth1 export WAN=eth0 #----------------------------------------------------------------------QoS Settings----------------------------------------------------------# #Rules for engress queue #----------------------------------start-------------------------- #create priority queue tc qdisc add dev ${WAN} root handle 1: htb default 13 tc class add dev ${WAN} parent 1: classid 1:1 htb rate 50kbps ceil 50kbps # voip class tc class add dev ${WAN} parent 1:1 classid 1:10 htb rate 30kbps ceil 50kbps prio 1 #stream class tc class add dev ${WAN} parent 1:1 classid 1:11 htb rate 30kbps ceil 30kbps prio 2 #http, https, ssh, telnet class tc class add dev ${WAN} parent 1:1 classid 1:12 htb rate 20kbps ceil 30kbps prio 3 #ftp class tc class add dev ${WAN} parent 1:1 classid 1:13 htb rate 20kbps ceil 20kbps prio 4 #attach sfq on every class tc qdisc add dev ${WAN} parent 1:10 handle 20: sfq perturb 10 tc qdisc add dev ${WAN} parent 1:11 handle 30: sfq perturb 10 tc qdisc add dev ${WAN} parent 1:12 handle 40: sfq perturb 10 tc qdisc add dev ${WAN} parent 1:13 handle 60: sfq perturb 10 #define class filters tc filter add dev ${WAN} parent 1:0 prio 1 protocol ip u32 match ip tos 0x28 0xff classid 1:10 tc filter add dev ${WAN} parent 1:0 prio 2 protocol ip u32 match ip tos 0x48 0xff classid 1:11 tc filter add dev ${WAN} parent 1:0 prio 3 protocol ip u32 match ip tos 0x68 0xff classid 1:12 tc filter add dev ${WAN} parent 1:0 prio 4 protocol ip u32 match ip tos 0x88 0xff classid 1:12 #-------------------------------------end---------------------------------------- iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p udp --sport 2345 -j TOS --set-tos 0x28 iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p udp --sport 2345 -j RETURN iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p udp --dport 2345 -j TOS --set-tos 0x28 iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p udp --dport 2345 -j RETURN iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p tcp --sport telnet -j TOS --set-tos 0x28 iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p tcp --sport telnet -j RETURN iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p tcp --dport telnet -j TOS --set-tos 0x28 iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p tcp --dport telnet -j RETURN iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p tcp --sport ssh -j TOS --set-tos 0x28 iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p tcp --sport ssh -j RETURN iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p tcp --dport ssh -j TOS --set-tos 0x28 iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p tcp --dport ssh -j RETURN iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p tcp -m tcp --tcp-flags SYN,RST,ACK SYN -j TOS --set-tos 0x28 iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p tcp -m tcp --tcp-flags SYN,RST,ACK SYN -j RETURN iptables -t mangle -I FORWARD -i ${LAN} -o ${WAN} -p udp --sport sip -j TOS --set-tos 0x48 iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p udp --sport sip -j RETURN iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p udp --dport sip -j TOS --set-tos 0x48 iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p udp --dport sip -j RETURN iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p udp --sport 5060 -j TOS --set-tos 0x48 iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p udp --sport 5060 -j RETURN iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p udp --dport 5060 -j TOS --set-tos 0x48 iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p udp --dport 5060 -j RETURN iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p udp --sport 4569 -j TOS --set-tos 0x48 iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p udp --sport 4569 -j RETURN iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p udp --dport 4569 -j TOS --set-tos 0x48 iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p udp --dport 4569 -j RETURN iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p udp --sport 5036 -j TOS --set-tos 0x48 iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p udp --sport 5036 -j RETURN iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p udp --dport 5036 -j TOS --set-tos 0x48 iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p udp --dport 5036 -j RETURN iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p udp --sport 10000:20000 -j TOS --set-tos 0x48 iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p udp --sport 10000:20000 -j RETURN iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p udp --dport 10000:20000 -j TOS --set-tos 0x48 iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p udp --dport 10000:20000 -j RETURN iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p udp --sport 2727 -j TOS --set-tos 0x48 iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p udp --sport 2727 -j RETURN iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p udp --dport 2727 -j TOS --set-tos 0x48 iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p udp --dport 2727 -j RETURN iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p tcp --sport http -j TOS --set-tos 0x68 iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p tcp --sport http -j RETURN iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p tcp --dport http -j TOS --set-tos 0x68 iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p tcp --dport http -j RETURN iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p tcp --sport https -j TOS --set-tos 0x68 iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p tcp --sport https -j RETURN iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p tcp --dport https -j TOS --set-tos 0x68 iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p tcp --dport https -j RETURN iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p tcp --sport ftp -j TOS --set-tos 0x88 iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p tcp --sport ftp -j RETURN iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p tcp --dport ftp -j TOS --set-tos 0x88 iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p tcp --dport ftp -j RETURN iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p tcp --dport ftp-data -j TOS --set-tos 0x88 iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p tcp --dport ftp-data -j RETURN iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p tcp --sport ftp-data -j TOS --set-tos 0x88 iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -p tcp --sport ftp-data -j RETURN iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -j TOS --set-tos 0x88 iptables -t mangle -A FORWARD -i ${LAN} -o ${WAN} -j RETURN #save iptables rules iptables-save ================================================================ On Fri, Jun 17, 2011 at 3:44 PM, Annie Rana <annier...@gmail.com> 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> 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> 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> >> 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> wrote: >> > > > I apologize for posting wrong log messages, here is the correct log: >> > >> > > > notice: Starting catalog run >> > > > notice: //File[/tmp/QoS/QoS.sh]/ensure: created >> > > > err: //Exec[/tmp/QoS/QoS.sh]/returns: change from notrun to 0 >> failed: >> > > > /tmp/QoS/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> >> 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]/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]: Dependency file[/tmp/QoS/QoS.sh] >> has 1 >> > > > > failures >> > > > > warning: //Exec[/tmp/QoS/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; 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 >> > > >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). >> > > > >> > 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. >> >> > -- 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.