First of all you need to download the APC code from the PHP PECL library. So change directory to somewhere like /tmp and then get the latest version like so:
$ wget http://pecl.php.net/get/APC
This will always get the latest version, and in my case when I installed it just now downloaded APC-3.0.16.tgz like so:
Resolving pecl.php.net... 188.8.131.52
Connecting to pecl.php.net|184.108.40.206|:80... connected.
HTTP request sent, awaiting response... 200 OK
Length: 114298 (112K) [application/octet-stream]
Saving to: `APC-3.0.16.tgz'
100%[=====================>] 114,298 97.1K/s in 1.1s
22:58:43 (97.1 KB/s) - `APC-3.0.16.tgz' saved [114298/114298]
So then you need to extract the files:
$ tar -zxf APC-3.0.16.tgz
and change into the APC directory:
$ cd APC-3.0.16
The next step is to run the "phpize" command. This requires that you have PHP development package installed. On CentOS this is php-devel (installed by running "yum install php-devel") and it should have a similar name on other Linux distros.
PHP Api Version: 20041225
Zend Module Api No: 20050922
Zend Extension Api No: 220051025
You then configure APC, telling it where the executable file php-config is. If you don't know where this is, then do this:
$ whereis php-config
which will return something like:
php-config: /usr/bin/php-config /usr/share/man/man1/php-config.1.gz
and then run the configure command like so:
./configure --enable-apc --enable-apc-mmap --with-apxs --with-php-config=/usr/bin/php-config
This will go ahead and do some configuring stuff which will look something like this:
checking for egrep... grep -E
checking for a sed that does not truncate output... /bin/sed
checking dynamic linker characteristics... GNU/Linux ld.so
checking how to hardcode library paths into programs... immediate
configure: creating ./config.status
config.status: creating config.h
Now that configure is done, it's just a matter of running make :
Libraries have been installed in:
If you ever happen to want to link against installed libraries
in a given directory, LIBDIR, you must either use libtool, and
specify the full pathname of the library, or use the `-LLIBDIR'
flag during linking and do at least one of the following:
- add LIBDIR to the `LD_LIBRARY_PATH' environment variable
- add LIBDIR to the `LD_RUN_PATH' environment variable
- use the `-Wl,--rpath -Wl,LIBDIR' linker flag
- have your system administrator add LIBDIR to `/etc/ld.so.conf'
See any operating system documentation about shared libraries for
more information, such as the ld(1) and ld.so(8) manual pages.
(It is safe to ignore warnings about tempnam and tmpnam).
and then make install:
$ make install
Installing shared extensions: /usr/lib64/php/modules/
and restarting the Apache web server:
The APC cache will now be enabled. You can confirm this by creating a script which calls the phpinfo() command and looking for the APC section. It will have been switched on by default by adding a "extension=apc.so" line to your /etc/php.ini file, but you may want to add more settings to configure it more. The INSTALL file suggests this (I have put the default values at the end of each line which is what is set if you don't set anything in the php.ini file):
apc.enabled=1 # default = 1
apc.shm_segments=1 # default = 1
apc.shm_size=128 # default = 30
apc.ttl=7200 # default = 0
apc.user_ttl=7200 # default = 0
apc.num_files_hint=1024 # default = 1000
apc.mmap_file_mask=/tmp/apc.XXXXXX # default = no value
apc.enable_cli=1 # default = 0