prestogres 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (393) hide show
  1. data/.gitignore +4 -0
  2. data/Gemfile +2 -0
  3. data/Gemfile.lock +20 -0
  4. data/LICENSE +202 -0
  5. data/NOTICE +22 -0
  6. data/README.md +217 -0
  7. data/Rakefile +13 -0
  8. data/VERSION +1 -0
  9. data/bin/prestogres +254 -0
  10. data/config/pcp.conf.sample +28 -0
  11. data/config/pgpool.conf +678 -0
  12. data/config/pool_hba.conf +84 -0
  13. data/config/pool_passwd +0 -0
  14. data/config/postgresql.conf +2 -0
  15. data/ext/.gitignore +6 -0
  16. data/ext/depend +26 -0
  17. data/ext/extconf.rb +4 -0
  18. data/ext/prestogres_config.c +12 -0
  19. data/pgpool2/.gitignore +36 -0
  20. data/pgpool2/AUTHORS +4 -0
  21. data/pgpool2/COPYING +12 -0
  22. data/pgpool2/ChangeLog +1 -0
  23. data/pgpool2/INSTALL +1 -0
  24. data/pgpool2/Makefile.am +159 -0
  25. data/pgpool2/Makefile.in +1187 -0
  26. data/pgpool2/NEWS +4960 -0
  27. data/pgpool2/README +1 -0
  28. data/pgpool2/README.euc_jp +1 -0
  29. data/pgpool2/README.online-recovery +62 -0
  30. data/pgpool2/TODO +103 -0
  31. data/pgpool2/ac_func_accept_argtypes.m4 +85 -0
  32. data/pgpool2/aclocal.m4 +1088 -0
  33. data/pgpool2/c-compiler.m4 +134 -0
  34. data/pgpool2/c-library.m4 +325 -0
  35. data/pgpool2/child.c +2097 -0
  36. data/pgpool2/config.guess +1532 -0
  37. data/pgpool2/config.h.in +332 -0
  38. data/pgpool2/config.sub +1640 -0
  39. data/pgpool2/configure +15752 -0
  40. data/pgpool2/configure.in +392 -0
  41. data/pgpool2/depcomp +522 -0
  42. data/pgpool2/doc/basebackup.sh +17 -0
  43. data/pgpool2/doc/pgpool-de.html +4220 -0
  44. data/pgpool2/doc/pgpool-en.html +5738 -0
  45. data/pgpool2/doc/pgpool-fr.html +4118 -0
  46. data/pgpool2/doc/pgpool-ja.css +198 -0
  47. data/pgpool2/doc/pgpool-ja.html +11279 -0
  48. data/pgpool2/doc/pgpool-zh_cn.html +4445 -0
  49. data/pgpool2/doc/pgpool.css +280 -0
  50. data/pgpool2/doc/pgpool_remote_start +13 -0
  51. data/pgpool2/doc/recovery.conf.sample +117 -0
  52. data/pgpool2/doc/tutorial-en.html +707 -0
  53. data/pgpool2/doc/tutorial-ja.html +422 -0
  54. data/pgpool2/doc/tutorial-memqcache-en.html +325 -0
  55. data/pgpool2/doc/tutorial-memqcache-ja.html +370 -0
  56. data/pgpool2/doc/tutorial-memqcache-zh_cn.html +322 -0
  57. data/pgpool2/doc/tutorial-watchdog-en.html +306 -0
  58. data/pgpool2/doc/tutorial-watchdog-ja.html +343 -0
  59. data/pgpool2/doc/tutorial-watchdog-zh_cn.html +301 -0
  60. data/pgpool2/doc/tutorial-zh_cn.html +537 -0
  61. data/pgpool2/doc/watchdog.png +0 -0
  62. data/pgpool2/doc/wd-en.html +236 -0
  63. data/pgpool2/doc/wd-en.jpg +0 -0
  64. data/pgpool2/doc/wd-ja.html +219 -0
  65. data/pgpool2/doc/wd-ja.jpg +0 -0
  66. data/pgpool2/doc/wd-zh_cn.html +201 -0
  67. data/pgpool2/doc/where_to_send_queries.odg +0 -0
  68. data/pgpool2/doc/where_to_send_queries.pdf +0 -0
  69. data/pgpool2/general.m4 +166 -0
  70. data/pgpool2/getopt_long.c +200 -0
  71. data/pgpool2/getopt_long.h +44 -0
  72. data/pgpool2/install-sh +251 -0
  73. data/pgpool2/ltmain.sh +8406 -0
  74. data/pgpool2/m4/libtool.m4 +7360 -0
  75. data/pgpool2/m4/ltoptions.m4 +368 -0
  76. data/pgpool2/m4/ltsugar.m4 +123 -0
  77. data/pgpool2/m4/ltversion.m4 +23 -0
  78. data/pgpool2/m4/lt~obsolete.m4 +92 -0
  79. data/pgpool2/main.c +2971 -0
  80. data/pgpool2/md5.c +444 -0
  81. data/pgpool2/md5.h +28 -0
  82. data/pgpool2/missing +360 -0
  83. data/pgpool2/mkinstalldirs +40 -0
  84. data/pgpool2/parser/Makefile.am +50 -0
  85. data/pgpool2/parser/Makefile.in +559 -0
  86. data/pgpool2/parser/copyfuncs.c +3310 -0
  87. data/pgpool2/parser/gram.c +39100 -0
  88. data/pgpool2/parser/gram.h +940 -0
  89. data/pgpool2/parser/gram.y +13408 -0
  90. data/pgpool2/parser/gramparse.h +74 -0
  91. data/pgpool2/parser/keywords.c +32 -0
  92. data/pgpool2/parser/keywords.h +39 -0
  93. data/pgpool2/parser/kwlist.h +425 -0
  94. data/pgpool2/parser/kwlookup.c +88 -0
  95. data/pgpool2/parser/list.c +1156 -0
  96. data/pgpool2/parser/makefuncs.c +518 -0
  97. data/pgpool2/parser/makefuncs.h +83 -0
  98. data/pgpool2/parser/memnodes.h +79 -0
  99. data/pgpool2/parser/nodes.c +29 -0
  100. data/pgpool2/parser/nodes.h +609 -0
  101. data/pgpool2/parser/outfuncs.c +5790 -0
  102. data/pgpool2/parser/parsenodes.h +2615 -0
  103. data/pgpool2/parser/parser.c +262 -0
  104. data/pgpool2/parser/parser.h +46 -0
  105. data/pgpool2/parser/pg_class.h +158 -0
  106. data/pgpool2/parser/pg_config_manual.h +273 -0
  107. data/pgpool2/parser/pg_list.h +352 -0
  108. data/pgpool2/parser/pg_trigger.h +147 -0
  109. data/pgpool2/parser/pg_wchar.h +492 -0
  110. data/pgpool2/parser/pool_memory.c +342 -0
  111. data/pgpool2/parser/pool_memory.h +77 -0
  112. data/pgpool2/parser/pool_parser.h +222 -0
  113. data/pgpool2/parser/pool_string.c +121 -0
  114. data/pgpool2/parser/pool_string.h +37 -0
  115. data/pgpool2/parser/primnodes.h +1280 -0
  116. data/pgpool2/parser/scan.c +4094 -0
  117. data/pgpool2/parser/scan.l +1451 -0
  118. data/pgpool2/parser/scanner.h +120 -0
  119. data/pgpool2/parser/scansup.c +221 -0
  120. data/pgpool2/parser/scansup.h +28 -0
  121. data/pgpool2/parser/snprintf.c +1102 -0
  122. data/pgpool2/parser/stringinfo.c +294 -0
  123. data/pgpool2/parser/stringinfo.h +178 -0
  124. data/pgpool2/parser/value.c +78 -0
  125. data/pgpool2/parser/value.h +62 -0
  126. data/pgpool2/parser/wchar.c +2048 -0
  127. data/pgpool2/pcp.conf.sample +28 -0
  128. data/pgpool2/pcp/Makefile.am +40 -0
  129. data/pgpool2/pcp/Makefile.in +771 -0
  130. data/pgpool2/pcp/libpcp_ext.h +250 -0
  131. data/pgpool2/pcp/md5.c +444 -0
  132. data/pgpool2/pcp/md5.h +28 -0
  133. data/pgpool2/pcp/pcp.c +1652 -0
  134. data/pgpool2/pcp/pcp.h +61 -0
  135. data/pgpool2/pcp/pcp_attach_node.c +172 -0
  136. data/pgpool2/pcp/pcp_detach_node.c +185 -0
  137. data/pgpool2/pcp/pcp_error.c +87 -0
  138. data/pgpool2/pcp/pcp_node_count.c +160 -0
  139. data/pgpool2/pcp/pcp_node_info.c +198 -0
  140. data/pgpool2/pcp/pcp_pool_status.c +166 -0
  141. data/pgpool2/pcp/pcp_proc_count.c +166 -0
  142. data/pgpool2/pcp/pcp_proc_info.c +261 -0
  143. data/pgpool2/pcp/pcp_promote_node.c +185 -0
  144. data/pgpool2/pcp/pcp_recovery_node.c +172 -0
  145. data/pgpool2/pcp/pcp_stop_pgpool.c +179 -0
  146. data/pgpool2/pcp/pcp_stream.c +385 -0
  147. data/pgpool2/pcp/pcp_stream.h +52 -0
  148. data/pgpool2/pcp/pcp_systemdb_info.c +194 -0
  149. data/pgpool2/pcp/pcp_watchdog_info.c +211 -0
  150. data/pgpool2/pcp_child.c +1493 -0
  151. data/pgpool2/pg_md5.c +305 -0
  152. data/pgpool2/pgpool.8.in +121 -0
  153. data/pgpool2/pgpool.conf +553 -0
  154. data/pgpool2/pgpool.conf.sample +666 -0
  155. data/pgpool2/pgpool.conf.sample-master-slave +665 -0
  156. data/pgpool2/pgpool.conf.sample-replication +664 -0
  157. data/pgpool2/pgpool.conf.sample-stream +664 -0
  158. data/pgpool2/pgpool.spec +264 -0
  159. data/pgpool2/pgpool_adm/TODO +7 -0
  160. data/pgpool2/pgpool_adm/pgpool_adm--1.0.sql +85 -0
  161. data/pgpool2/pgpool_adm/pgpool_adm.c +558 -0
  162. data/pgpool2/pgpool_adm/pgpool_adm.control +5 -0
  163. data/pgpool2/pgpool_adm/pgpool_adm.h +46 -0
  164. data/pgpool2/pgpool_adm/pgpool_adm.sql.in +85 -0
  165. data/pgpool2/pool.h +655 -0
  166. data/pgpool2/pool_auth.c +1390 -0
  167. data/pgpool2/pool_config.c +5007 -0
  168. data/pgpool2/pool_config.h +284 -0
  169. data/pgpool2/pool_config.l +3281 -0
  170. data/pgpool2/pool_config_md5.c +29 -0
  171. data/pgpool2/pool_connection_pool.c +812 -0
  172. data/pgpool2/pool_error.c +242 -0
  173. data/pgpool2/pool_globals.c +27 -0
  174. data/pgpool2/pool_hba.c +1723 -0
  175. data/pgpool2/pool_hba.conf.sample +67 -0
  176. data/pgpool2/pool_ip.c +567 -0
  177. data/pgpool2/pool_ip.h +65 -0
  178. data/pgpool2/pool_ipc.h +38 -0
  179. data/pgpool2/pool_lobj.c +242 -0
  180. data/pgpool2/pool_lobj.h +32 -0
  181. data/pgpool2/pool_memqcache.c +3818 -0
  182. data/pgpool2/pool_memqcache.h +268 -0
  183. data/pgpool2/pool_params.c +163 -0
  184. data/pgpool2/pool_passwd.c +249 -0
  185. data/pgpool2/pool_passwd.h +41 -0
  186. data/pgpool2/pool_path.c +193 -0
  187. data/pgpool2/pool_path.h +81 -0
  188. data/pgpool2/pool_process_context.c +247 -0
  189. data/pgpool2/pool_process_context.h +62 -0
  190. data/pgpool2/pool_process_query.c +5001 -0
  191. data/pgpool2/pool_process_reporting.c +1671 -0
  192. data/pgpool2/pool_process_reporting.h +44 -0
  193. data/pgpool2/pool_proto2.c +671 -0
  194. data/pgpool2/pool_proto_modules.c +3524 -0
  195. data/pgpool2/pool_proto_modules.h +185 -0
  196. data/pgpool2/pool_query_cache.c +1020 -0
  197. data/pgpool2/pool_query_context.c +1871 -0
  198. data/pgpool2/pool_query_context.h +105 -0
  199. data/pgpool2/pool_relcache.c +284 -0
  200. data/pgpool2/pool_relcache.h +78 -0
  201. data/pgpool2/pool_rewrite_outfuncs.c +9060 -0
  202. data/pgpool2/pool_rewrite_query.c +715 -0
  203. data/pgpool2/pool_rewrite_query.h +192 -0
  204. data/pgpool2/pool_select_walker.c +1150 -0
  205. data/pgpool2/pool_select_walker.h +68 -0
  206. data/pgpool2/pool_sema.c +161 -0
  207. data/pgpool2/pool_session_context.c +952 -0
  208. data/pgpool2/pool_session_context.h +203 -0
  209. data/pgpool2/pool_shmem.c +185 -0
  210. data/pgpool2/pool_signal.c +158 -0
  211. data/pgpool2/pool_signal.h +61 -0
  212. data/pgpool2/pool_ssl.c +339 -0
  213. data/pgpool2/pool_stream.c +962 -0
  214. data/pgpool2/pool_stream.h +61 -0
  215. data/pgpool2/pool_system.c +659 -0
  216. data/pgpool2/pool_timestamp.c +1215 -0
  217. data/pgpool2/pool_timestamp.h +38 -0
  218. data/pgpool2/pool_type.h +171 -0
  219. data/pgpool2/pool_worker_child.c +384 -0
  220. data/pgpool2/ps_status.c +404 -0
  221. data/pgpool2/recovery.c +435 -0
  222. data/pgpool2/redhat/pgpool.conf.sample.patch +52 -0
  223. data/pgpool2/redhat/pgpool.init +201 -0
  224. data/pgpool2/redhat/pgpool.sysconfig +7 -0
  225. data/pgpool2/redhat/rpm_installer/basebackup-replication.sh +53 -0
  226. data/pgpool2/redhat/rpm_installer/basebackup-stream.sh +55 -0
  227. data/pgpool2/redhat/rpm_installer/config_for_script +17 -0
  228. data/pgpool2/redhat/rpm_installer/failover.sh +64 -0
  229. data/pgpool2/redhat/rpm_installer/getsources.sh +141 -0
  230. data/pgpool2/redhat/rpm_installer/install.sh +1363 -0
  231. data/pgpool2/redhat/rpm_installer/pgpool_recovery_pitr +47 -0
  232. data/pgpool2/redhat/rpm_installer/pgpool_remote_start +15 -0
  233. data/pgpool2/redhat/rpm_installer/recovery.conf +4 -0
  234. data/pgpool2/redhat/rpm_installer/uninstall.sh +57 -0
  235. data/pgpool2/sample/dist_def_pgbench.sql +73 -0
  236. data/pgpool2/sample/pgpool.pam +3 -0
  237. data/pgpool2/sample/pgpool_recovery +20 -0
  238. data/pgpool2/sample/pgpool_recovery_pitr +19 -0
  239. data/pgpool2/sample/pgpool_remote_start +13 -0
  240. data/pgpool2/sample/replicate_def_pgbench.sql +18 -0
  241. data/pgpool2/sql/insert_lock.sql +15 -0
  242. data/pgpool2/sql/pgpool-recovery/pgpool-recovery.c +280 -0
  243. data/pgpool2/sql/pgpool-recovery/pgpool-recovery.sql.in +19 -0
  244. data/pgpool2/sql/pgpool-recovery/pgpool_recovery--1.0.sql +24 -0
  245. data/pgpool2/sql/pgpool-recovery/pgpool_recovery.control +5 -0
  246. data/pgpool2/sql/pgpool-recovery/uninstall_pgpool-recovery.sql +3 -0
  247. data/pgpool2/sql/pgpool-regclass/pgpool-regclass.c +206 -0
  248. data/pgpool2/sql/pgpool-regclass/pgpool-regclass.sql.in +4 -0
  249. data/pgpool2/sql/pgpool-regclass/pgpool_regclass--1.0.sql +7 -0
  250. data/pgpool2/sql/pgpool-regclass/pgpool_regclass.control +5 -0
  251. data/pgpool2/sql/pgpool-regclass/uninstall_pgpool-regclass.sql +1 -0
  252. data/pgpool2/sql/system_db.sql +38 -0
  253. data/pgpool2/strlcpy.c +85 -0
  254. data/pgpool2/test/C/test_extended.c +98 -0
  255. data/pgpool2/test/jdbc/.cvsignore +2 -0
  256. data/pgpool2/test/jdbc/AutoCommitTest.java +45 -0
  257. data/pgpool2/test/jdbc/BatchTest.java +55 -0
  258. data/pgpool2/test/jdbc/ColumnTest.java +60 -0
  259. data/pgpool2/test/jdbc/CreateTempTableTest.java +48 -0
  260. data/pgpool2/test/jdbc/InsertTest.java +34 -0
  261. data/pgpool2/test/jdbc/LockTest.java +36 -0
  262. data/pgpool2/test/jdbc/PgpoolTest.java +75 -0
  263. data/pgpool2/test/jdbc/README.euc_jp +73 -0
  264. data/pgpool2/test/jdbc/RunTest.java +83 -0
  265. data/pgpool2/test/jdbc/SelectTest.java +37 -0
  266. data/pgpool2/test/jdbc/UpdateTest.java +32 -0
  267. data/pgpool2/test/jdbc/expected/CreateTempTable +1 -0
  268. data/pgpool2/test/jdbc/expected/autocommit +10 -0
  269. data/pgpool2/test/jdbc/expected/batch +1 -0
  270. data/pgpool2/test/jdbc/expected/column +100 -0
  271. data/pgpool2/test/jdbc/expected/insert +1 -0
  272. data/pgpool2/test/jdbc/expected/lock +100 -0
  273. data/pgpool2/test/jdbc/expected/select +2 -0
  274. data/pgpool2/test/jdbc/expected/update +1 -0
  275. data/pgpool2/test/jdbc/pgpool.properties +7 -0
  276. data/pgpool2/test/jdbc/prepare.sql +54 -0
  277. data/pgpool2/test/jdbc/run.sh +6 -0
  278. data/pgpool2/test/parser/.cvsignore +6 -0
  279. data/pgpool2/test/parser/README +32 -0
  280. data/pgpool2/test/parser/expected/copy.out +17 -0
  281. data/pgpool2/test/parser/expected/create.out +64 -0
  282. data/pgpool2/test/parser/expected/cursor.out +37 -0
  283. data/pgpool2/test/parser/expected/delete.out +10 -0
  284. data/pgpool2/test/parser/expected/drop.out +12 -0
  285. data/pgpool2/test/parser/expected/insert.out +13 -0
  286. data/pgpool2/test/parser/expected/misc.out +28 -0
  287. data/pgpool2/test/parser/expected/prepare.out +4 -0
  288. data/pgpool2/test/parser/expected/privileges.out +31 -0
  289. data/pgpool2/test/parser/expected/scanner.out +30 -0
  290. data/pgpool2/test/parser/expected/select.out +89 -0
  291. data/pgpool2/test/parser/expected/transaction.out +38 -0
  292. data/pgpool2/test/parser/expected/update.out +11 -0
  293. data/pgpool2/test/parser/expected/v84.out +37 -0
  294. data/pgpool2/test/parser/expected/v90.out +25 -0
  295. data/pgpool2/test/parser/expected/var.out +22 -0
  296. data/pgpool2/test/parser/input/alter.sql +2 -0
  297. data/pgpool2/test/parser/input/copy.sql +17 -0
  298. data/pgpool2/test/parser/input/create.sql +64 -0
  299. data/pgpool2/test/parser/input/cursor.sql +37 -0
  300. data/pgpool2/test/parser/input/delete.sql +10 -0
  301. data/pgpool2/test/parser/input/drop.sql +12 -0
  302. data/pgpool2/test/parser/input/insert.sql +13 -0
  303. data/pgpool2/test/parser/input/misc.sql +28 -0
  304. data/pgpool2/test/parser/input/prepare.sql +4 -0
  305. data/pgpool2/test/parser/input/privileges.sql +31 -0
  306. data/pgpool2/test/parser/input/scanner.sql +34 -0
  307. data/pgpool2/test/parser/input/select.sql +89 -0
  308. data/pgpool2/test/parser/input/transaction.sql +38 -0
  309. data/pgpool2/test/parser/input/update.sql +11 -0
  310. data/pgpool2/test/parser/input/v84.sql +37 -0
  311. data/pgpool2/test/parser/input/v90.sql +38 -0
  312. data/pgpool2/test/parser/input/var.sql +22 -0
  313. data/pgpool2/test/parser/main.c +96 -0
  314. data/pgpool2/test/parser/parse_schedule +16 -0
  315. data/pgpool2/test/parser/pool.h +13 -0
  316. data/pgpool2/test/parser/run-test +62 -0
  317. data/pgpool2/test/pdo-test/README.euc_jp +58 -0
  318. data/pgpool2/test/pdo-test/SQLlist/test1.sql +3 -0
  319. data/pgpool2/test/pdo-test/SQLlist/test2.sql +3 -0
  320. data/pgpool2/test/pdo-test/collections.inc +11 -0
  321. data/pgpool2/test/pdo-test/def.inc +7 -0
  322. data/pgpool2/test/pdo-test/log.txt +0 -0
  323. data/pgpool2/test/pdo-test/mod/database.inc +36 -0
  324. data/pgpool2/test/pdo-test/mod/def.inc +0 -0
  325. data/pgpool2/test/pdo-test/mod/errorhandler.inc +27 -0
  326. data/pgpool2/test/pdo-test/pdotest.php +11 -0
  327. data/pgpool2/test/pdo-test/regsql.inc +56 -0
  328. data/pgpool2/test/pgpool_setup +898 -0
  329. data/pgpool2/test/regression/README +39 -0
  330. data/pgpool2/test/regression/clean.sh +21 -0
  331. data/pgpool2/test/regression/libs.sh +16 -0
  332. data/pgpool2/test/regression/regress.sh +166 -0
  333. data/pgpool2/test/regression/tests/001.load_balance/test.sh +128 -0
  334. data/pgpool2/test/regression/tests/002.native_replication/PgTester.java +47 -0
  335. data/pgpool2/test/regression/tests/002.native_replication/create.sql +6 -0
  336. data/pgpool2/test/regression/tests/002.native_replication/test.sh +71 -0
  337. data/pgpool2/test/regression/tests/003.failover/expected.r +6 -0
  338. data/pgpool2/test/regression/tests/003.failover/expected.s +6 -0
  339. data/pgpool2/test/regression/tests/003.failover/test.sh +45 -0
  340. data/pgpool2/test/regression/tests/004.watchdog/master.conf +12 -0
  341. data/pgpool2/test/regression/tests/004.watchdog/standby.conf +19 -0
  342. data/pgpool2/test/regression/tests/004.watchdog/test.sh +52 -0
  343. data/pgpool2/test/regression/tests/050.bug58/test.sh +50 -0
  344. data/pgpool2/test/regression/tests/051.bug60/bug.sql +12 -0
  345. data/pgpool2/test/regression/tests/051.bug60/database-clean.sql +6 -0
  346. data/pgpool2/test/regression/tests/051.bug60/database-setup.sql +28 -0
  347. data/pgpool2/test/regression/tests/051.bug60/test.sh +79 -0
  348. data/pgpool2/test/regression/tests/052.do_query/test.sh +44 -0
  349. data/pgpool2/test/regression/tests/053.insert_lock_hangs/test.sh +81 -0
  350. data/pgpool2/test/regression/tests/054.postgres_fdw/test.sh +67 -0
  351. data/pgpool2/test/regression/tests/055.backend_all_down/test.sh +52 -0
  352. data/pgpool2/test/regression/tests/056.bug63/jdbctest2.java +66 -0
  353. data/pgpool2/test/regression/tests/056.bug63/test.sh +47 -0
  354. data/pgpool2/test/regression/tests/057.bug61/test.sh +40 -0
  355. data/pgpool2/test/regression/tests/058.bug68/jdbctest3.java +45 -0
  356. data/pgpool2/test/regression/tests/058.bug68/test.sh +47 -0
  357. data/pgpool2/test/timestamp/expected/insert.out +16 -0
  358. data/pgpool2/test/timestamp/expected/misc.out +3 -0
  359. data/pgpool2/test/timestamp/expected/update.out +6 -0
  360. data/pgpool2/test/timestamp/input/insert.sql +16 -0
  361. data/pgpool2/test/timestamp/input/misc.sql +3 -0
  362. data/pgpool2/test/timestamp/input/update.sql +6 -0
  363. data/pgpool2/test/timestamp/main.c +129 -0
  364. data/pgpool2/test/timestamp/parse_schedule +3 -0
  365. data/pgpool2/test/timestamp/run-test +69 -0
  366. data/pgpool2/version.h +1 -0
  367. data/pgpool2/watchdog/Makefile.am +17 -0
  368. data/pgpool2/watchdog/Makefile.in +505 -0
  369. data/pgpool2/watchdog/test/stab.c +266 -0
  370. data/pgpool2/watchdog/test/test.c +85 -0
  371. data/pgpool2/watchdog/test/wd_child_t.c +87 -0
  372. data/pgpool2/watchdog/test/wd_lifecheck_t.c +87 -0
  373. data/pgpool2/watchdog/test/wd_packet_t.c +87 -0
  374. data/pgpool2/watchdog/test/wd_ping_t.c +20 -0
  375. data/pgpool2/watchdog/watchdog.c +408 -0
  376. data/pgpool2/watchdog/watchdog.h +209 -0
  377. data/pgpool2/watchdog/wd_child.c +444 -0
  378. data/pgpool2/watchdog/wd_ext.h +123 -0
  379. data/pgpool2/watchdog/wd_heartbeat.c +577 -0
  380. data/pgpool2/watchdog/wd_if.c +216 -0
  381. data/pgpool2/watchdog/wd_init.c +126 -0
  382. data/pgpool2/watchdog/wd_interlock.c +347 -0
  383. data/pgpool2/watchdog/wd_lifecheck.c +512 -0
  384. data/pgpool2/watchdog/wd_list.c +429 -0
  385. data/pgpool2/watchdog/wd_packet.c +1159 -0
  386. data/pgpool2/watchdog/wd_ping.c +330 -0
  387. data/pgpool2/ylwrap +223 -0
  388. data/pgsql/presto_client.py +346 -0
  389. data/pgsql/prestogres.py +156 -0
  390. data/pgsql/setup_functions.sql +21 -0
  391. data/pgsql/setup_language.sql +3 -0
  392. data/prestogres.gemspec +23 -0
  393. metadata +496 -0
@@ -0,0 +1,330 @@
1
+ /*
2
+ * $Header$
3
+ *
4
+ * Handles watchdog connection, and protocol communication with pgpool-II
5
+ *
6
+ * pgpool: a language independent connection pool server for PostgreSQL
7
+ * written by Tatsuo Ishii
8
+ *
9
+ * Copyright (c) 2003-2013 PgPool Global Development Group
10
+ *
11
+ * Permission to use, copy, modify, and distribute this software and
12
+ * its documentation for any purpose and without fee is hereby
13
+ * granted, provided that the above copyright notice appear in all
14
+ * copies and that both that copyright notice and this permission
15
+ * notice appear in supporting documentation, and that the name of the
16
+ * author not be used in advertising or publicity pertaining to
17
+ * distribution of the software without specific, written prior
18
+ * permission. The author makes no representations about the
19
+ * suitability of this software for any purpose. It is provided "as
20
+ * is" without express or implied warranty.
21
+ *
22
+ */
23
+
24
+ #include <pthread.h>
25
+ #include <stdio.h>
26
+ #include <errno.h>
27
+ #include <string.h>
28
+ #include <stdlib.h>
29
+ #include <unistd.h>
30
+ #include <netdb.h>
31
+ #include <sys/wait.h>
32
+ #include <sys/stat.h>
33
+ #include <errno.h>
34
+ #include "pool.h"
35
+ #include "pool_config.h"
36
+ #include "watchdog.h"
37
+
38
+ #define WD_MAX_PING_RESULT 256
39
+
40
+ int wd_is_upper_ok(char * server_list);
41
+ int wd_is_unused_ip(char * ip);
42
+
43
+ static void * exec_ping(void * arg);
44
+ static double get_result (char * ping_data);
45
+
46
+ /**
47
+ * Try to connect to trusted servers.
48
+ */
49
+ int
50
+ wd_is_upper_ok(char * server_list)
51
+ {
52
+ pthread_attr_t attr;
53
+ char * buf;
54
+ int rc = 0;
55
+ int i,cnt;
56
+ int len;
57
+ pthread_t thread[MAX_WATCHDOG_NUM];
58
+ WdInfo thread_arg[MAX_WATCHDOG_NUM];
59
+
60
+ char * bp, *ep;
61
+ int rtn = WD_NG;
62
+
63
+ if (server_list == NULL)
64
+ {
65
+ pool_error("wd_is_upper_ok: server_list is NULL");
66
+ return WD_NG;
67
+ }
68
+ len = strlen(server_list)+2;
69
+ buf = malloc(len);
70
+ if (buf == NULL)
71
+ {
72
+ pool_error("wd_is_upper_ok: malloc failed");
73
+ return WD_NG;
74
+ }
75
+
76
+ memset(buf,0,len);
77
+ strlcpy(buf,server_list,len);
78
+ /* thread init */
79
+ pthread_attr_init(&attr);
80
+ pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_JOINABLE);
81
+ /* set hostname as a thread_arg */
82
+ bp = buf;
83
+ cnt = 0;
84
+ while (*bp != '\0')
85
+ {
86
+ ep = strchr(bp,',');
87
+ if (ep != NULL)
88
+ {
89
+ *ep = '\0';
90
+ }
91
+ strlcpy(thread_arg[cnt].hostname,bp,sizeof(thread_arg[cnt].hostname));
92
+ rc = pthread_create(&thread[cnt], &attr, exec_ping, (void*)&thread_arg[cnt]);
93
+
94
+ cnt ++;
95
+ if (ep != NULL)
96
+ {
97
+ bp = ep + 1;
98
+ }
99
+ else
100
+ {
101
+ break;
102
+ }
103
+ if (cnt >= MAX_WATCHDOG_NUM)
104
+ {
105
+ pool_debug("wd_is_upper_ok: trusted server num is out of range(%d)",cnt);
106
+ break;
107
+ }
108
+ }
109
+ pthread_attr_destroy(&attr);
110
+ for (i=0; i <cnt; )
111
+ {
112
+ int result;
113
+ rc = pthread_join(thread[i], (void **)&result);
114
+ if ((rc != 0) && (errno == EINTR))
115
+ {
116
+ usleep(100);
117
+ continue;
118
+ }
119
+ if (result == WD_OK)
120
+ {
121
+ rtn = WD_OK;
122
+ }
123
+ i++;
124
+ }
125
+ free(buf);
126
+ return rtn;
127
+ }
128
+
129
+ /**
130
+ * check if IP address is unused.
131
+ */
132
+ int
133
+ wd_is_unused_ip(char * ip)
134
+ {
135
+ pthread_attr_t attr;
136
+ int rc = 0;
137
+ pthread_t thread;
138
+ WdInfo thread_arg;
139
+
140
+ int rtn = WD_NG;
141
+ int result;
142
+
143
+ if (ip == NULL)
144
+ {
145
+ return WD_NG;
146
+ }
147
+
148
+ /* thread init */
149
+ pthread_attr_init(&attr);
150
+ pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_JOINABLE);
151
+
152
+ /* set hostname as a thread_arg */
153
+ strlcpy(thread_arg.hostname,ip,sizeof(thread_arg.hostname));
154
+
155
+ rc = pthread_create(&thread, &attr, exec_ping, (void*)&thread_arg);
156
+ pthread_attr_destroy(&attr);
157
+
158
+ rc = pthread_join(thread, (void **)&result);
159
+ if ((rc != 0) && (errno == EINTR))
160
+ {
161
+ return WD_NG;
162
+ }
163
+ if (result == WD_NG)
164
+ {
165
+ rtn = WD_OK;
166
+ }
167
+
168
+ return rtn;
169
+ }
170
+
171
+
172
+ /**
173
+ * Thread to execute ping against "trusted hosts" or delegate IP.
174
+ */
175
+ static void *
176
+ exec_ping(void * arg)
177
+ {
178
+ WdInfo * thread_arg;
179
+ uintptr_t rtn = (uintptr_t)WD_NG;
180
+ int pfd[2];
181
+ int status;
182
+ char * args[8];
183
+ int pid, i = 0;
184
+ int r_size = 0;
185
+ char result[WD_MAX_PING_RESULT];
186
+ char ping_path[WD_MAX_PATH_LEN];
187
+
188
+ snprintf(ping_path,sizeof(ping_path),"%s/ping",pool_config->ping_path);
189
+ thread_arg = (WdInfo *)arg;
190
+ memset(result,0,sizeof(result));
191
+
192
+ if (pipe(pfd) == -1)
193
+ {
194
+ pool_error("exec_ping: pipe open error:%s", strerror(errno));
195
+ return WD_NG;
196
+ }
197
+
198
+ args[i++] = "ping";
199
+ args[i++] = "-q";
200
+ args[i++] = "-c3";
201
+ args[i++] = thread_arg->hostname;
202
+ args[i++] = NULL;
203
+
204
+ pid = fork();
205
+ if (pid == -1)
206
+ {
207
+ pool_error("exec_ping: fork() failed. reason: %s", strerror(errno));
208
+ exit(1);
209
+ }
210
+ if (pid == 0)
211
+ {
212
+ close(STDOUT_FILENO);
213
+ dup2(pfd[1], STDOUT_FILENO);
214
+ close(pfd[0]);
215
+ status = execv(ping_path,args);
216
+
217
+ if (status == -1)
218
+ {
219
+ pool_error("exec_ping: execv(%s) failed. reason: %s", ping_path, strerror(errno));
220
+ exit(1);
221
+ }
222
+ exit(0);
223
+ }
224
+ else
225
+ {
226
+ close(pfd[1]);
227
+ for (;;)
228
+ {
229
+ int r;
230
+ r = wait(&status);
231
+ if (r < 0)
232
+ {
233
+ if (errno == EINTR)
234
+ continue;
235
+
236
+ pool_error("exec_ping: wait() failed. reason: %s", strerror(errno));
237
+ close(pfd[0]);
238
+ return WD_NG;
239
+ }
240
+
241
+ if (WIFEXITED(status) == 0)
242
+ {
243
+ pool_error("exec_ping: %s exited abnormally", ping_path);
244
+ close(pfd[0]);
245
+ return WD_NG;
246
+ }
247
+ else if (WEXITSTATUS(status) != 0)
248
+ {
249
+ pool_debug("exec_ping: failed to ping %s", thread_arg->hostname);
250
+ return WD_NG;
251
+ }
252
+ else
253
+ {
254
+ pool_debug("exec_ping: succeed to ping %s", thread_arg->hostname);
255
+ break;
256
+ }
257
+ }
258
+
259
+ i = 0;
260
+ while (( (r_size = read (pfd[0], &result[i], sizeof(result)-i-1)) > 0) && (errno == EINTR))
261
+ {
262
+ i += r_size;
263
+ }
264
+ result[sizeof(result)-1] = '\0';
265
+
266
+ close(pfd[0]);
267
+ }
268
+
269
+ /* Check whether average RTT >= 0 */
270
+ rtn = (get_result (result) >= 0) ? WD_OK : WD_NG;
271
+
272
+ pthread_exit((void *)rtn);
273
+ }
274
+
275
+ /**
276
+ * Get average round-trip time of ping result.
277
+ */
278
+ static double
279
+ get_result (char * ping_data)
280
+ {
281
+ char * sp = NULL;
282
+ char * ep = NULL;
283
+ int i;
284
+ double msec = 0;
285
+
286
+ if (ping_data == NULL)
287
+ {
288
+ pool_error("get_result: no ping data");
289
+ return -1;
290
+ }
291
+
292
+ pool_debug("get_result: ping data: %s", ping_data);
293
+
294
+ /*
295
+ skip result until average data
296
+ typical result of ping is as follows,
297
+ "rtt min/avg/max/mdev = 0.045/0.045/0.046/0.006 ms"
298
+ we can find the average data beyond the 4th '/'.
299
+ */
300
+ sp = ping_data;
301
+ for ( i = 0 ; i < 4 ; i ++)
302
+ {
303
+ sp = strchr(sp,'/');
304
+ if (sp == NULL)
305
+ {
306
+ return -1;
307
+ }
308
+ sp ++;
309
+ }
310
+
311
+ ep = strchr (sp,'/');
312
+ if (ep == NULL)
313
+ {
314
+ return -1;
315
+ }
316
+
317
+ *ep = '\0';
318
+ errno = 0;
319
+
320
+ /* convert to numeric data from text */
321
+ msec = strtod(sp,(char **)NULL);
322
+
323
+ if (errno != 0)
324
+ {
325
+ pool_error("get_result: strtod() failed. reason: %s", strerror(errno));
326
+ return -1;
327
+ }
328
+
329
+ return msec;
330
+ }
data/pgpool2/ylwrap ADDED
@@ -0,0 +1,223 @@
1
+ #! /bin/sh
2
+ # ylwrap - wrapper for lex/yacc invocations.
3
+
4
+ scriptversion=2005-05-14.22
5
+
6
+ # Copyright (C) 1996, 1997, 1998, 1999, 2001, 2002, 2003, 2004, 2005
7
+ # Free Software Foundation, Inc.
8
+ #
9
+ # Written by Tom Tromey <tromey@cygnus.com>.
10
+ #
11
+ # This program is free software; you can redistribute it and/or modify
12
+ # it under the terms of the GNU General Public License as published by
13
+ # the Free Software Foundation; either version 2, or (at your option)
14
+ # any later version.
15
+ #
16
+ # This program is distributed in the hope that it will be useful,
17
+ # but WITHOUT ANY WARRANTY; without even the implied warranty of
18
+ # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19
+ # GNU General Public License for more details.
20
+ #
21
+ # You should have received a copy of the GNU General Public License
22
+ # along with this program; if not, write to the Free Software
23
+ # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
24
+ # 02110-1301, USA.
25
+
26
+ # As a special exception to the GNU General Public License, if you
27
+ # distribute this file as part of a program that contains a
28
+ # configuration script generated by Autoconf, you may include it under
29
+ # the same distribution terms that you use for the rest of that program.
30
+
31
+ # This file is maintained in Automake, please report
32
+ # bugs to <bug-automake@gnu.org> or send patches to
33
+ # <automake-patches@gnu.org>.
34
+
35
+ case "$1" in
36
+ '')
37
+ echo "$0: No files given. Try \`$0 --help' for more information." 1>&2
38
+ exit 1
39
+ ;;
40
+ --basedir)
41
+ basedir=$2
42
+ shift 2
43
+ ;;
44
+ -h|--h*)
45
+ cat <<\EOF
46
+ Usage: ylwrap [--help|--version] INPUT [OUTPUT DESIRED]... -- PROGRAM [ARGS]...
47
+
48
+ Wrapper for lex/yacc invocations, renaming files as desired.
49
+
50
+ INPUT is the input file
51
+ OUTPUT is one file PROG generates
52
+ DESIRED is the file we actually want instead of OUTPUT
53
+ PROGRAM is program to run
54
+ ARGS are passed to PROG
55
+
56
+ Any number of OUTPUT,DESIRED pairs may be used.
57
+
58
+ Report bugs to <bug-automake@gnu.org>.
59
+ EOF
60
+ exit $?
61
+ ;;
62
+ -v|--v*)
63
+ echo "ylwrap $scriptversion"
64
+ exit $?
65
+ ;;
66
+ esac
67
+
68
+
69
+ # The input.
70
+ input="$1"
71
+ shift
72
+ case "$input" in
73
+ [\\/]* | ?:[\\/]*)
74
+ # Absolute path; do nothing.
75
+ ;;
76
+ *)
77
+ # Relative path. Make it absolute.
78
+ input="`pwd`/$input"
79
+ ;;
80
+ esac
81
+
82
+ pairlist=
83
+ while test "$#" -ne 0; do
84
+ if test "$1" = "--"; then
85
+ shift
86
+ break
87
+ fi
88
+ pairlist="$pairlist $1"
89
+ shift
90
+ done
91
+
92
+ # The program to run.
93
+ prog="$1"
94
+ shift
95
+ # Make any relative path in $prog absolute.
96
+ case "$prog" in
97
+ [\\/]* | ?:[\\/]*) ;;
98
+ *[\\/]*) prog="`pwd`/$prog" ;;
99
+ esac
100
+
101
+ # FIXME: add hostname here for parallel makes that run commands on
102
+ # other machines. But that might take us over the 14-char limit.
103
+ dirname=ylwrap$$
104
+ trap "cd `pwd`; rm -rf $dirname > /dev/null 2>&1" 1 2 3 15
105
+ mkdir $dirname || exit 1
106
+
107
+ cd $dirname
108
+
109
+ case $# in
110
+ 0) $prog "$input" ;;
111
+ *) $prog "$@" "$input" ;;
112
+ esac
113
+ ret=$?
114
+
115
+ if test $ret -eq 0; then
116
+ set X $pairlist
117
+ shift
118
+ first=yes
119
+ # Since DOS filename conventions don't allow two dots,
120
+ # the DOS version of Bison writes out y_tab.c instead of y.tab.c
121
+ # and y_tab.h instead of y.tab.h. Test to see if this is the case.
122
+ y_tab_nodot="no"
123
+ if test -f y_tab.c || test -f y_tab.h; then
124
+ y_tab_nodot="yes"
125
+ fi
126
+
127
+ # The directory holding the input.
128
+ input_dir=`echo "$input" | sed -e 's,\([\\/]\)[^\\/]*$,\1,'`
129
+ # Quote $INPUT_DIR so we can use it in a regexp.
130
+ # FIXME: really we should care about more than `.' and `\'.
131
+ input_rx=`echo "$input_dir" | sed 's,\\\\,\\\\\\\\,g;s,\\.,\\\\.,g'`
132
+
133
+ while test "$#" -ne 0; do
134
+ from="$1"
135
+ # Handle y_tab.c and y_tab.h output by DOS
136
+ if test $y_tab_nodot = "yes"; then
137
+ if test $from = "y.tab.c"; then
138
+ from="y_tab.c"
139
+ else
140
+ if test $from = "y.tab.h"; then
141
+ from="y_tab.h"
142
+ fi
143
+ fi
144
+ fi
145
+ if test -f "$from"; then
146
+ # If $2 is an absolute path name, then just use that,
147
+ # otherwise prepend `../'.
148
+ case "$2" in
149
+ [\\/]* | ?:[\\/]*) target="$2";;
150
+ *) target="../$2";;
151
+ esac
152
+
153
+ # We do not want to overwrite a header file if it hasn't
154
+ # changed. This avoid useless recompilations. However the
155
+ # parser itself (the first file) should always be updated,
156
+ # because it is the destination of the .y.c rule in the
157
+ # Makefile. Divert the output of all other files to a temporary
158
+ # file so we can compare them to existing versions.
159
+ if test $first = no; then
160
+ realtarget="$target"
161
+ target="tmp-`echo $target | sed s/.*[\\/]//g`"
162
+ fi
163
+ # Edit out `#line' or `#' directives.
164
+ #
165
+ # We don't want the resulting debug information to point at
166
+ # an absolute srcdir; it is better for it to just mention the
167
+ # .y file with no path.
168
+ #
169
+ # We want to use the real output file name, not yy.lex.c for
170
+ # instance.
171
+ #
172
+ # We want the include guards to be adjusted too.
173
+ FROM=`echo "$from" | sed \
174
+ -e 'y/abcdefghijklmnopqrstuvwxyz/ABCDEFGHIJKLMNOPQRSTUVWXYZ/'\
175
+ -e 's/[^ABCDEFGHIJKLMNOPQRSTUVWXYZ]/_/g'`
176
+ TARGET=`echo "$2" | sed \
177
+ -e 'y/abcdefghijklmnopqrstuvwxyz/ABCDEFGHIJKLMNOPQRSTUVWXYZ/'\
178
+ -e 's/[^ABCDEFGHIJKLMNOPQRSTUVWXYZ]/_/g'`
179
+
180
+ sed -e "/^#/!b" -e "s,$input_rx,," -e "s,$from,$2," \
181
+ -e "s,$FROM,$TARGET," "$from" >"$target" || ret=$?
182
+
183
+ # Check whether header files must be updated.
184
+ if test $first = no; then
185
+ if test -f "$realtarget" && cmp -s "$realtarget" "$target"; then
186
+ echo "$2" is unchanged
187
+ rm -f "$target"
188
+ else
189
+ echo updating "$2"
190
+ mv -f "$target" "$realtarget"
191
+ fi
192
+ fi
193
+ else
194
+ # A missing file is only an error for the first file. This
195
+ # is a blatant hack to let us support using "yacc -d". If -d
196
+ # is not specified, we don't want an error when the header
197
+ # file is "missing".
198
+ if test $first = yes; then
199
+ ret=1
200
+ fi
201
+ fi
202
+ shift
203
+ shift
204
+ first=no
205
+ done
206
+ else
207
+ ret=$?
208
+ fi
209
+
210
+ # Remove the directory.
211
+ cd ..
212
+ rm -rf $dirname
213
+
214
+ exit $ret
215
+
216
+ # Local Variables:
217
+ # mode: shell-script
218
+ # sh-indentation: 2
219
+ # eval: (add-hook 'write-file-hooks 'time-stamp)
220
+ # time-stamp-start: "scriptversion="
221
+ # time-stamp-format: "%:y-%02m-%02d.%02H"
222
+ # time-stamp-end: "$"
223
+ # End: