nirvdrum-rubber 1.1.7 → 2.0.0.rails3.beta6

Sign up to get free protection for your applications and to get access to all the features.
Files changed (291) hide show
  1. data/CHANGELOG +82 -0
  2. data/VERSION +1 -1
  3. data/bin/vulcanize +10 -33
  4. data/generators/vulcanize/templates/apache/config/rubber/deploy-apache.rb +6 -6
  5. data/generators/vulcanize/templates/apache/config/rubber/role/apache/monit-apache.conf +2 -2
  6. data/generators/vulcanize/templates/apache/config/rubber/role/apache/ports.conf +3 -0
  7. data/generators/vulcanize/templates/apache/config/rubber/role/web_tools/tools-apache-vhost.conf +29 -16
  8. data/generators/vulcanize/templates/apache/config/rubber/role/web_tools/tools-index.html +1 -1
  9. data/generators/vulcanize/templates/base/Rakefile +19 -0
  10. data/generators/vulcanize/templates/base/config/rubber/common/crontab +6 -1
  11. data/generators/vulcanize/templates/base/config/rubber/common/monit-postfix.conf +2 -2
  12. data/generators/vulcanize/templates/base/config/rubber/common/rubber.profile +3 -4
  13. data/generators/vulcanize/templates/base/config/rubber/deploy-setup.rb +28 -49
  14. data/generators/vulcanize/templates/base/config/rubber/deploy-util.rb +97 -0
  15. data/generators/vulcanize/templates/base/config/rubber/rubber-dns.yml +0 -1
  16. data/generators/vulcanize/templates/base/config/rubber/rubber-rvm.yml +25 -0
  17. data/generators/vulcanize/templates/base/config/rubber/rubber.yml +21 -13
  18. data/generators/vulcanize/templates/base/script/cron-runner +1 -1
  19. data/generators/vulcanize/templates/base/templates.rb +1 -0
  20. data/generators/vulcanize/templates/base/templates.yml +5 -0
  21. data/generators/vulcanize/templates/cassandra/config/rubber/deploy-cassandra.rb +88 -0
  22. data/generators/vulcanize/templates/cassandra/config/rubber/role/cassandra/cassandra.in.sh +58 -0
  23. data/generators/vulcanize/templates/cassandra/config/rubber/role/cassandra/cassandra.yaml +210 -0
  24. data/generators/vulcanize/templates/cassandra/config/rubber/role/cassandra/log4j-server.properties +45 -0
  25. data/generators/vulcanize/templates/cassandra/config/rubber/role/cassandra/monit-cassandra.conf +8 -0
  26. data/generators/vulcanize/templates/cassandra/config/rubber/rubber-cassandra.yml +18 -0
  27. data/generators/vulcanize/templates/cassandra/templates.yml +1 -0
  28. data/generators/vulcanize/templates/complete_mongrel_mysql/config/rubber/role/haproxy/haproxy-mongrel.conf +2 -2
  29. data/generators/vulcanize/templates/{complete_passenger_mysql → complete_passenger}/config/rubber/role/haproxy/haproxy-passenger.conf +2 -2
  30. data/generators/vulcanize/templates/complete_passenger/templates.rb +9 -0
  31. data/generators/vulcanize/templates/complete_passenger/templates.yml +9 -0
  32. data/generators/vulcanize/templates/complete_passenger_mysql/templates.yml +1 -7
  33. data/generators/vulcanize/templates/complete_passenger_postgresql/templates.yml +4 -0
  34. data/generators/vulcanize/templates/cruise/config/rubber/deploy-cruise.rb +3 -3
  35. data/generators/vulcanize/templates/cruise/config/rubber/role/cruise/my.cnf +1 -1
  36. data/generators/vulcanize/templates/haproxy/config/rubber/deploy-haproxy.rb +5 -5
  37. data/generators/vulcanize/templates/haproxy/config/rubber/role/haproxy/monit-haproxy.conf +2 -2
  38. data/generators/vulcanize/templates/haproxy/config/rubber/role/haproxy/syslog-haproxy.conf +8 -3
  39. data/generators/vulcanize/templates/haproxy/config/rubber/role/haproxy/syslogd-default.conf +4 -0
  40. data/generators/vulcanize/templates/jetty/config/rubber/deploy-jetty.rb +5 -5
  41. data/generators/vulcanize/templates/memcached/config/rubber/role/memcached/memcached.conf +1 -1
  42. data/generators/vulcanize/templates/mongrel/config/rubber/deploy-mongrel.rb +4 -4
  43. data/generators/vulcanize/templates/monit/config/rubber/common/monit.conf +2 -1
  44. data/generators/vulcanize/templates/monit/config/rubber/deploy-monit.rb +5 -4
  45. data/generators/vulcanize/templates/munin/config/rubber/common/monit-munin.conf +2 -2
  46. data/generators/vulcanize/templates/munin/config/rubber/common/munin-node.conf +1 -1
  47. data/generators/vulcanize/templates/munin/config/rubber/common/munin-plugins.conf +4 -2
  48. data/generators/vulcanize/templates/munin/config/rubber/deploy-munin.rb +5 -5
  49. data/generators/vulcanize/templates/munin/config/rubber/role/web_tools/munin-plugins.conf +1 -1
  50. data/generators/vulcanize/templates/munin/config/rubber/role/web_tools/munin.conf +1 -0
  51. data/generators/vulcanize/templates/munin/config/rubber/rubber-munin.yml +1 -1
  52. data/generators/vulcanize/templates/munin/script/munin/example_mysql_query.rb +6 -8
  53. data/generators/vulcanize/templates/mysql/config/rubber/common/database.yml +1 -0
  54. data/generators/vulcanize/templates/mysql/config/rubber/deploy-mysql.rb +40 -27
  55. data/generators/vulcanize/templates/mysql/config/rubber/role/db/apparmor-mysql.conf +46 -0
  56. data/generators/vulcanize/templates/mysql/config/rubber/role/db/monit-mysql.cnf +2 -2
  57. data/generators/vulcanize/templates/mysql/config/rubber/role/db/my.cnf +2 -6
  58. data/generators/vulcanize/templates/mysql/config/rubber/rubber-mysql.yml +2 -1
  59. data/generators/vulcanize/templates/mysql_cluster/config/rubber/deploy-mysql_cluster.rb +19 -15
  60. data/generators/vulcanize/templates/mysql_cluster/config/rubber/role/mysql_sql/monit-mysql_cluster_sql.cnf +2 -2
  61. data/generators/vulcanize/templates/mysql_proxy/config/rubber/common/monit-mysql_proxy.cnf +2 -2
  62. data/generators/vulcanize/templates/mysql_proxy/config/rubber/deploy-mysql_proxy.rb +3 -3
  63. data/generators/vulcanize/templates/nginx/config/rubber/deploy-nginx.rb +5 -5
  64. data/generators/vulcanize/templates/nginx/config/rubber/role/nginx/monit-nginx.conf +2 -2
  65. data/generators/vulcanize/templates/passenger/config/rubber/deploy-passenger.rb +10 -1
  66. data/generators/vulcanize/templates/passenger/config/rubber/role/passenger/munin-passenger-memory.conf +1 -1
  67. data/generators/vulcanize/templates/passenger/config/rubber/role/passenger/munin-passenger-sudoers.conf +2 -2
  68. data/generators/vulcanize/templates/passenger/config/rubber/role/passenger/munin-passenger.conf +1 -1
  69. data/generators/vulcanize/templates/passenger/config/rubber/role/passenger/passenger.conf +28 -3
  70. data/generators/vulcanize/templates/passenger/config/rubber/rubber-passenger.yml +3 -3
  71. data/generators/vulcanize/templates/postgresql/config/rubber/common/database.yml +12 -0
  72. data/generators/vulcanize/templates/postgresql/config/rubber/deploy-postgresql.rb +131 -0
  73. data/generators/vulcanize/templates/postgresql/config/rubber/role/db/crontab +14 -0
  74. data/generators/vulcanize/templates/postgresql/config/rubber/role/db/monit-postgresql.conf +10 -0
  75. data/generators/vulcanize/templates/postgresql/config/rubber/role/db/pg_hba.conf +89 -0
  76. data/generators/vulcanize/templates/postgresql/config/rubber/role/db/postgresql-sysctl.conf +6 -0
  77. data/generators/vulcanize/templates/postgresql/config/rubber/role/db/postgresql.conf +504 -0
  78. data/generators/vulcanize/templates/postgresql/config/rubber/rubber-postgresql.yml +45 -0
  79. data/generators/vulcanize/templates/postgresql/templates.yml +1 -0
  80. data/generators/vulcanize/templates/redis/config/rubber/deploy-redis.rb +8 -7
  81. data/generators/vulcanize/templates/resque/config/initializers/resque.rb +15 -0
  82. data/generators/vulcanize/templates/resque/config/rubber/common/resque.yml +5 -0
  83. data/generators/vulcanize/templates/resque/config/rubber/deploy-resque.rb +46 -27
  84. data/generators/vulcanize/templates/resque/config/rubber/role/resque_web/monit-resque_web.conf +14 -0
  85. data/generators/vulcanize/templates/resque/config/rubber/role/resque_worker/monit-resque_worker.conf +19 -0
  86. data/generators/vulcanize/templates/resque/config/rubber/rubber-resque.yml +14 -6
  87. data/generators/vulcanize/templates/resque/script/resque_worker_management.rb +112 -0
  88. data/generators/vulcanize/templates/resque/templates.rb +1 -0
  89. data/generators/vulcanize/templates/sphinx/config/rubber/deploy-sphinx.rb +8 -8
  90. data/generators/vulcanize/templates/sphinx/config/rubber/role/sphinx/monit-sphinx.conf +7 -4
  91. data/generators/vulcanize/vulcanize_generator.rb +139 -49
  92. data/lib/generators/vulcanize/USAGE +6 -0
  93. data/lib/generators/vulcanize/templates/apache/config/rubber/deploy-apache.rb +51 -0
  94. data/lib/generators/vulcanize/templates/apache/config/rubber/role/apache/deflate.conf +10 -0
  95. data/lib/generators/vulcanize/templates/apache/config/rubber/role/apache/expires.conf +9 -0
  96. data/lib/generators/vulcanize/templates/apache/config/rubber/role/apache/headers.conf +6 -0
  97. data/lib/generators/vulcanize/templates/apache/config/rubber/role/apache/monit-apache.conf +8 -0
  98. data/lib/generators/vulcanize/templates/apache/config/rubber/role/apache/ports.conf +8 -0
  99. data/lib/generators/vulcanize/templates/apache/config/rubber/role/apache/setenvif.conf +52 -0
  100. data/lib/generators/vulcanize/templates/apache/config/rubber/role/web_tools/tools-apache-vhost.conf +79 -0
  101. data/lib/generators/vulcanize/templates/apache/config/rubber/role/web_tools/tools-apache.auth +7 -0
  102. data/lib/generators/vulcanize/templates/apache/config/rubber/role/web_tools/tools-index.html +34 -0
  103. data/lib/generators/vulcanize/templates/apache/config/rubber/rubber-apache.yml +6 -0
  104. data/lib/generators/vulcanize/templates/apache/templates.yml +1 -0
  105. data/lib/generators/vulcanize/templates/base/Capfile +14 -0
  106. data/lib/generators/vulcanize/templates/base/Rakefile +19 -0
  107. data/lib/generators/vulcanize/templates/base/config/deploy.rb +55 -0
  108. data/lib/generators/vulcanize/templates/base/config/rubber/common/crontab +22 -0
  109. data/lib/generators/vulcanize/templates/base/config/rubber/common/monit-postfix.conf +8 -0
  110. data/lib/generators/vulcanize/templates/base/config/rubber/common/rubber.profile +13 -0
  111. data/lib/generators/vulcanize/templates/base/config/rubber/deploy-setup.rb +63 -0
  112. data/lib/generators/vulcanize/templates/base/config/rubber/deploy-util.rb +97 -0
  113. data/lib/generators/vulcanize/templates/base/config/rubber/rubber-dns.yml +78 -0
  114. data/lib/generators/vulcanize/templates/base/config/rubber/rubber-rvm.yml +25 -0
  115. data/lib/generators/vulcanize/templates/base/config/rubber/rubber.yml +235 -0
  116. data/lib/generators/vulcanize/templates/base/lib/tasks/rubber.rake +15 -0
  117. data/lib/generators/vulcanize/templates/base/script/cron-rake +18 -0
  118. data/lib/generators/vulcanize/templates/base/script/cron-runner +18 -0
  119. data/lib/generators/vulcanize/templates/base/script/cron-sh +67 -0
  120. data/lib/generators/vulcanize/templates/base/templates.rb +1 -0
  121. data/lib/generators/vulcanize/templates/base/templates.yml +6 -0
  122. data/lib/generators/vulcanize/templates/cassandra/config/rubber/deploy-cassandra.rb +88 -0
  123. data/lib/generators/vulcanize/templates/cassandra/config/rubber/role/cassandra/cassandra.in.sh +58 -0
  124. data/lib/generators/vulcanize/templates/cassandra/config/rubber/role/cassandra/cassandra.yaml +210 -0
  125. data/lib/generators/vulcanize/templates/cassandra/config/rubber/role/cassandra/log4j-server.properties +45 -0
  126. data/lib/generators/vulcanize/templates/cassandra/config/rubber/role/cassandra/monit-cassandra.conf +8 -0
  127. data/lib/generators/vulcanize/templates/cassandra/config/rubber/rubber-cassandra.yml +18 -0
  128. data/lib/generators/vulcanize/templates/cassandra/templates.yml +1 -0
  129. data/lib/generators/vulcanize/templates/complete_mongrel_mysql/config/rubber/role/haproxy/haproxy-mongrel.conf +23 -0
  130. data/lib/generators/vulcanize/templates/complete_mongrel_mysql/config/rubber/role/nginx/nginx-mongrel.conf +113 -0
  131. data/lib/generators/vulcanize/templates/complete_mongrel_mysql/config/rubber/rubber-complete.yml +41 -0
  132. data/lib/generators/vulcanize/templates/complete_mongrel_mysql/templates.yml +6 -0
  133. data/lib/generators/vulcanize/templates/complete_passenger/config/rubber/role/haproxy/haproxy-passenger.conf +21 -0
  134. data/lib/generators/vulcanize/templates/complete_passenger/config/rubber/rubber-complete.yml +40 -0
  135. data/lib/generators/vulcanize/templates/complete_passenger/templates.rb +9 -0
  136. data/lib/generators/vulcanize/templates/complete_passenger/templates.yml +9 -0
  137. data/lib/generators/vulcanize/templates/complete_passenger_mysql/templates.yml +4 -0
  138. data/lib/generators/vulcanize/templates/complete_passenger_postgresql/templates.yml +4 -0
  139. data/lib/generators/vulcanize/templates/cruise/config/rubber/deploy-cruise.rb +72 -0
  140. data/lib/generators/vulcanize/templates/cruise/config/rubber/role/cruise/cruise +40 -0
  141. data/lib/generators/vulcanize/templates/cruise/config/rubber/role/cruise/my.cnf +165 -0
  142. data/lib/generators/vulcanize/templates/cruise/config/rubber/role/cruise/production.rb +8 -0
  143. data/lib/generators/vulcanize/templates/cruise/config/rubber/role/cruise/site_config.rb +76 -0
  144. data/lib/generators/vulcanize/templates/cruise/config/rubber/role/web_tools/cruise-nginx.conf +11 -0
  145. data/lib/generators/vulcanize/templates/cruise/config/rubber/rubber-cruise.yml +18 -0
  146. data/lib/generators/vulcanize/templates/cruise/templates.yml +1 -0
  147. data/lib/generators/vulcanize/templates/haproxy/config/rubber/deploy-haproxy.rb +45 -0
  148. data/lib/generators/vulcanize/templates/haproxy/config/rubber/role/haproxy/haproxy-base.conf +26 -0
  149. data/lib/generators/vulcanize/templates/haproxy/config/rubber/role/haproxy/haproxy-default.conf +8 -0
  150. data/lib/generators/vulcanize/templates/haproxy/config/rubber/role/haproxy/monit-haproxy.conf +9 -0
  151. data/lib/generators/vulcanize/templates/haproxy/config/rubber/role/haproxy/syslog-haproxy.conf +11 -0
  152. data/lib/generators/vulcanize/templates/haproxy/config/rubber/role/haproxy/syslogd-default.conf +21 -0
  153. data/lib/generators/vulcanize/templates/haproxy/config/rubber/role/web_tools/haproxy-nginx.conf +10 -0
  154. data/lib/generators/vulcanize/templates/haproxy/config/rubber/rubber-haproxy.yml +7 -0
  155. data/lib/generators/vulcanize/templates/haproxy/templates.yml +1 -0
  156. data/lib/generators/vulcanize/templates/jetty/config/rubber/deploy-jetty.rb +59 -0
  157. data/lib/generators/vulcanize/templates/jetty/config/rubber/role/jetty/jetty.sh +589 -0
  158. data/lib/generators/vulcanize/templates/jetty/config/rubber/role/jetty/jetty.xml +199 -0
  159. data/lib/generators/vulcanize/templates/jetty/config/rubber/role/jetty/monit-jetty.conf +9 -0
  160. data/lib/generators/vulcanize/templates/jetty/config/rubber/rubber-jetty.yml +10 -0
  161. data/lib/generators/vulcanize/templates/jetty/templates.yml +1 -0
  162. data/lib/generators/vulcanize/templates/memcached/config/memcached.yml +28 -0
  163. data/lib/generators/vulcanize/templates/memcached/config/rubber/common/memcached.yml +14 -0
  164. data/lib/generators/vulcanize/templates/memcached/config/rubber/role/memcached/memcached.conf +52 -0
  165. data/lib/generators/vulcanize/templates/memcached/config/rubber/role/memcached/memcached_munin_plugin +249 -0
  166. data/lib/generators/vulcanize/templates/memcached/config/rubber/rubber-memcached.yml +7 -0
  167. data/lib/generators/vulcanize/templates/memcached/templates.yml +1 -0
  168. data/lib/generators/vulcanize/templates/minimal_mysql/templates.yml +7 -0
  169. data/lib/generators/vulcanize/templates/minimal_nodb/templates.yml +6 -0
  170. data/lib/generators/vulcanize/templates/mongrel/config/rubber/deploy-mongrel.rb +75 -0
  171. data/lib/generators/vulcanize/templates/mongrel/config/rubber/role/mongrel/mongrel_cluster.yml +12 -0
  172. data/lib/generators/vulcanize/templates/mongrel/config/rubber/role/mongrel/monit-mongrel.conf +20 -0
  173. data/lib/generators/vulcanize/templates/mongrel/config/rubber/rubber-mongrel.yml +9 -0
  174. data/lib/generators/vulcanize/templates/mongrel/templates.yml +1 -0
  175. data/lib/generators/vulcanize/templates/monit/config/rubber/common/monit-default.conf +15 -0
  176. data/lib/generators/vulcanize/templates/monit/config/rubber/common/monit.conf +252 -0
  177. data/lib/generators/vulcanize/templates/monit/config/rubber/deploy-monit.rb +33 -0
  178. data/lib/generators/vulcanize/templates/monit/config/rubber/role/web_tools/monit-admin-nginx.conf +10 -0
  179. data/lib/generators/vulcanize/templates/monit/config/rubber/rubber-monit.yml +6 -0
  180. data/lib/generators/vulcanize/templates/monit/templates.yml +1 -0
  181. data/lib/generators/vulcanize/templates/munin/config/rubber/common/monit-munin.conf +8 -0
  182. data/lib/generators/vulcanize/templates/munin/config/rubber/common/munin-node.conf +48 -0
  183. data/lib/generators/vulcanize/templates/munin/config/rubber/common/munin-plugins.conf +11 -0
  184. data/lib/generators/vulcanize/templates/munin/config/rubber/deploy-munin.rb +46 -0
  185. data/lib/generators/vulcanize/templates/munin/config/rubber/role/web_tools/munin-nginx.conf +8 -0
  186. data/lib/generators/vulcanize/templates/munin/config/rubber/role/web_tools/munin-plugins.conf +31 -0
  187. data/lib/generators/vulcanize/templates/munin/config/rubber/role/web_tools/munin.conf +81 -0
  188. data/lib/generators/vulcanize/templates/munin/config/rubber/rubber-munin.yml +8 -0
  189. data/lib/generators/vulcanize/templates/munin/script/munin/example_mysql_query.rb +55 -0
  190. data/lib/generators/vulcanize/templates/munin/script/munin/example_simple.rb +24 -0
  191. data/lib/generators/vulcanize/templates/munin/templates.yml +1 -0
  192. data/lib/generators/vulcanize/templates/mysql/config/rubber/common/database.yml +12 -0
  193. data/lib/generators/vulcanize/templates/mysql/config/rubber/deploy-mysql.rb +169 -0
  194. data/lib/generators/vulcanize/templates/mysql/config/rubber/role/db/apparmor-mysql.conf +46 -0
  195. data/lib/generators/vulcanize/templates/mysql/config/rubber/role/db/crontab +14 -0
  196. data/lib/generators/vulcanize/templates/mysql/config/rubber/role/db/monit-mysql.cnf +10 -0
  197. data/lib/generators/vulcanize/templates/mysql/config/rubber/role/db/my.cnf +163 -0
  198. data/lib/generators/vulcanize/templates/mysql/config/rubber/role/mysql_slave/mysql_slave_munin_plugin +51 -0
  199. data/lib/generators/vulcanize/templates/mysql/config/rubber/rubber-mysql.yml +47 -0
  200. data/lib/generators/vulcanize/templates/mysql/templates.yml +1 -0
  201. data/lib/generators/vulcanize/templates/mysql_cluster/config/rubber/common/mysql_cluster_migrations.rb +13 -0
  202. data/lib/generators/vulcanize/templates/mysql_cluster/config/rubber/deploy-mysql_cluster.rb +177 -0
  203. data/lib/generators/vulcanize/templates/mysql_cluster/config/rubber/role/mysql_data/my.cnf +15 -0
  204. data/lib/generators/vulcanize/templates/mysql_cluster/config/rubber/role/mysql_mgm/ndb_mgmd.cnf +39 -0
  205. data/lib/generators/vulcanize/templates/mysql_cluster/config/rubber/role/mysql_sql/monit-mysql_cluster_sql.cnf +10 -0
  206. data/lib/generators/vulcanize/templates/mysql_cluster/config/rubber/role/mysql_sql/my.cnf +23 -0
  207. data/lib/generators/vulcanize/templates/mysql_cluster/config/rubber/rubber-mysql_cluster.yml +32 -0
  208. data/lib/generators/vulcanize/templates/mysql_cluster/templates.yml +1 -0
  209. data/lib/generators/vulcanize/templates/mysql_proxy/config/rubber/common/database.yml +16 -0
  210. data/lib/generators/vulcanize/templates/mysql_proxy/config/rubber/common/monit-mysql_proxy.cnf +10 -0
  211. data/lib/generators/vulcanize/templates/mysql_proxy/config/rubber/common/mysql-proxy +153 -0
  212. data/lib/generators/vulcanize/templates/mysql_proxy/config/rubber/common/mysql-proxy.conf +10 -0
  213. data/lib/generators/vulcanize/templates/mysql_proxy/config/rubber/common/mysql-proxy.lua +5 -0
  214. data/lib/generators/vulcanize/templates/mysql_proxy/config/rubber/deploy-mysql_proxy.rb +52 -0
  215. data/lib/generators/vulcanize/templates/mysql_proxy/config/rubber/rubber-mysql_proxy.yml +11 -0
  216. data/lib/generators/vulcanize/templates/mysql_proxy/templates.yml +1 -0
  217. data/lib/generators/vulcanize/templates/nginx/config/rubber/deploy-nginx.rb +45 -0
  218. data/lib/generators/vulcanize/templates/nginx/config/rubber/role/nginx/crontab +9 -0
  219. data/lib/generators/vulcanize/templates/nginx/config/rubber/role/nginx/monit-nginx.conf +8 -0
  220. data/lib/generators/vulcanize/templates/nginx/config/rubber/role/nginx/nginx.conf +42 -0
  221. data/lib/generators/vulcanize/templates/nginx/config/rubber/role/web_tools/nginx-tools.conf +55 -0
  222. data/lib/generators/vulcanize/templates/nginx/config/rubber/role/web_tools/tools-index.html +30 -0
  223. data/lib/generators/vulcanize/templates/nginx/config/rubber/role/web_tools/tools-nginx.auth +7 -0
  224. data/lib/generators/vulcanize/templates/nginx/config/rubber/rubber-nginx.yml +10 -0
  225. data/lib/generators/vulcanize/templates/nginx/templates.yml +1 -0
  226. data/lib/generators/vulcanize/templates/passenger/config/rubber/deploy-passenger.rb +46 -0
  227. data/lib/generators/vulcanize/templates/passenger/config/rubber/role/passenger/munin-passenger-memory.conf +34 -0
  228. data/lib/generators/vulcanize/templates/passenger/config/rubber/role/passenger/munin-passenger-sudoers.conf +7 -0
  229. data/lib/generators/vulcanize/templates/passenger/config/rubber/role/passenger/munin-passenger.conf +47 -0
  230. data/lib/generators/vulcanize/templates/passenger/config/rubber/role/passenger/passenger-apache-vhost.conf +46 -0
  231. data/lib/generators/vulcanize/templates/passenger/config/rubber/role/passenger/passenger.conf +35 -0
  232. data/lib/generators/vulcanize/templates/passenger/config/rubber/rubber-passenger.yml +15 -0
  233. data/lib/generators/vulcanize/templates/passenger/templates.yml +3 -0
  234. data/lib/generators/vulcanize/templates/postgresql/config/rubber/common/database.yml +12 -0
  235. data/lib/generators/vulcanize/templates/postgresql/config/rubber/deploy-postgresql.rb +131 -0
  236. data/lib/generators/vulcanize/templates/postgresql/config/rubber/role/db/crontab +14 -0
  237. data/lib/generators/vulcanize/templates/postgresql/config/rubber/role/db/monit-postgresql.conf +10 -0
  238. data/lib/generators/vulcanize/templates/postgresql/config/rubber/role/db/pg_hba.conf +89 -0
  239. data/lib/generators/vulcanize/templates/postgresql/config/rubber/role/db/postgresql-sysctl.conf +6 -0
  240. data/lib/generators/vulcanize/templates/postgresql/config/rubber/role/db/postgresql.conf +504 -0
  241. data/lib/generators/vulcanize/templates/postgresql/config/rubber/rubber-postgresql.yml +45 -0
  242. data/lib/generators/vulcanize/templates/postgresql/templates.yml +1 -0
  243. data/lib/generators/vulcanize/templates/redis/config/rubber/deploy-redis.rb +37 -0
  244. data/lib/generators/vulcanize/templates/redis/config/rubber/role/redis/crontab +8 -0
  245. data/lib/generators/vulcanize/templates/redis/config/rubber/role/redis/monit-redis.conf +9 -0
  246. data/lib/generators/vulcanize/templates/redis/config/rubber/role/redis/redis.conf +141 -0
  247. data/lib/generators/vulcanize/templates/redis/config/rubber/rubber-redis.yml +4 -0
  248. data/lib/generators/vulcanize/templates/redis/templates.yml +1 -0
  249. data/lib/generators/vulcanize/templates/resque/config/initializers/resque.rb +15 -0
  250. data/lib/generators/vulcanize/templates/resque/config/rubber/common/resque.yml +5 -0
  251. data/lib/generators/vulcanize/templates/resque/config/rubber/deploy-resque.rb +58 -0
  252. data/lib/generators/vulcanize/templates/resque/config/rubber/role/resque_web/monit-resque_web.conf +14 -0
  253. data/lib/generators/vulcanize/templates/resque/config/rubber/role/resque_worker/monit-resque_worker.conf +19 -0
  254. data/lib/generators/vulcanize/templates/resque/config/rubber/rubber-resque.yml +18 -0
  255. data/lib/generators/vulcanize/templates/resque/script/resque_worker_management.rb +112 -0
  256. data/lib/generators/vulcanize/templates/resque/templates.rb +1 -0
  257. data/lib/generators/vulcanize/templates/resque/templates.yml +3 -0
  258. data/lib/generators/vulcanize/templates/sphinx/config/rubber/common/sphinx.yml +46 -0
  259. data/lib/generators/vulcanize/templates/sphinx/config/rubber/deploy-sphinx.rb +112 -0
  260. data/lib/generators/vulcanize/templates/sphinx/config/rubber/role/sphinx/crontab +11 -0
  261. data/lib/generators/vulcanize/templates/sphinx/config/rubber/role/sphinx/monit-sphinx.conf +13 -0
  262. data/lib/generators/vulcanize/templates/sphinx/config/rubber/rubber-sphinx.yml +6 -0
  263. data/lib/generators/vulcanize/templates/sphinx/templates.yml +1 -0
  264. data/lib/generators/vulcanize/vulcanize_generator.rb +157 -0
  265. data/lib/rubber/cloud/aws.rb +7 -2
  266. data/lib/rubber/dns/zerigo.rb +60 -125
  267. data/lib/rubber/environment.rb +6 -6
  268. data/lib/rubber/generator.rb +33 -25
  269. data/lib/rubber/instance.rb +11 -1
  270. data/lib/rubber/railtie.rb +14 -0
  271. data/lib/rubber/recipes/rubber/deploy.rb +3 -3
  272. data/lib/rubber/recipes/rubber/instances.rb +12 -1
  273. data/lib/rubber/recipes/rubber/setup.rb +96 -55
  274. data/lib/rubber/recipes/rubber/spot_requests.rb +6 -0
  275. data/lib/rubber/recipes/rubber/static_ips.rb +83 -0
  276. data/lib/rubber/recipes/rubber/utils.rb +39 -16
  277. data/lib/rubber/recipes/rubber/volumes.rb +4 -4
  278. data/lib/rubber/recipes/rubber.rb +16 -9
  279. data/lib/rubber/util.rb +28 -1
  280. data/lib/rubber.rb +47 -7
  281. data/rails/init.rb +1 -4
  282. data/test/environment_test.rb +3 -0
  283. data/test/generator_test.rb +47 -0
  284. data/test/instance_test.rb +3 -0
  285. data/test/test_helper.rb +6 -0
  286. data/test/util_test.rb +3 -0
  287. data/test/zerigo_test.rb +87 -0
  288. metadata +275 -50
  289. data/generators/vulcanize/templates/resque/config/rubber/deploy-resque-worker-default.rb +0 -38
  290. data/generators/vulcanize/templates/resque/config/rubber/role/resque_worker_default/monit-resque_worker_default.conf +0 -19
  291. /data/generators/vulcanize/templates/{complete_passenger_mysql → complete_passenger}/config/rubber/rubber-complete.yml +0 -0
