(Updated 16 May 2020 – after testing with latest DevDesktop 2, built May 13 2020, on macOS High Sierra 10.13.6)
These instructions now refer to PHP 7.3 (which is recommended for Drupal 8, and required for the forthcoming Drupal 9). There is one extra requirement for 7.3 – the entry pcre.jit = 0 in your php.ini, to avoid a JIT Compilation Failed error message. (That’s specific to the memcached extension.)
Other than that, you can change all 3 to 2 in all the instructions if you still want 7.2.
Let’s assume you have the latest Acquia Dev Desktop, which comes with PHP (switchable between 7.0, 7.1, 7.2 and 7.3), and you want to install the PHP memcached extension – so you can use Drupal’s memcache module to make your local development a bit faster (and test for any memcached issues on production).
Memcached v3.1.0 added support for PHP 7.3.
But first…
Why still use Dev Desktop in 2020?
I still use DevDesktop, but only for quickly testing things on a clean Drupal site, and some legacy sites. Otherwise, nowadays I recommend Laravel Valet (you can use it for loads of frameworks/content management systems besides Laravel. It takes care of almost everything, except setting up your MySQL database.)
I don’t recommend Docker. Running PHP and MySQL directly is blisteringly fast compared to Docker for Mac – usually several seconds every page load, and with ADD you can instantly PHP restarts when changing a config setting (e.g. enabling/disabling Xdebug) compared to having to wait a minute or more for a Lando container to rebuild (Docker containers are immutable; you have to rebuild the container to make a significant PHP.ini change like adding or removing an extension – you can’t just restart the service). Composer is faster (still a bit annoying, of course, but consider what it’s doing in the background). Drush is faster, including rebuilding the cache. Over a day, every day, this all really adds up. For those of you using laptops, your battery life will be extended too. (Docker can also use quite a bit of CPU when idle).
Running PHP on the host means you’re directly accessing the file system and not having to jump through all the hoops you do with Docker and Vagrant – either slow file accesses, or having to wait for changes to sync. This is especially true with Drupal given all the caching it does.
It’s very unpopular to criticise Docker (which I’m not, exactly – more the hype and the rush to use it on a platform it wasn’t designed for, despite the slowness issues many people experience.) There’s a trade off between performance and configuration – the assumption seems to be you should go for whatever requires the least configuration, but is it really that hard to install the correct version of PHP or MySQL version (how about making a note of what your site runs in your Git repository?) I’d rather spend a bit longer up front getting the configuration right and have the performance benefit each day after. Also, if I have a choice of what to learn, I think knowledge of PHP extensions and configuration – given I’m a PHP developer – is more useful than learning loads about containers.
Comments welcome by email. (I use Ansible heavily, by the way, so I’m not opposed to automation.)
Install steps:
You need to repeat this once for each version of PHP you want the extension available in, e.g. 7.1 or 7.2. The example below is for 7.3.
Download the extension from here – https://pecl.php.net/package/memcached/3.1.5 – or you can use the quicker get latest link: pecl.php.net/get/memcached
extract the tar file into its own directory – it’s fine if it’s just in your downloads folder (tar -xvf
)
Then, change to that directory and run:
/Applications/DevDesktop/php7_3_x64/bin/phpize
This next line is the important bit – to make it properly compatible with the PHP version DevDesktop is using. Without this you may get an error like:
Symbol not found: _compiler_globals
Expected in: flat namespace
./configure --with-php-config=/Applications/DevDesktop/php7_3_x64/bin/php-config
Tip: modules that don’t successfully load don’t show up in phpinfo(), so a quick way to see what the error was when PHP attempted to load them is to do php -v
(it’ll show any warnings above the version info) or php -m
to get a list of all the extensions loaded and verify yours is OK.
make
make install
Important: if you need to rerun any of these steps, wipe the directory you extracted first and start afresh.
You should see:
Installing shared extensions: /Applications/DevDesktop/php7_3_x64/ext/
There will now be a memcached.so file in that directory. If it hadn’t picked the config details up, it would have written to a different directory, e.g. your default homebrew one.
Add the memcached.so file to your php.ini – you can verify where that is via Preferences > Config in DevDesktop, but it would normally be:
/Applications/DevDesktop/php7_3_x64/bin/php.ini
extension_dir = "/Applications/DevDesktop/php7_2_x64/ext"
extension = memcached.so
pcre.jit = 0
This doesn’t usually get overwritten when upgrading DevDesktop, but you’ll need to go through this process each time you switch to a newer PHP branch. It will take you a few minutes at most.
NB: I rather thought PECL had an equivalent install command line switch to load the correct php-config, so you could just run pecl install command to save time, but apparently not? Let me know if I’m wrong.
Useful reading elsewhere: