class PostgresXc < Formula
desc "PostgreSQL cluster based on shared-nothing architecture"
homepage "https://sourceforge.net/p/postgres-xc/xc-wiki/Main_Page/"
url "https://downloads.sourceforge.net/project/postgres-xc/Version_1.0/pgxc-v1.0.4.tar.gz"
sha256 "b467cbb7d562a8545645182958efd1608799ed4e04a9c3906211878d477b29c1"
revision 2
bottle do
sha256 "ebd62d467b624fa9c5e39360a04f2b2a270ce8ae5d4c01783c8237f203c6d332" => :mojave
sha256 "dc801fc18cb3371ae85ba61569a403b9b49855ea80696518baebc945a43a794f" => :high_sierra
end
depends_on :arch => :x86_64
depends_on "openssl"
depends_on "ossp-uuid"
depends_on "readline"
conflicts_with "postgresql",
:because => "postgres-xc and postgresql install the same binaries."
# Fix PL/Python build: https://github.com/Homebrew/homebrew/issues/11162
patch :DATA
def install
# Fix uuid-ossp build issues: https://www.postgresql.org/message-id/05843630-E25D-442A-A6B0-5CA63622A400@likeness.com
ENV.append_to_cflags "-D_XOPEN_SOURCE"
# See https://sourceforge.net/p/postgres-xc/mailman/postgres-xc-bugs/thread/82E44F89-543A-44F2-8AF8-F6909B5DC561@uniud.it/
ENV.append "CFLAGS", "-D_FORTIFY_SOURCE=0 -O2"
ENV.prepend "LDFLAGS", "-L#{Formula["openssl"].opt_lib} -L#{Formula["readline"].opt_lib}"
ENV.prepend "CPPFLAGS", "-I#{Formula["openssl"].opt_include} -I#{Formula["readline"].opt_include}"
ENV.append "CFLAGS", `uuid-config --cflags`.strip
ENV.append "LDFLAGS", `uuid-config --ldflags`.strip
ENV.append "LIBS", `uuid-config --libs`.strip
args = [
"--disable-debug",
"--prefix=#{prefix}",
"--datadir=#{pkgshare}",
"--docdir=#{doc}",
"--enable-thread-safety",
"--with-bonjour",
"--with-gssapi",
"--with-krb5",
"--with-libxml",
"--with-libxslt",
"--with-openssl",
"--with-ossp-uuid",
"ARCHFLAGS=-arch x86_64",
]
system "./configure", *args
# Building the documentation looks for Jade or OpenJade, neither of which exist on macOS
# or are supplied by Homebrew at this point in time. Disable for now, since error fatal.
inreplace "GNUmakefile", "recurse,install-world,doc-xc src", "recurse,install-world,src"
system "make", "install-world"
plist_path("gtm").write gtm_startup_plist("gtm")
plist_path("gtm").chmod 0644
plist_path("gtm_proxy").write gtm_proxy_startup_plist("gtm_proxy")
plist_path("gtm_proxy").chmod 0644
plist_path("coord").write coordinator_startup_plist("coord")
plist_path("coord").chmod 0644
plist_path("datanode").write datanode_startup_plist("datanode")
plist_path("datanode").chmod 0644
end
def post_install
(var/"postgres-xc").mkpath
end
def caveats; <<~EOS
To get started with Postgres-XC, read the documents at
https://sourceforge.net/projects/postgres-xc/files/Publication/
https://postgres-xc.sourceforge.io/docs/1_0/tutorial-start.html
For a first cluster, you may start with a single GTM (Global Transaction Manager),
a pair of Data Nodes and a single Coordinator, all on the same machine:
initgtm -Z gtm -D #{var}/postgres-xc/gtm
initdb -D #{var}/postgres-xc/datanode1 --nodename datanode1
initdb -D #{var}/postgres-xc/datanode2 --nodename datanode2
initdb -D #{var}/postgres-xc/coord --nodename coord
Then edit:
#{var}/postgres-xc/datanode1/postgresql.conf
#{var}/postgres-xc/datanode2/postgresql.conf
and change the port to 15432 and 15433, respectively.
Then, launch the nodes and connect to the coordinator:
gtm -D #{var}/postgres-xc/gtm -l #{var}/postgres-xc/gtm/server.log &
postgres -i -X -D #{var}/postgres-xc/datanode1 -r #{var}/postgres-xc/datanode1/server.log &
postgres -i -X -D #{var}/postgres-xc/datanode2 -r #{var}/postgres-xc/datanode2/server.log &
postgres -i -C -D #{var}/postgres-xc/coord -r #{var}/postgres-xc/coord/server.log &
psql postgres
create node datanode1 with (type='datanode', port=15432);
create node datanode2 with (type='datanode', port=15433);
select * from pgxc_node;
select pgxc_pool_reload();
To shutdown everything, kill the processes in reverse order:
kill -SIGTERM `head -1 #{var}/postgres-xc/coord/postmaster.pid`
kill -SIGTERM `head -1 #{var}/postgres-xc/datanode1/postmaster.pid`
kill -SIGTERM `head -1 #{var}/postgres-xc/datanode2/postmaster.pid`
kill -SIGTERM `head -1 #{var}/postgres-xc/gtm/gtm.pid`
If you get the following error:
FATAL: could not create shared memory segment: Cannot allocate memory
then you need to tweak your system's shared memory parameters:
https://www.postgresql.org/docs/current/static/kernel-resources.html#SYSVIPC
EOS
end
plist_options :startup => true
# Override Formula#plist_name
def plist_name(extra = nil)
extra ? super()+"-"+extra : super()+"-gtm"
end
# Override Formula#plist_path
def plist_path(extra = nil)
extra ? super().dirname+(plist_name(extra)+".plist") : super()
end
def gtm_startup_plist(name); <<~EOS
KeepAlive
Label
#{plist_name(name)}
ProgramArguments
#{opt_bin}/gtm
-D
#{var}/postgres-xc/#{name}
-l
#{var}/postgres-xc/#{name}/server.log
RunAtLoad
WorkingDirectory
#{HOMEBREW_PREFIX}
StandardErrorPath
#{var}/postgres-xc/#{name}/server.log
EOS
end
def gtm_proxy_startup_plist(name); <<~EOS
KeepAlive
Label
#{plist_name(name)}
ProgramArguments
#{opt_bin}/gtm_proxy
-D
#{var}/postgres-xc/#{name}
-n
2
-s
localhost
-t
6666
-l
#{var}/postgres-xc/#{name}/server.log
RunAtLoad
WorkingDirectory
#{HOMEBREW_PREFIX}
StandardErrorPath
#{var}/postgres-xc/#{name}/server.log
EOS
end
def coordinator_startup_plist(name); <<~EOS
KeepAlive
Label
#{plist_name(name)}
ProgramArguments
#{opt_bin}/postgres
-i
-C
-D
#{var}/postgres-xc/#{name}
-r
#{var}/postgres-xc/#{name}/server.log
RunAtLoad
WorkingDirectory
#{HOMEBREW_PREFIX}
StandardErrorPath
#{var}/postgres-xc/#{name}/server.log
EOS
end
def datanode_startup_plist(name); <<~EOS
KeepAlive
Label
#{plist_name(name)}
ProgramArguments
#{opt_bin}/postgres
-i
-X
-D
#{var}/postgres-xc/#{name}
-r
#{var}/postgres-xc/#{name}/server.log
RunAtLoad
WorkingDirectory
#{HOMEBREW_PREFIX}
StandardErrorPath
#{var}/postgres-xc/#{name}/server.log
EOS
end
test do
system "#{bin}/initdb", "--nodename=brew", testpath/"test"
assert_predicate testpath/"test", :exist?
end
end
__END__
--- a/src/pl/plpython/Makefile 2011-09-23 08:03:52.000000000 +1000
+++ b/src/pl/plpython/Makefile 2011-10-26 21:43:40.000000000 +1100
@@ -24,8 +24,6 @@
# Darwin (OS X) has its own ideas about how to do this.
ifeq ($(PORTNAME), darwin)
shared_libpython = yes
-override python_libspec = -framework Python
-override python_additional_libs =
endif
# If we don't have a shared library and the platform doesn't allow it