@@ -0,0 +1,55 @@
1
+ <%
2
+ @path = "/etc/nginx/rubber/tools.conf"
3
+ %>
4
+
5
+
6
+ # This server is setup to serve http.
7
+ server
8
+ {
9
+ listen <%= rubber_env.web_tools_port %>;
10
+ server_name <%= rubber_env.full_host %>;
11
+ root /var/www;
12
+
13
+ rewrite (.*) https://$host:<%= rubber_env.web_tools_ssl_port %>$1 break;
14
+ }
15
+
16
+ # This server is setup to serve https.
17
+ server
18
+ {
19
+ listen <%= rubber_env.web_tools_ssl_port %>;
20
+ server_name <%= rubber_env.full_host %>;
21
+
22
+ ssl on;
23
+ ssl_certificate /etc/ssl/certs/ssl-cert-snakeoil.pem;
24
+ ssl_certificate_key /etc/ssl/private/ssl-cert-snakeoil.key;
25
+ # ssl_certificate <%= RUBBER_ROOT %>/config/snapmylife.com.crt;
26
+ # ssl_certificate_key <%= RUBBER_ROOT %>/config/snapmylife.com.key;
27
+
28
+ auth_basic "Rubber Admin Tools";
29
+ auth_basic_user_file <%= RUBBER_ROOT %>/config/<%= rubber_env.app_name %>.auth;
30
+
31
+ client_max_body_size 10M;
32
+ root /var/www;
33
+
34
+
35
+ location /
36
+ {
37
+ # If the file exists as a static file serve it directly without
38
+ # running all the other rewrite tests on it
39
+ if (-f $request_filename)
40
+ {
41
+ break;
42
+ }
43
+
44
+ # check for index.html for directory index
45
+ # if its there on the filesystem then rewite
46
+ # the url to add /index.html to the end of it
47
+ # and then break to send it to the next config rules.
48
+ if (-f $request_filename/index.html)
49
+ {
50
+ rewrite (.*) $1/index.html break;
51
+ }
52
+ }
53
+
54
+ include /etc/nginx/rubber/tools/*.conf;
55
+ }
@@ -0,0 +1,30 @@
1
+ <%
2
+ @path = "/var/www/index.html"
3
+ %>
4
+ <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
5
+ <html>
6
+ <head>
7
+ <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
8
+ <title>Rubber Admin Tools</title>
9
+ </head>
10
+ <body>
11
+ <h1>Rubber Admin Tools</h1>
12
+ <ul>
13
+
14
+ <li><a href="/munin/">Munin</a></li>
15
+
16
+ <% if cruise_host = rubber_instances.for_role('cruise').first %>
17
+ <li><a href="http://<%= cruise_host %>/cruise/">CruiseControl</a></li>
18
+ <% end %>
19
+
20
+ <% rubber_instances.for_role('haproxy').each do |ic| %>
21
+ <li><a href="/haproxy_<%= ic.name %>/">HAProxy <%= ic.name %></a></li>
22
+ <% end %>
23
+
24
+ <% rubber_instances.each do |ic| %>
25
+ <li><a href="/monit_<%= ic.name %>/">Monit <%= ic.name %></a></li>
26
+ <% end %>
27
+
28
+ </ul>
29
+ </body>
30
+ </html>
@@ -0,0 +1,7 @@
1
+ <%
2
+ @path = "#{RUBBER_ROOT}/config/#{rubber_env.app_name}.auth"
3
+ user = rubber_env.web_tools_user || 'admin'
4
+ pass = rubber_env.web_tools_password || rand(1000000000).to_s
5
+ %>
6
+
7
+ <%= user %>:<%= pass.crypt(sprintf('%02d', rand(100)))%>
@@ -0,0 +1,10 @@
1
+
2
+ # Uses from base rubber config
3
+ # domain: foo.com
4
+
5
+ # Uses from rubber-complete.yml
6
+ # web_tools_port: 8080
7
+
8
+ roles:
9
+ nginx:
10
+ packages: [nginx]
@@ -0,0 +1 @@
1
+ description: The nginx module
@@ -0,0 +1,46 @@
1
+
2
+ namespace :rubber do
3
+
4
+ namespace :passenger do
5
+
6
+ rubber.allow_optional_tasks(self)
7
+
8
+ after "rubber:install_gems", "rubber:passenger:custom_install"
9
+
10
+ task :custom_install, :roles => :passenger do
11
+ rubber.sudo_script 'install_passenger', <<-ENDSCRIPT
12
+ if [[ -z `ls #{rubber_env.passenger_lib} 2> /dev/null` ]]; then
13
+ echo -en "\n\n\n\n" | passenger-install-apache2-module
14
+ rvm #{rubber_env.rvm_ruby} --passenger
15
+ fi
16
+ ENDSCRIPT
17
+ end
18
+
19
+ after "rubber:setup_app_permissions", "rubber:passenger:setup_passenger_permissions"
20
+
21
+ task :setup_passenger_permissions, :roles => :passenger do
22
+ rsudo "chown #{rubber_env.app_user}:#{rubber_env.app_user} #{current_path}/config/environment.rb"
23
+ end
24
+
25
+ # passenger does things differently for rack apps, so if this is a rails app, remove config.ru
26
+ # to stop passenger from treating this like a rack app
27
+ after "deploy:update_code", "rubber:passenger:remove_config_ru" if Rubber::Util.is_rails?
28
+
29
+ task :remove_config_ru, :roles => :passenger do
30
+ rsudo "rm -f #{current_release}/config.ru"
31
+ end
32
+
33
+ # passenger depends on apache for start/stop/restart, just need these defined
34
+ # as apache hooks into standard deploy lifecycle
35
+
36
+ deploy.task :restart, :roles => :app do
37
+ end
38
+
39
+ deploy.task :stop, :roles => :app do
40
+ end
41
+
42
+ deploy.task :start, :roles => :app do
43
+ end
44
+
45
+ end
46
+ end
@@ -0,0 +1,34 @@
1
+ <%
2
+ @path = "/etc/munin/plugins/passenger_memory_status"
3
+ @perms = 0755
4
+ %>#!/usr/bin/env ruby
5
+ # put in /etc/munin/plugins and restart munin-node
6
+ # by Dan Manges, http://www.dcmanges.com/blog/rails-application-visualization-with-munin
7
+ # NOTE: you might need to add munin to allow passwordless sudo for passenger-memory-stats
8
+
9
+ def output_config
10
+ puts <<-END
11
+ graph_category App
12
+ graph_title Passenger memory stats
13
+ graph_vlabel megabytes
14
+
15
+ memory.label memory
16
+ END
17
+ exit 0
18
+ end
19
+
20
+ def output_values
21
+ status = `sudo <%= ENV['GEM_HOME'] %>/bin/passenger-memory-stats | tail -1`
22
+ unless $?.success?
23
+ $stderr.puts "failed executing passenger-memory-stats"
24
+ exit 1
25
+ end
26
+ status =~ /(\d+\.\d+)/
27
+ puts "memory.value #{$1}"
28
+ end
29
+
30
+ if ARGV[0] == "config"
31
+ output_config
32
+ else
33
+ output_values
34
+ end
@@ -0,0 +1,7 @@
1
+ <%
2
+ @path = '/etc/sudoers'
3
+ @additive = ["# munin passenger start", "# munin passenger end"]
4
+ %>
5
+
6
+ nobody ALL=(ALL) NOPASSWD: <%= ENV['GEM_HOME'] %>/bin/passenger-status
7
+ nobody ALL=(ALL) NOPASSWD: <%= ENV['GEM_HOME'] %>/bin/passenger-memory-stats
@@ -0,0 +1,47 @@
1
+ <%
2
+ @path = "/etc/munin/plugins/passenger_status"
3
+ @perms = 0755
4
+ %>#!/usr/bin/env ruby
5
+
6
+ # from http://gist.github.com/21328
7
+ # by Dan Manges, http://www.dcmanges.com/blog/rails-application-visualization-with-munin
8
+
9
+ def output_config
10
+ puts <<-END
11
+ graph_category App
12
+ graph_title passenger status
13
+ graph_vlabel count
14
+
15
+ sessions.label sessions
16
+ max.label max processes
17
+ running.label running processes
18
+ active.label active processes
19
+ END
20
+ exit 0
21
+ end
22
+
23
+ def output_values
24
+ status = `sudo <%= ENV['GEM_HOME'] %>/bin/passenger-status`
25
+ unless $?.success?
26
+ $stderr.puts "failed executing passenger-status"
27
+ exit 1
28
+ end
29
+ status =~ /max\s+=\s+(\d+)/
30
+ puts "max.value #{$1}"
31
+
32
+ status =~ /count\s+=\s+(\d+)/
33
+ puts "running.value #{$1}"
34
+
35
+ status =~ /active\s+=\s+(\d+)/
36
+ puts "active.value #{$1}"
37
+
38
+ total_sessions = 0
39
+ status.scan(/Sessions: (\d+)/).flatten.each { |count| total_sessions += count.to_i }
40
+ puts "sessions.value #{total_sessions}"
41
+ end
42
+
43
+ if ARGV[0] == "config"
44
+ output_config
45
+ else
46
+ output_values
47
+ end
@@ -0,0 +1,46 @@
1
+ <%
2
+ @path = "/etc/apache2/sites-available/#{rubber_env.app_name}-passenger"
3
+ @post = "a2enmod rewrite && a2enmod ssl && a2ensite #{rubber_env.app_name}-passenger"
4
+ %>
5
+
6
+ <% [rubber_env.passenger_listen_port, rubber_env.passenger_listen_ssl_port].each do |port| %>
7
+
8
+ Listen <%= port %>
9
+ <VirtualHost *:<%= port %>>
10
+ ServerName <%= rubber_env.domain %>
11
+ <%- if rubber_env.web_aliases -%>
12
+ ServerAlias <%= rubber_env.web_aliases.join(" ") %>
13
+ <%- end -%>
14
+ DocumentRoot <%= RUBBER_ROOT + "/public" %>
15
+
16
+ ErrorDocument 404 /404.html
17
+ ErrorDocument 500 /500.html
18
+
19
+ SetEnvIf User-Agent "^(.*MSIE.*)|(.*AppleWebKit.*)$" nokeepalive
20
+
21
+ RailsEnv <%= RUBBER_ENV %>
22
+ RailsAllowModRewrite on
23
+
24
+ RewriteEngine On
25
+ RewriteCond %{HTTP_HOST} ^<%= rubber_env.domain %>$
26
+ RewriteRule ^(.*)$ http://www.<%= rubber_env.domain %>$1 [R,L]
27
+
28
+ # Include <%= RUBBER_ROOT %>/config/apache/rewrites.conf
29
+
30
+ RewriteCond %{DOCUMENT_ROOT}/system/maintenance.html -f
31
+ RewriteCond %{SCRIPT_FILENAME} !maintenance.html
32
+ RewriteRule ^.*$ /system/maintenance.html [L]
33
+
34
+ <% if port == rubber_env.passenger_listen_ssl_port %>
35
+ SSLEngine on
36
+ SSLOptions +FakeBasicAuth +ExportCertData +StrictRequire
37
+ SSLCertificateFile /etc/ssl/certs/ssl-cert-snakeoil.pem
38
+ SSLCertificateKeyFile /etc/ssl/private/ssl-cert-snakeoil.key
39
+ # SSLCertificateFile <%= RUBBER_ROOT %>/config/<%= rubber_env.domain %>.crt
40
+ # SSLCertificateKeyFile <%= RUBBER_ROOT %>/config/<%= rubber_env.domain %>.key
41
+ # SSLCertificateChainFile /etc/ssl/certs/gd_intermediate_bundle.crt
42
+ <% end %>
43
+
44
+ </VirtualHost>
45
+
46
+ <% end %>
@@ -0,0 +1,35 @@
1
+ <%
2
+ @path = '/etc/apache2/mods-available/passenger.conf'
3
+ @post = 'cd /etc/apache2/mods-enabled && ln -fs ../mods-available/passenger.conf'
4
+ %>
5
+ LoadModule passenger_module <%= `echo #{rubber_env.passenger_lib}` %>
6
+ PassengerRoot <%= `echo #{rubber_env.passenger_root}` %>
7
+ PassengerRuby <%= `echo #{rubber_env.passenger_ruby}` %>
8
+ PassengerUseGlobalQueue on
9
+
10
+ # max number of rails instances per appserver
11
+ PassengerMaxPoolSize <%= rubber_env.max_app_connections %>
12
+
13
+ # Use PassengerMaxPoolSize for limit as we only have 1 app
14
+ PassengerMaxInstancesPerApp 0
15
+
16
+ # For performances sake, never shutdown rails instances when idle
17
+ PassengerPoolIdleTime 0
18
+
19
+ # For performances sake, never shutdown a rails instance after N requests
20
+ PassengerMaxRequests 0
21
+
22
+ # Passenger checks stuff like restart.txt on every request when this is 0
23
+ PassengerStatThrottleRate <%= RUBBER_ENV == 'production' ? '60' : '0' %>
24
+
25
+ # Turning this on breaks mod_rewrite
26
+ PassengerHighPerformance off
27
+
28
+ # Cache framework code per application
29
+ RailsSpawnMethod smart-lv2
30
+
31
+ # For performances sake, don't ever unload framework spawner
32
+ RailsFrameworkSpawnerIdleTime 0
33
+
34
+ # For performances sake, don't ever unload app spawner
35
+ RailsAppSpawnerIdleTime 0
@@ -0,0 +1,15 @@
1
+ passenger_version: 2.2.11
2
+ passenger_root: "$GEM_HOME/gems/passenger-#{passenger_version}"
3
+ passenger_ruby: "#{rvm_prefix}/bin/passenger_ruby"
4
+ passenger_lib: "#{passenger_root}/ext/apache2/mod_passenger.so"
5
+ passenger_listen_port: 7000
6
+ passenger_listen_ssl_port: 7001
7
+ max_app_connections: 20
8
+
9
+ role_dependencies:
10
+ passenger: [apache]
11
+
12
+ roles:
13
+ passenger:
14
+ packages: [apache2-mpm-prefork, apache2-prefork-dev]
15
+ gems: [fastthread, rack, [passenger, "#{passenger_version}"]]
@@ -0,0 +1,3 @@
1
+ description: Phusion Passenger module (Apache2)
2
+ dependent_templates:
3
+ - apache
@@ -0,0 +1,12 @@
1
+ <%
2
+ @path = "#{RUBBER_ROOT}/config/database.yml"
3
+ %>
4
+
5
+ <%= RUBBER_ENV %>:
6
+ adapter: postgresql
7
+ encoding: unicode
8
+ database: <%= rubber_env.db_name %>
9
+ username: <%= rubber_env.db_user %>
10
+ password: <%= rubber_env.db_pass %>
11
+ host: <%= rubber_instances.for_role('db', 'primary' => true).first.full_name %>
12
+ pool: 5
@@ -0,0 +1,131 @@
1
+
2
+ namespace :rubber do
3
+
4
+ namespace :postgresql do
5
+
6
+ rubber.allow_optional_tasks(self)
7
+
8
+ after "rubber:create", "rubber:postgresql:validate_db_roles"
9
+
10
+ task :validate_db_roles do
11
+ db_instances = rubber_instances.for_role("postgresql_slave")
12
+ db_instances.each do |instance|
13
+ if instance.role_names.find {|n| n == 'postgresql_master'}
14
+ fatal "Cannot have a postgresql slave and master on the same instance, please removing slave role for #{instance.name}"
15
+ end
16
+ end
17
+ end
18
+
19
+ after "rubber:bootstrap", "rubber:postgresql:bootstrap"
20
+
21
+
22
+ # Bootstrap the production database config. Db bootstrap is special - the
23
+ # user could be requiring the rails env inside some of their config
24
+ # templates, which creates a catch 22 situation with the db, so we try and
25
+ # bootstrap the db separate from the rest of the config
26
+ task :bootstrap, :roles => [:postgresql_master, :postgresql_slave] do
27
+
28
+ # Conditionaly bootstrap for each node/role only if that node has not
29
+ # been boostrapped for that role before
30
+ master_instances = rubber_instances.for_role("postgresql_master") & rubber_instances.filtered
31
+ master_instances.each do |ic|
32
+ task_name = "_bootstrap_postgresql_master_#{ic.full_name}".to_sym()
33
+ task task_name, :hosts => ic.full_name do
34
+ env = rubber_cfg.environment.bind("postgresql_master", ic.name)
35
+ exists = capture("echo $(ls #{env.postgresql_data_dir}/ 2> /dev/null)")
36
+ if exists.strip.size == 0
37
+ common_bootstrap("postgresql_master")
38
+
39
+ create_user_cmd = "CREATE USER #{env.db_user} WITH NOSUPERUSER CREATEDB NOCREATEROLE"
40
+ create_user_cmd << "PASSWORD '#{env.db_pass}'" if env.db_pass
41
+ rubber.sudo_script "create_master_db", <<-ENDSCRIPT
42
+ sudo -u postgres psql -c "#{create_user_cmd}"
43
+ sudo -u postgres psql -c "CREATE DATABASE #{env.db_name} WITH OWNER #{env.db_user}"
44
+ ENDSCRIPT
45
+ end
46
+ end
47
+ send task_name
48
+ end
49
+
50
+ # Wait for postgresql 9.0 to be avlabel before allowing slaves
51
+ #
52
+ # slave_instances = rubber_instances.for_role("postgresql_slave") & rubber_instances.filtered
53
+ # slave_instances.each do |ic|
54
+ # task_name = "_bootstrap_postgresql_slave_#{ic.full_name}".to_sym()
55
+ # task task_name, :hosts => ic.full_name do
56
+ # env = rubber_cfg.environment.bind("postgresql_slave", ic.name)
57
+ # exists = capture("echo $(ls #{env.db_data_dir}/ 2> /dev/null)")
58
+ # if exists.strip.size == 0
59
+ # common_bootstrap("postgresql_slave")
60
+ #
61
+ # source = master = rubber_instances.for_role("postgresql_master").first
62
+ #
63
+ # slave_pub_key = capture("cat /root/.ssh/id_dsa.pub")
64
+ # sudo "echo \"#{slave_pub_key}\" >> /root/.ssh/authorized_keys", :hosts => [master.full_name]
65
+ #
66
+ # base_backup_script = <<-ENDSCRIPT
67
+ # sudo -u postgres psql -c "SELECT pg_start_backup('rubber_create_slave')"
68
+ # tar --exclude pg_xlog -czf /tmp/postgresql-data.tgz #{env.postgresql_data_dir}
69
+ # tar -czf /tmp/postgresql-archive.tgz #{env.postgresql_archive_dir}
70
+ # sudo -u postgres psql -c "SELECT pg_stop_backup()"
71
+ # ENDSCRIPT
72
+ #
73
+ # rubber.sudo_script "create_slave_db_from_master", base_backup_script, :hosts => [master.full_name]
74
+ #
75
+ # rsudo "psql -u root -e \"start slave;\""
76
+ # end
77
+ # end
78
+ # send task_name
79
+ # end
80
+
81
+ end
82
+
83
+ # TODO: Make the setup/update happen just once per host
84
+ def common_bootstrap(role)
85
+ # postgresql package install starts postgresql, so stop it
86
+ rsudo "#{rubber_env.postgresql_ctl} stop" rescue nil
87
+
88
+ # After everything installed on machines, we need the source tree
89
+ # on hosts in order to run rubber:config for bootstrapping the db
90
+ rubber.update_code_for_bootstrap
91
+
92
+ # Gen just the conf for the given postgresql role
93
+ rubber.run_config(:RUBBER_ENV => RUBBER_ENV, :FILE => "role/#{role}|role/db/", :FORCE => true, :deploy_path => release_path)
94
+
95
+ # reconfigure postgresql so that it sets up data dir in /mnt with correct files
96
+ dirs = [rubber_env.postgresql_data_dir, rubber_env.postgresql_archive_dir]
97
+ sudo_script 'reconfigure-postgresql', <<-ENDSCRIPT
98
+ mkdir -p #{dirs.join(' ')}
99
+ chown -R postgres:postgres #{dirs.join(' ')}
100
+
101
+ sudo -u postgres /usr/lib/postgresql/#{rubber_env.postgresql_ver}/bin/initdb -D #{rubber_env.postgresql_data_dir}
102
+
103
+ #{rubber_env.postgresql_ctl} start
104
+ ENDSCRIPT
105
+ sleep 5
106
+ end
107
+
108
+ desc <<-DESC
109
+ Starts the postgresql daemons
110
+ DESC
111
+ task :start, :roles => [:postgresql_master, :postgresql_slave] do
112
+ rsudo "#{rubber_env.postgresql_ctl} start"
113
+ end
114
+
115
+ desc <<-DESC
116
+ Stops the postgresql daemons
117
+ DESC
118
+ task :stop, :roles => [:postgresql_master, :postgresql_slave] do
119
+ rsudo "#{rubber_env.postgresql_ctl} stop"
120
+ end
121
+
122
+ desc <<-DESC
123
+ Restarts the postgresql daemons
124
+ DESC
125
+ task :restart, :roles => [:postgresql_master, :postgresql_slave] do
126
+ rsudo "#{rubber_env.postgresql_ctl} restart"
127
+ end
128
+
129
+ end
130
+
131
+ end
@@ -0,0 +1,14 @@
1
+ <%
2
+ @read_cmd = 'crontab -l'
3
+ @write_cmd = 'crontab -'
4
+ @additive = ["# rubber-postgresql-start", "# rubber-postgresql-end"]
5
+ %>
6
+
7
+ <%
8
+ # Backup db every 3 hours to secondary db if available, else primary db
9
+ backup_db_host = rubber_instances.for_role('db', {}).first rescue nil
10
+ backup_db_host ||= rubber_instances.for_role('db', 'primary' => true).first
11
+ if backup_db_host.name == rubber_env.host
12
+ %>
13
+ 0 */3 * * * BACKUP_DIR=/mnt/db_backups DBUSER=<%= rubber_env.db_user %> DBPASS=<%= rubber_env.db_pass %> DBNAME=<%= rubber_env.db_name %> DBHOST=<%= backup_db_host.full_name %> <%= RUBBER_ROOT %>/script/cron-rake rubber:backup_db
14
+ <% end %>
@@ -0,0 +1,10 @@
1
+ <%
2
+ @path = '/etc/monit/monit.d/monit-postgresql.conf'
3
+ %>
4
+
5
+ check process postgresql with pidfile <%= rubber_env.postgresql_pid_file %>
6
+ group postgresql-<%= RUBBER_ENV %>
7
+ start program = "<%= rubber_env.postgresql_ctl %> restart"
8
+ stop program = "<%= rubber_env.postgresql_ctl %> stop"
9
+ if failed host 127.0.0.1 port 5432 protocol pgsql then alert
10
+ if 5 restarts within 5 cycles then timeout
@@ -0,0 +1,89 @@
1
+ <%
2
+ @path = "#{rubber_env.postgresql_conf_dir}/pg_hba.conf"
3
+ %>
4
+ # PostgreSQL Client Authentication Configuration File
5
+ # ===================================================
6
+ #
7
+ # Refer to the "Client Authentication" section in the
8
+ # PostgreSQL documentation for a complete description
9
+ # of this file. A short synopsis follows.
10
+ #
11
+ # This file controls: which hosts are allowed to connect, how clients
12
+ # are authenticated, which PostgreSQL user names they can use, which
13
+ # databases they can access. Records take one of these forms:
14
+ #
15
+ # local DATABASE USER METHOD [OPTIONS]
16
+ # host DATABASE USER CIDR-ADDRESS METHOD [OPTIONS]
17
+ # hostssl DATABASE USER CIDR-ADDRESS METHOD [OPTIONS]
18
+ # hostnossl DATABASE USER CIDR-ADDRESS METHOD [OPTIONS]
19
+ #
20
+ # (The uppercase items must be replaced by actual values.)
21
+ #
22
+ # The first field is the connection type: "local" is a Unix-domain socket,
23
+ # "host" is either a plain or SSL-encrypted TCP/IP socket, "hostssl" is an
24
+ # SSL-encrypted TCP/IP socket, and "hostnossl" is a plain TCP/IP socket.
25
+ #
26
+ # DATABASE can be "all", "sameuser", "samerole", a database name, or
27
+ # a comma-separated list thereof.
28
+ #
29
+ # USER can be "all", a user name, a group name prefixed with "+", or
30
+ # a comma-separated list thereof. In both the DATABASE and USER fields
31
+ # you can also write a file name prefixed with "@" to include names from
32
+ # a separate file.
33
+ #
34
+ # CIDR-ADDRESS specifies the set of hosts the record matches.
35
+ # It is made up of an IP address and a CIDR mask that is an integer
36
+ # (between 0 and 32 (IPv4) or 128 (IPv6) inclusive) that specifies
37
+ # the number of significant bits in the mask. Alternatively, you can write
38
+ # an IP address and netmask in separate columns to specify the set of hosts.
39
+ #
40
+ # METHOD can be "trust", "reject", "md5", "password", "gss", "sspi", "krb5",
41
+ # "ident", "pam", "ldap" or "cert". Note that "password" sends passwords
42
+ # in clear text; "md5" is preferred since it sends encrypted passwords.
43
+ #
44
+ # OPTIONS are a set of options for the authentication in the format
45
+ # NAME=VALUE. The available options depend on the different authentication
46
+ # methods - refer to the "Client Authentication" section in the documentation
47
+ # for a list of which options are available for which authentication methods.
48
+ #
49
+ # Database and user names containing spaces, commas, quotes and other special
50
+ # characters must be quoted. Quoting one of the keywords "all", "sameuser" or
51
+ # "samerole" makes the name lose its special character, and just match a
52
+ # database or username with that name.
53
+ #
54
+ # This file is read on server startup and when the postmaster receives
55
+ # a SIGHUP signal. If you edit the file on a running system, you have
56
+ # to SIGHUP the postmaster for the changes to take effect. You can use
57
+ # "pg_ctl reload" to do that.
58
+
59
+ # Put your actual configuration here
60
+ # ----------------------------------
61
+ #
62
+ # If you want to allow non-local connections, you need to add more
63
+ # "host" records. In that case you will also need to make PostgreSQL listen
64
+ # on a non-local interface via the listen_addresses configuration parameter,
65
+ # or via the -i or -h command line switches.
66
+ #
67
+
68
+
69
+
70
+
71
+ # DO NOT DISABLE!
72
+ # If you change this first entry you will need to make sure that the
73
+ # database
74
+ # super user can access the database using some other method.
75
+ # Noninteractive
76
+ # access to all databases is required during automatic maintenance
77
+ # (custom daily cronjobs, replication, and similar tasks).
78
+ #
79
+ # Database administrative login by UNIX sockets
80
+ local all postgres ident
81
+
82
+ # TYPE DATABASE USER CIDR-ADDRESS METHOD
83
+ <%
84
+ scheme = rubber_env.db_pass ? 'md5' : 'trust'
85
+ %>
86
+ local all <%= rubber_env.db_user %> <%= scheme %>
87
+ host all all 127.0.0.1/32 <%= scheme %>
88
+ host all all ::1/128 <%= scheme %>
89
+ host all <%= rubber_env.db_user %> 10.0.0.1/8 <%= scheme %>
@@ -0,0 +1,6 @@
1
+ <%
2
+ @path = "/etc/sysctl.d/30-postgresql.conf"
3
+ @post = "service procps start"
4
+ %>
5
+ kernel.shmmax=1610612736
6
+ kernel.shmall=393216