I have installed [email protected] and Postgis via Homebrew. However, installing Postgis via Homebrew installs the latest version of Postgresql at 10 as dependency and pinning Postgresql at 9.6.5 blocks the install of Postgis via Homebrew.
Performing 'CREATE EXTENSION postgis;' returns:
ERROR: could not open extension control file "/usr/local/Cellar/[email protected]/9.6.5/share/[email protected]/extension/postgis.control": No such file or directory
I've also tried uninstalling the Postgresql (at 10) and editing the Postgis formula to depend on [email protected] instead of Postgresql.
This is similar to How to install Postgis to a Keg installation of [email protected] using Homebrew? but with a later keg formula
Installing PEX, a package manager for Postgresql allowed me to install Postgis for the keg version of [email protected] and use CREATE EXTENSION postgis;
This isn't a Homebrew solution but after a lot of searching, it finally allowed me to use Postgis.
I managed to do it after many combinations.
In a nutshell, solution is to install the old version of the original package postgres
, switch to it, and install the old version of postgis
.
1/ Install the current version of postgres
(10.1 as speaking)
brew install postgres
2/ Install the old version of postgres using its old formula. Proper link can be found using github or git log
on the Tap repo (/usr/local/Homebrew/Library/Taps/homebrew/homebrew-core/
).
brew install https://raw.githubusercontent.com/Homebrew/homebrew-core/d014fa223f77bee4b4097c5e80faa0954e28182f/Formula/postgresql.rb
This will install the version 9.6.5 (last one before 10.x series).
3/ Switch to it so links are defaulted to postgres 9.6
brew switch postgres 9.6.5
4/ Install old version of postgis (2.3). This is using the same sha version of the Formula so everything is linked correctly (using the current postgis will expect postgresql 10, so it will end up to a version mismatch when initializing extension).
brew install https://raw.githubusercontent.com/Homebrew/homebrew-core/d014fa223f77bee4b4097c5e80faa0954e28182f/Formula/postgis.rb
5/ If required initialise the DB
initdb /usr/local/var/postgres
6/ Create and use your DB
createdb mydb
psql mydb
mydb=# CREATE EXTENSION postgis;
Hello
I ran into this same problem of multiple implementation of pgsql versions including legacy ones. So after a bit of research I would like to share my solution.
Problem:I am working on a macbook pro 2013 with 10.11 el capitan. I am GIS developer and extensive user of homebrew. I didn't pin the postgresql package for compatibility reasons. Thus, the package got updated to postgresql version 10.5 along other packages. This caused me to be unable to use postgresql version 9.4. The cleverest solution would have been to use a brew switch postgresql 9.4.19
. Except that when compiling postgis 2.5.0 from osgeo/osgeo4mac
it defautls (looks for) the postgresql binary folder to install the symlinked (or not) extensions. Here again another compatibility problem. One could tinker a bit with homebrew files and transfer files manually. That's ill advice...the package manager (homebrew) needs to stay a coherent ecosystem to provide for a stable workspace.
Proposed Solution:
pg9x
; x being the version number (e.g pg95 for postgresql 9.5 and so on...pg9x.env
.profile
with source /your/path/pg9x/pg9x.env
line/your/path/pg9x/
, you'll finde a python script called pgc
, alias it to your .profile
with alias pgc="your/path/pgc"
.profile
and refresh your environment variable with source .profile
on the command promptpgc list
, you'll get a list of installed packages. You'll see the version of postgesql you've downloadedpgc install pg96
pgc install postgis22-pg95
pgc install postgis23-pg96
pgc init pg96
or pgc init postgis23-pg96
etc...pgc status
pgc start pg95
pgc stop pg95
pgc help
for more optionsLet the elephant dance^^
Hope this helps.
Spicy.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With