I installed node using homebrew (Mojave), afterwards php stoped working and if I try to run php -v
I get this error:
php -v
dyld: Library not loaded: /usr/local/opt/icu4c/lib/libicui18n.62.dylib
Referenced from: /usr/local/bin/php
Reason: image not found
I tried to uninstall both node and icu4c but the problem persists
/usr/local/opt/icu4c
didn't exist, and brew reinstall icu4c
gave me a bunch of "permission denied" issues for the icu4c dir. So I sudo rm -rf /usr/local/Cellar/icu4c
and brew reinstall icu4c
, and everything worked.
Update - As stated in some of the comments, running brew cleanup could possibly fix this error, if that alone doesn't fix it, you might try upgrading individual packages or all your brew packages.
I just had this same problem. Upgrading Homebrew and then cleaning up worked for me. This error likely showed up for me because of a mismatch in package versions. None of the above solutions resolved my error, but running the following homebrew commands did.
Caution - This will upgrade all your brew packages, including, but not limited to PHP. If you only want to upgrade specific packages make sure to be specific.
brew upgrade icu4c
brew upgrade // or upgrade all packages
and finally
brew cleanup
In my case, that happened because icu4c was upgraded to version 63 but my locally installed postgres image still referenced icu4c 62.1. Therefore I had to change the icu4c version used:
brew info icu4c
brew switch icu4c <version>
Where version
is the installed version returned by info
.
brew list icu4c
showed a files from /usr/local/Cellar/icu4c/63.1
. brew switch icu4c 63.1
fixed it for me.
brew switch icu4c 63.1
but still getting the same error in the logs, even after restarting postgres. Not sure what to do next...
brew reinstall postgres
and that seemed to solve my problems
brew switch
command is brew link
I am actually quite surprised that this solution has not been presented yet, and I feel like it is the easiest solution.
Go to GitHub, find the version of the brewfile that matches the version of icu4c
that you need and get the raw version of the file (follow the links above and click View File
then Raw
).
Then just have brew reinstall from that url.
For example, version 62.1
:
brew reinstall https://raw.githubusercontent.com/Homebrew/homebrew-core/575eb4bbef683551e19f329f60456b13a558132f/Formula/icu4c.rb
For example, version 64.2
:
brew reinstall https://raw.githubusercontent.com/Homebrew/homebrew-core/a806a621ed3722fb580a58000fb274a2f2d86a6d/Formula/icu4c.rb
UPDATE:
Later versions of Homebrew may require you to download the file first. If this is the case:
wget https://raw.githubusercontent.com/Homebrew/homebrew-core/a806a621ed3722fb580a58000fb274a2f2d86a6d/Formula/icu4c.rb
brew reinstall icu4c.rb
dyld: Library not loaded: /usr/local/opt/icu4c/lib/libicui18n.64.dylib
this command fixed it: brew reinstall https://raw.githubusercontent.com/Homebrew/homebrew-core/a806a621ed3722fb580a58000fb274a2f2d86a6d/Formula/icu4c.rb
brew upgrade
to install latest version of icu4c 4)Copy saved dir in to the /usr/local/Cellar/icu4c/ 5)Now you can switch between versions: brew switch icu4c 64.2
brew reinstall https://raw.githubusercontent.com/Homebrew/homebrew-core/22fb699a417093cd1440857134c530f1e3794f7d/Formula/icu4c.rb
brew extract
brew reinstall icu4c.rb
Turns out I, like @Grey Black, had to actually install v62.1 of icu4c. Nothing else worked.
However, brew switch icu4c 62.1
only works if you have installed 62.1 in the past. If you haven't there's more legwork involved. Homebrew does not make it easy to install previous versions of formulae.
Here's how I did it:
We first need a deep clone of the Homebrew repo. This may take a while: git -C $(brew --repo homebrew/core) fetch --unshallow brew log icu4c to track down a commit that references 62.1; 575eb4b does the trick. cd $(brew --repo homebrew/core) git checkout 575eb4b -- Formula/icu4c.rb brew uninstall --ignore-dependencies icu4c brew install icu4c You should now have the correct version of the dependency! Now just to... git reset && git checkout . Cleanup your modified recipe. brew pin icu4c Pin the dependency to prevent it from being accidentally upgraded in the future
If you decide you do want to upgrade it at some point, make sure to run brew unpin icu4c
git -C (brew --repo homebrew/core) fetch --unshallow
to make sure you have a full brew git history.
icu4c
. Neither updating, upgrading brew worked, nor reinstalling, relinking, building php from source.
git checkout bc0c97952453ff6afc146aa3a706e9902aba4300 -- Formula/icu4c.rb
and then brew switch 63.1
==> Downloading https://ghcr.io/v2/homebrew/core/icu4c/manifests/67.1 #=#=-# # curl: (22) The requested URL returned error: 404 Error: Failed to download resource "icu4c_bottle_manifest" Download failed: https://ghcr.io/v2/homebrew/core/icu4c/manifests/67.1
when I tried to get version 67.1
with github.com/Homebrew/homebrew-core/commit/….
brew
has moved on. The command structure has changed and the format of the "formula" has too. I got past the format by editing the ruby to suit the new format. It doesn't help me though becuase, as @bluepanda said, https://ghcr.io/v2/homebrew/core/icu4c/manifests/64.2
is gone. I did find an alternative formula though, and it did work for me: gist.github.com/bbatsche/c1c747bb9297661772ae7e106c556c3f. I used wget
to pull the file and then brew reinstall Icu4c@64.rb
followed by brew link Icu4c@64
. I'll now retire to the simplicity of my archlinux box :)
Run npm version
, if you see the same error, upgrade npm.
brew upgrade npm
.
==> Upgrading 1 outdated package, with result:
npm 8.1.2 -> 10.3.0
==> Upgrading npm
==> Installing dependencies for node: icu4c
==> Installing node dependency: icu4c
I had the same problem after I upgraded my macOS
to version 10.13.6
. I can't run composer
and php
commands. After researching for a while and trying various solutions posted online, reinstalling php using homebrew
worked.
brew reinstall php@7.1
Added on March 14th based on Ryan's comment
get the version you are currently using by running php -v
and get the right formulae (which you can find here: https://formulae.brew.sh/formula/php) to replace @7.1
in the above command.
node
after upgrading macOS to 10.14.2
, brew reinstall node
was the ticket for me too
brew upgrade
fixed it for me.
brew reinstall php
may end up installing a different version to the current one. You may have to specify the version using php@7.1
php -v
if your php is broken :p
echo $PATH
(if you have php
, you should see something like this: /usr/local/opt/php@7.2/bin
) this is one way to find out what versions are currently being used.
This fixed it for me:
brew upgrade node
/icu4c/lib/libicui18n.66.dylib
error suddenly occurred when I was running rspec. I stashed my handful of code changes, error still showed up. upgrading node fixed the problem! Thank you!
For me the solution was to:
brew reinstall icu4c
Then
gem uninstall charlock_holmes
gem install charlock_holmes
Seems like it is impossible to link icu4c
using brew
after latest OS X update. Which makes things more interesting. The only solution I found working for me:
Download and compile icu4c 62.1 to /usr/local/icu4c/62.1
mkdir ~/sources
cd ~/sources
wget http://download.icu-project.org/files/icu4c/62.1/icu4c-62_1-src.tgz
tar xvzf icu4c-62_1-src.tgz
cd icu/source/
sudo mkdir /usr/local/icu4c/62.1
./configure --prefix=/usr/local/icu4c/62.1
make
sudo make install
Link libs:
ln -s /usr/local/icu4c/62.1/lib/*.dylib /usr/local/include/
Set DYLD_LIBRARY_PATH in ~/.bash_profile:
export DYLD_LIBRARY_PATH=/usr/local/include
I actually tried all of the solutions which made sense, mentioned in this post and yet i still got the same error when running php -v
or composer
. The node version was fine, npm as well there were no issues on having installed correct versions and they were all running. Running reinstall php@7.1
just threw an error. In the end i had to run:
brew reinstall icu4c
This basically worked, with me having to manually then install php dependencies such as imagick.so
, imap.so
As these libraries were installed for a project that i no longer maintain i can go without them. But if you do have dependancies on them, have in mind that there will be more work to do afterwards.
npm install
wasn't working after my work macbook force updated to Catalina last week. Found here originally: gist.github.com/berkedel/d1fc6d13651c16002f64653096d1fded
Just brew remove php
and brew install php
did not work, nor did brew reinstall php
. My solution was to do:
brew remove php
cd /usr/local/Cellar
rm -rf php/
brew install php
brew doctor
brew cleanup
Now php -v
gives me:
PHP 7.3.2 (cli) (built: Feb 14 2019 10:08:45) ( NTS )
my issue:
# npm install -g canvas
dyld: Library not loaded: /usr/local/opt/icu4c/lib/libicui18n.64.dylib
Referenced from: /usr/local/opt/node@8/bin/node
Reason: image not found
for now 20210118, after many try:
...
brew reinstall https://raw.githubusercontent.com/Homebrew/homebrew-core/master/Formula/icu4c.rb
brew upgrade npm
brew install node
brew uninstall --ignore-dependencies node@8 icu4c
brew install icu4c
...
Final worked solution is:
brew reinstall npm
brew reinstall npm
command solved my problem
Actually, I found the solution directly on homebrew page: https://docs.brew.sh/Common-Issues
Upgrading macOS can cause errors like the following:
dyld: Library not loaded: /usr/local/opt/icu4c/lib/libicui18n.54.dylib configure: error: Cannot find libz
Following a macOS upgrade it may be necessary to reinstall the Xcode Command Line Tools and brew upgrade all installed formula:
xcode-select --install
brew upgrade
In my case the problem wasn't related to upgrading OS, but the solution worked nicely.
2021-02 Easy solution
After years of dealing with this problem the following, surprisingly easy, solution worked for me:
Open the raw file in your web browser of the version you need:
Latest version: https://raw.githubusercontent.com/Homebrew/homebrew-core/master/Formula/icu4c.rb
Copy paste the contents into a new file named: icu4c.rb Run the following on the newly created file: brew reinstall icu4c.rb
Source: https://gist.github.com/hgrimelid/703691ab48c4a4d0537cfe835b4d55a6
For me brew reinstall nodejs
fixed this - my issue was with running Elixir/Phoenix so not PHP specific, I think it was caused by brew install postgres
, but reinstalling that didn't help. I was getting it from npm
commands.
In order to downgrade, i had to recompile from source (MacOS Mojave)
$ wget https://ssl.icu-project.org/files/icu4c/62.1/icu4c-62_1-src.tgz
$ tar xvfz icu4c-62_1-src.tgz
$ cd icu/sources
$ ./configure
$ make
$ make install
brew update && brew upgrade
worked for me
This is what finally worked for me.
brew reinstall postgres
After running the above command you might need to run
brew postgresql-upgrade-database
to access your previous data.
i followed this article here and this seems to be the missing piece of the puzzle for me:
brew uninstall node@8
brew remove node && brew install node
Rather than install an old version of icu4c
that the older (precompiled) php can link to, it's better to recompile the old php to link to the more recent library.
brew uninstall php@7.2
brew install --build-from-source php@7.2
This will build php and link it to the newer library. I found reinstall
didn't quite work; the new install choked when the destination folder already existed.
I also did brew link --force php@7.2
for my environment.
brew switch icu4c 62.1
command worked for me, however.
I had problems because my version of PHP (7.3) was expecting icu4c 63 and brew would only install 64.
https://stackoverflow.com/a/55828190/2000947 helped me install 63.
On MacOS Mojave, only way I could fix it was with brew upgrade
On OSX 10.15.4 running xcode-select --install
fixed the issue for me.
Leland's answer worked for me, but I had to change steps 4 and 6 to:
4) git checkout -B icu4c-62.1 575eb4b
6) brew reinstall Formula/icu4c.rb
The solution in this gist did it for me
brew uninstall --ignore-dependencies node icu4c
brew install node
In my case, brew update icu4c to version 67.1 so my php7.1 doesn't work. Just reinstall icu4c, then it fine.
Got this error, too, after installing php 7.3. I had it resolved upgrading just my old php's versions (5.6 and 7.0, not from the official repos).
The maintainers had compiled new php versions against the current icu4c.
In my case, PHP 7 got from 0.31 to 0.33, and the problem was solved.
In my case I had to switch between two versions of icu4c since I still maintain PHP 5.6 projects (which use the old icu4c 64.2). brew install and reinstall from raw .rb links always replaces the previously installed versions for some reason.
#fetching 64.2
brew fetch https://raw.githubusercontent.com/Homebrew/homebrew-core/a806a621ed3722fb580a58000fb274a2f2d86a6d/Formula/icu4c.rb
#fetching stable version
brew fetch https://raw.githubusercontent.com/Homebrew/homebrew-core/master/Formula/icu4c.rb
cd $(brew --cache)/downloads
tar xvfz e2a83648f37dc5193016ce14fa6faeb97460258b214e805b1d7ce8956e83c1a7--icu4c-64.2.catalina.bottle.tar.gz
tar xvfz e045a709e2e21df31e66144a637f0c77dfc154f60183c89e6b04afa2fbda28ba--icu4c-67.1.catalina.bottle.tar.gz
mv -n icu4c/67.1 $(brew --cellar)/icu4c/
mv -n icu4c/64.2 $(brew --cellar)/icu4c/
then switch between versions
$ brew switch icu4c 64.2
Cleaning /usr/local/Cellar/icu4c/64.2
Cleaning /usr/local/Cellar/icu4c/67.1
Opt link created for /usr/local/Cellar/icu4c/64.2
$ brew switch icu4c 67.1
Cleaning /usr/local/Cellar/icu4c/64.2
Cleaning /usr/local/Cellar/icu4c/67.1
Opt link created for /usr/local/Cellar/icu4c/67.1
[2020] edition
For me, it was installing icu4c with the needed version.
If you need to install the old version like version 62, (same steps for else versions), you need to:
Create your own repo (or find someones repo) with this version of brew tap (links are different for every version):
version 62
https://raw.githubusercontent.com/Homebrew/homebrew-core/575eb4bbef683551e19f329f60456b13a558132f/Formula/icu4c.rb
version 64
https://raw.githubusercontent.com/Homebrew/homebrew-core/a806a621ed3722fb580a58000fb274a2f2d86a6d/Formula/icu4c.rb
version 66
https://raw.githubusercontent.com/Homebrew/homebrew-core/22fb699a417093cd1440857134c530f1e3794f7d/Formula/icu4c.rb
version 67
https://raw.githubusercontent.com/Homebrew/homebrew-core/88b9cc789820f2f544d8d4a1053eebb044c2926c/Formula/icu4c.rb
[yourUsername]/homebrew-versions/Formula/ Place downloaded file to 'Formula' folder brew tap [yourUsername]/homebrew-versions brew install [yourUsername]/homebrew-versions/icu4c You got it!
Where [yourUsername] is the name of your GitHub account or person who already have the needed version tap.
Unfortunately, latest homebrew gives no longer a warning and now displays the error: Error: Calling Installation of XXX from a GitHub commit URL is disabled! Use 'brew extract XXX' to stable tap on GitHub instead. So the way to go now is to create a new repo on github called homebrew-versions to host the Formula in a Tap Then initialise it with: brew tap-new MYORG/homebrew-versions after git cloning the homebrew repo as suggested by Shine Hugh, copy paste the raw ruby file to your new Formula. Beware the funny naming convention! Example: File name is: gettext@0.20.2.rb Class name is: GettextAT0202 Example: https://github.com/nedap/homebrew-versions source:https://itnext.io/how-to-install-an-older-brew-package-add141e58d32
I just wanted to leave a detail summary on how to fix this issue at the current moment (this worked for me):
First go to the local installation of homebrew
cd /usr/local/Homebrew/
Homebrew > 2.5 remove the option to install formulas directly from git repos so we need to checkout an older version
git checkout 2.3.0
Install icu4c version (in my case 64.2 was compitable with php@7.1)
HOMEBREW_NO_AUTO_UPDATE=1 brew install https://raw.githubusercontent.com/Homebrew/homebrew-core/a806a621ed3722fb580a58000fb274a2f2d86a6d/Formula/icu4c.rb
Go back to current version of homebrew
git checkout -
Tell brew to use the old version of icu4c this way you can chose wich version to use if you have both intalled
brew switch icu4c 64.2
Success story sharing
brew upgrade
will upgrade all your brew outdated packages, instead, probably only dobrew upgrade npm
or a specific package, not all.