2011-02-11 14:58:45 -08:00
|
|
|
@title Installation Guide
|
2011-05-12 08:15:02 -07:00
|
|
|
@group intro
|
2011-02-11 14:58:45 -08:00
|
|
|
|
|
|
|
This document contains basic install instructions to get Phabricator up and
|
|
|
|
running.
|
|
|
|
|
|
|
|
= Installation Requirements =
|
|
|
|
|
2013-10-25 08:58:42 -07:00
|
|
|
You will need **a computer**. Options include:
|
|
|
|
|
|
|
|
- **A Normal Computer**: This is strongly recommended. Many installs use a VM
|
|
|
|
in EC2. Phabricator installs properly and works well on a normal computer.
|
|
|
|
- **A Shared Host**: This may work, but is not recommended. Many shared
|
|
|
|
hosting environments have restrictions which prevent some of Phabricator's
|
|
|
|
features from working. Consider using a normal computer instead.
|
|
|
|
- **A SAN Appliance, Network Router, Gaming Console, Raspberry Pi, etc.**:
|
|
|
|
Although you may be able to install Phabricator on specialized hardware, it
|
|
|
|
is unlikely to work well and will be difficult for us to support. Strongly
|
|
|
|
consider using a normal computer instead.
|
|
|
|
- **A Toaster, Car, Firearm, Thermostat, etc.**: Yes, many modern devices now
|
|
|
|
have embedded computing capability. We live in interesting times. However,
|
|
|
|
you should not install Phabricator on these devices. Instead, install it on
|
|
|
|
a normal computer.
|
|
|
|
|
2014-03-16 13:00:20 -07:00
|
|
|
To install the Phabricator server software, you will need an **operating
|
|
|
|
system** on your normal computer which is **not Windows**. Note that **the
|
|
|
|
command line interface //does// work on Windows**, and **you can //use//
|
|
|
|
Phabricator from any operating system with a web browser**. However, the server
|
|
|
|
software does not run on Windows. It does run on most other operating systems,
|
|
|
|
so choose one of these instead:
|
2013-10-25 08:58:42 -07:00
|
|
|
|
|
|
|
- **Linux**: Most installs use Linux.
|
|
|
|
- **Mac OS X**: Mac OS X is an acceptable flavor of Linux.
|
|
|
|
- **FreeBSD**: While FreeBSD is certainly not a flavor of Linux, it is a fine
|
|
|
|
operating system possessed of many desirable qualities, and Phabricator will
|
|
|
|
install and run properly on FreeBSD.
|
|
|
|
- **Solaris, etc.**: Other systems which look like Linux and quack like Linux
|
|
|
|
will generally work fine, although we may suffer a reduced ability to
|
|
|
|
support and resolve issues on unusual operating systems.
|
2011-02-11 14:58:45 -08:00
|
|
|
|
2013-10-25 08:58:42 -07:00
|
|
|
Beyond an operating system, you will need **a webserver**.
|
|
|
|
|
|
|
|
- **Apache**: Many installs use Apache + `mod_php`.
|
|
|
|
- **nginx**: Many installs use nginx + `php-fpm`.
|
|
|
|
- **lighttpd**: `lighttpd` is less popular than Apache or nginx, but it
|
|
|
|
works fine.
|
|
|
|
- **Other**: Other webservers which can run PHP are also likely to work fine,
|
|
|
|
although these installation instructions will not cover how to set them up.
|
|
|
|
- **PHP Builtin Server**: You can use the builtin PHP webserver for
|
|
|
|
development or testing, although it should not be used in production.
|
|
|
|
|
|
|
|
You will also need:
|
|
|
|
|
|
|
|
- **MySQL**: You need MySQL.
|
|
|
|
- **PHP**: You need PHP 5.2 or newer.
|
|
|
|
|
|
|
|
You'll probably also need a **domain name**. In particular, you should read this
|
|
|
|
note:
|
|
|
|
|
|
|
|
NOTE: Phabricator must be installed on an entire domain. You can not install it
|
|
|
|
to a path on an existing domain, like `example.com/phabricator/`. Instead,
|
|
|
|
install it to an entire domain or subdomain, like `phabricator.example.com`.
|
2011-02-11 14:58:45 -08:00
|
|
|
|
|
|
|
= Installing Required Components =
|
|
|
|
|
2011-06-12 20:40:50 -07:00
|
|
|
If you are installing on Ubuntu or an RedHat derivative, there are install
|
|
|
|
scripts available which should handle most of the things discussed in this
|
|
|
|
document for you:
|
2011-02-11 14:58:45 -08:00
|
|
|
|
2013-01-04 12:30:47 -08:00
|
|
|
- **RedHat Derivatives**:
|
|
|
|
<http://www.phabricator.com/rsrc/install/install_rhel-derivs.sh>
|
2012-04-09 14:23:10 -07:00
|
|
|
- **Ubuntu**: <http://www.phabricator.com/rsrc/install/install_ubuntu.sh>
|
2011-02-11 14:58:45 -08:00
|
|
|
|
2011-06-12 20:40:50 -07:00
|
|
|
If those work for you, you can skip directly to the
|
|
|
|
@{article:Configuration Guide}. These scripts are also available in the
|
|
|
|
##scripts/install## directory in the project itself.
|
2011-05-08 13:25:39 -07:00
|
|
|
|
2011-06-12 20:40:50 -07:00
|
|
|
Otherwise, here's a general description of what you need to install:
|
2011-05-08 13:25:39 -07:00
|
|
|
|
2011-06-12 20:40:50 -07:00
|
|
|
- git (usually called "git" in package management systems)
|
2012-01-16 16:05:00 -08:00
|
|
|
- Apache (usually "httpd" or "apache2") (or nginx)
|
2011-06-12 20:40:50 -07:00
|
|
|
- MySQL Server (usually "mysqld" or "mysql-server")
|
|
|
|
- PHP (usually "php")
|
2013-01-04 12:30:47 -08:00
|
|
|
- Required PHP extensions: mbstring, iconv, mysql (or mysqli), curl, pcntl
|
|
|
|
(these might be something like "php-mysql" or "php5-mysql")
|
2011-06-12 20:40:50 -07:00
|
|
|
- Optional PHP extensions: gd, apc (special instructions for APC are available
|
2011-06-26 11:21:25 -07:00
|
|
|
below if you have difficulty installing it), xhprof (instructions below,
|
|
|
|
you only need this if you are developing Phabricator)
|
2011-06-12 20:40:50 -07:00
|
|
|
|
|
|
|
If you already have LAMP setup, you've probably already got everything you need.
|
|
|
|
It may also be helpful to refer to the install scripts above, even if they don't
|
|
|
|
work for your system.
|
|
|
|
|
|
|
|
Now that you have all that stuff installed, grab Phabricator and its
|
|
|
|
dependencies:
|
2011-02-11 14:58:45 -08:00
|
|
|
|
|
|
|
$ cd somewhere/ # pick some install directory
|
2014-06-03 09:40:16 -07:00
|
|
|
somewhere/ $ git clone https://github.com/phacility/libphutil.git
|
|
|
|
somewhere/ $ git clone https://github.com/phacility/arcanist.git
|
|
|
|
somewhere/ $ git clone https://github.com/phacility/phabricator.git
|
2011-05-08 13:25:39 -07:00
|
|
|
|
2011-06-13 07:58:02 -07:00
|
|
|
= Installing APC (Optional) =
|
2011-02-11 14:58:45 -08:00
|
|
|
|
|
|
|
Like everything else written in PHP, Phabricator will run much faster with APC
|
|
|
|
installed. You likely need to install "pcre-devel" first:
|
2011-05-08 13:25:39 -07:00
|
|
|
|
2011-02-11 14:58:45 -08:00
|
|
|
sudo yum install pcre-devel
|
2011-05-08 13:25:39 -07:00
|
|
|
|
2011-06-12 20:40:50 -07:00
|
|
|
Then you have two options. Either install via PECL (try this first):
|
2011-02-11 14:58:45 -08:00
|
|
|
|
|
|
|
sudo yum install php-pear
|
|
|
|
sudo pecl install apc
|
2011-05-08 13:25:39 -07:00
|
|
|
|
2011-06-12 20:40:50 -07:00
|
|
|
**If that doesn't work**, grab the package from PECL directly and follow the
|
|
|
|
build instructions there:
|
2011-02-11 14:58:45 -08:00
|
|
|
|
|
|
|
http://pecl.php.net/package/APC
|
2011-05-08 13:25:39 -07:00
|
|
|
|
2011-02-11 14:58:45 -08:00
|
|
|
Installing APC is optional but **strongly recommended**, especially on
|
|
|
|
production hosts.
|
|
|
|
|
|
|
|
Once APC is installed, test that it is available by running:
|
|
|
|
|
|
|
|
php -i | grep apc
|
2011-05-08 13:25:39 -07:00
|
|
|
|
2011-02-11 14:58:45 -08:00
|
|
|
If it doesn't show up, add:
|
|
|
|
|
|
|
|
extension=apc.so
|
2011-05-08 13:25:39 -07:00
|
|
|
|
2011-02-11 14:58:45 -08:00
|
|
|
..to "/etc/php.d/apc.ini" or the "php.ini" file indicated by "php -i".
|
|
|
|
|
2011-06-26 11:21:25 -07:00
|
|
|
= Installing XHProf (Optional) =
|
|
|
|
|
|
|
|
XHProf is a PHP profiling tool. You don't need to install it unless you are
|
|
|
|
developing Phabricator and making performance changes.
|
|
|
|
|
2012-01-09 07:39:25 -08:00
|
|
|
You can install xhprof with:
|
2011-06-26 11:21:25 -07:00
|
|
|
|
2012-01-09 07:39:25 -08:00
|
|
|
$ pecl install xhprof
|
2011-06-26 11:21:25 -07:00
|
|
|
|
2012-01-09 07:39:25 -08:00
|
|
|
If you have a PEAR version prior to 1.9.3, you may run into a `phpize` failure.
|
|
|
|
If so, you can download the source and build it with:
|
|
|
|
|
|
|
|
$ cd extension/
|
|
|
|
$ phpize
|
|
|
|
$ ./configure
|
|
|
|
$ make
|
|
|
|
$ sudo make install
|
|
|
|
|
2012-05-18 17:37:32 -07:00
|
|
|
You may also need to add "##extension=xhprof.so##" to your php.ini.
|
2012-01-09 07:39:25 -08:00
|
|
|
|
|
|
|
See <https://bugs.php.net/bug.php?id=59747> for more information.
|
2011-06-26 11:21:25 -07:00
|
|
|
|
2011-06-29 19:45:12 -07:00
|
|
|
= Updating Phabricator =
|
|
|
|
|
Make SQL patch management DAG-based and provide namespace support
Summary:
This addresses three issues with the current patch management system:
# Two people developing at the same time often pick the same SQL patch number, and then have to go rename it. The system catches this, but it's silly.
# Second/third-party developers can't use the same system to manage auxiliary storage they may want to add.
# There's no way to build mock databases for unit tests that need to do reads.
To resolve these things, you can now name your patches whatever you want and conflicts are just merge conflicts, which are less of a pain to fix than filename conflicts.
Dependencies are now a DAG, with implicit dependencies created on the prior patch if no dependencies are specified. Developers can add new concrete subclasses of `PhabricatorSQLPatchList` to add storage management, and define the dependency branchpoint of their patches so they apply in the correct order (although, generally, they should not depend on the mainline patches, presumably).
The commands `storage upgrade --namespace test1234` and `storage destroy --namespace test1234` will allow unit tests to build and destroy MySQL storage.
A "quickstart" mode allows an upgrade from scratch in ~1200ms. Destruction takes about 200ms. These seem like fairily reasonable costs to actually use in tests. Building from scratch patch-by-patch takes about 6000ms.
Test Plan:
- Created new databases from scratch with and without quickstart in a separate test namespace. Pointed the webapp at the test namespaces, browsed around, everything looked good.
- Compared quickstart and no-quickstart dump states, they're identical except for mysqldump timestamps and a few similar things.
- Upgraded a legacy database to the new storage format.
- Destroyed / dumped storage.
Reviewers: edward, vrana, btrahan, jungejason
Reviewed By: btrahan
CC: aran, nh
Maniphest Tasks: T140, T345
Differential Revision: https://secure.phabricator.com/D2323
2012-04-30 07:54:00 -07:00
|
|
|
Since Phabricator is under active development, you should update frequently. To
|
|
|
|
update Phabricator:
|
|
|
|
|
2013-12-30 16:47:05 -08:00
|
|
|
- Stop the webserver (including `php-fpm`, if you use it).
|
2013-01-22 10:32:26 -08:00
|
|
|
- Run `git pull` in `libphutil/`, `arcanist/` and `phabricator/`.
|
Make SQL patch management DAG-based and provide namespace support
Summary:
This addresses three issues with the current patch management system:
# Two people developing at the same time often pick the same SQL patch number, and then have to go rename it. The system catches this, but it's silly.
# Second/third-party developers can't use the same system to manage auxiliary storage they may want to add.
# There's no way to build mock databases for unit tests that need to do reads.
To resolve these things, you can now name your patches whatever you want and conflicts are just merge conflicts, which are less of a pain to fix than filename conflicts.
Dependencies are now a DAG, with implicit dependencies created on the prior patch if no dependencies are specified. Developers can add new concrete subclasses of `PhabricatorSQLPatchList` to add storage management, and define the dependency branchpoint of their patches so they apply in the correct order (although, generally, they should not depend on the mainline patches, presumably).
The commands `storage upgrade --namespace test1234` and `storage destroy --namespace test1234` will allow unit tests to build and destroy MySQL storage.
A "quickstart" mode allows an upgrade from scratch in ~1200ms. Destruction takes about 200ms. These seem like fairily reasonable costs to actually use in tests. Building from scratch patch-by-patch takes about 6000ms.
Test Plan:
- Created new databases from scratch with and without quickstart in a separate test namespace. Pointed the webapp at the test namespaces, browsed around, everything looked good.
- Compared quickstart and no-quickstart dump states, they're identical except for mysqldump timestamps and a few similar things.
- Upgraded a legacy database to the new storage format.
- Destroyed / dumped storage.
Reviewers: edward, vrana, btrahan, jungejason
Reviewed By: btrahan
CC: aran, nh
Maniphest Tasks: T140, T345
Differential Revision: https://secure.phabricator.com/D2323
2012-04-30 07:54:00 -07:00
|
|
|
- Run `phabricator/bin/storage upgrade`.
|
2013-12-30 16:47:05 -08:00
|
|
|
- Restart the webserver (and `php-fpm`, if you stopped it earlier).
|
Make SQL patch management DAG-based and provide namespace support
Summary:
This addresses three issues with the current patch management system:
# Two people developing at the same time often pick the same SQL patch number, and then have to go rename it. The system catches this, but it's silly.
# Second/third-party developers can't use the same system to manage auxiliary storage they may want to add.
# There's no way to build mock databases for unit tests that need to do reads.
To resolve these things, you can now name your patches whatever you want and conflicts are just merge conflicts, which are less of a pain to fix than filename conflicts.
Dependencies are now a DAG, with implicit dependencies created on the prior patch if no dependencies are specified. Developers can add new concrete subclasses of `PhabricatorSQLPatchList` to add storage management, and define the dependency branchpoint of their patches so they apply in the correct order (although, generally, they should not depend on the mainline patches, presumably).
The commands `storage upgrade --namespace test1234` and `storage destroy --namespace test1234` will allow unit tests to build and destroy MySQL storage.
A "quickstart" mode allows an upgrade from scratch in ~1200ms. Destruction takes about 200ms. These seem like fairily reasonable costs to actually use in tests. Building from scratch patch-by-patch takes about 6000ms.
Test Plan:
- Created new databases from scratch with and without quickstart in a separate test namespace. Pointed the webapp at the test namespaces, browsed around, everything looked good.
- Compared quickstart and no-quickstart dump states, they're identical except for mysqldump timestamps and a few similar things.
- Upgraded a legacy database to the new storage format.
- Destroyed / dumped storage.
Reviewers: edward, vrana, btrahan, jungejason
Reviewed By: btrahan
CC: aran, nh
Maniphest Tasks: T140, T345
Differential Revision: https://secure.phabricator.com/D2323
2012-04-30 07:54:00 -07:00
|
|
|
|
|
|
|
For more details, see @{article:Configuration Guide}. You can use a script
|
|
|
|
similar to this one to automate the process:
|
2011-06-29 19:45:12 -07:00
|
|
|
|
2012-04-09 14:23:10 -07:00
|
|
|
http://www.phabricator.com/rsrc/install/update_phabricator.sh
|
2011-06-29 19:45:12 -07:00
|
|
|
|
2011-02-11 14:58:45 -08:00
|
|
|
= Next Steps =
|
|
|
|
|
2011-05-12 08:15:02 -07:00
|
|
|
Continue by:
|
|
|
|
|
|
|
|
- configuring Phabricator with the @{article:Configuration Guide}.
|