class PostgresXc < Formula desc "PostgreSQL cluster based on shared-nothing architecture" homepage "https://postgres-xc.sourceforge.io/" url "https://downloads.sourceforge.net/project/postgres-xc/Version_1.0/pgxc-v1.0.4.tar.gz" sha256 "b467cbb7d562a8545645182958efd1608799ed4e04a9c3906211878d477b29c1" revision 1 bottle do rebuild 1 sha256 "fa227de1722867aadf57d0868bc137a67f30d79b613fbf713396ba846b33f908" => :high_sierra sha256 "9219ea92a221cae45f87c8119afbae22a190c396f41972ab2f8019ede381207d" => :sierra sha256 "8c17e52f8c1171e0a4e36d77180ee5113aa61d35acbe0d11741372d3fe93e9f5" => :el_capitan sha256 "3dc1e2e4d10cc1cf2604b5bc91c4167257bd84b27a167580d2342e7ab7539428" => :yosemite end option "with-dtrace", "Build with DTrace support" option "without-perl", "Build without Perl support" deprecated_option "no-perl" => "without-perl" deprecated_option "enable-dtrace" => "with-dtrace" deprecated_option "with-python" => "with-python@2" depends_on :arch => :x86_64 depends_on "openssl" depends_on "readline" depends_on "ossp-uuid" => :recommended depends_on "python@2" => :optional conflicts_with "postgresql", :because => "postgres-xc and postgresql install the same binaries." fails_with :clang do build 211 cause "Miscompilation resulting in segfault on queries" end # 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" if MacOS.version >= :mavericks 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}" args = %W[ --disable-debug --prefix=#{prefix} --datadir=#{pkgshare} --docdir=#{doc} --enable-thread-safety --with-bonjour --with-gssapi --with-krb5 --with-openssl --with-libxml --with-libxslt ] args << "--with-ossp-uuid" if build.with? "ossp-uuid" args << "--with-python" if build.with? "python@2" args << "--with-perl" if build.with? "perl" args << "--enable-dtrace" if build.with? "dtrace" args << "ARCHFLAGS='-arch x86_64'" if build.with? "ossp-uuid" ENV.append "CFLAGS", `uuid-config --cflags`.strip ENV.append "LDFLAGS", `uuid-config --ldflags`.strip ENV.append "LIBS", `uuid-config --libs`.strip end check_python_arch if build.with? "python@2" 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 check_python_arch # On 64-bit systems, we need to look for a 32-bit Framework Python. # The configure script prefers this Python version, and if it doesn't # have 64-bit support then linking will fail. framework_python = Pathname.new "/Library/Frameworks/Python.framework/Versions/Current/Python" return unless framework_python.exist? unless (archs_for_command framework_python).include? :x86_64 opoo "Detected a framework Python that does not have 64-bit support in:" puts <<~EOS #{framework_python} The configure script seems to prefer this version of Python over any others, so you may experience linker problems as described in: https://osdir.com/ml/pgsql-general/2009-09/msg00160.html To fix this issue, you may need to either delete the version of Python shown above, or move it out of the way before brewing PostgreSQL. Note that a framework Python in /Library/Frameworks/Python.framework is the "MacPython" version, and not the system-provided version which is in: /System/Library/Frameworks/Python.framework EOS end 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