2003-03-08 12:28:24 +00:00
|
|
|
// $Id$
|
2001-01-13 17:16:05 +00:00
|
|
|
|
2003-03-08 12:28:24 +00:00
|
|
|
REQUIREMENTS
|
|
|
|
------------
|
|
|
|
|
2004-10-04 20:15:32 +00:00
|
|
|
Drupal requires a web server, PHP4 (http://www.php.net/) and either
|
2005-01-13 16:15:49 +00:00
|
|
|
MySQL or PostgreSQL. Drupal requires PHP 4.1.0 or greater on Linux
|
|
|
|
and PHP 4.2.3 or greater on Windows. PHP5 is not yet supported.
|
2003-03-08 12:28:24 +00:00
|
|
|
|
2003-06-14 17:47:01 +00:00
|
|
|
NOTE: The Apache web server and MySQL database are strongly recommended;
|
|
|
|
other web server and database combinations such as IIS and PostgreSQL
|
2004-05-17 19:35:49 +00:00
|
|
|
are possible but tested to a lesser extent.
|
2003-03-08 12:28:24 +00:00
|
|
|
|
|
|
|
SERVER CONFIGURATION
|
|
|
|
--------------------
|
|
|
|
|
|
|
|
Your PHP must have the following settings:
|
|
|
|
|
|
|
|
session.save_handler user
|
|
|
|
|
|
|
|
In addition, we recommend the following settings:
|
|
|
|
|
|
|
|
session.cache_limiter none
|
|
|
|
|
|
|
|
These values are set in php.ini and can be overwritten in a .htaccess
|
|
|
|
file; you can print out your local PHP settings with PHP's phpinfo()
|
|
|
|
function.
|
|
|
|
|
|
|
|
OPTIONAL COMPONENTS
|
|
|
|
-------------------
|
|
|
|
|
|
|
|
- To use XML-based services such as the Blogger API, Jabber, RSS
|
2005-01-13 16:15:49 +00:00
|
|
|
syndication, you will need PHP's XML extension. This extension is
|
2003-03-08 12:28:24 +00:00
|
|
|
enabled by default in standard PHP4 installations.
|
|
|
|
|
|
|
|
- If you want support for clean URLs, you'll need mod_rewrite and
|
|
|
|
the ability to use local .htaccess files. (More information can
|
|
|
|
be found in the Drupal handbook on drupal.org.)
|
|
|
|
|
|
|
|
INSTALLATION
|
|
|
|
------------
|
|
|
|
|
|
|
|
1. DOWNLOAD DRUPAL
|
|
|
|
|
2003-06-14 17:47:01 +00:00
|
|
|
You can obtain the latest Drupal release from http://drupal.org/.
|
2005-01-13 16:15:49 +00:00
|
|
|
The files are in .tar.gz format and can be extracted using most
|
|
|
|
compression tools. On a typical Unix command line, use:
|
2003-03-08 12:28:24 +00:00
|
|
|
|
2005-01-13 16:15:49 +00:00
|
|
|
wget http://drupal.org/files/project/drupal-x.x.x.tgz
|
|
|
|
tar -zxvf drupal-x.x.x.tgz
|
2003-03-08 12:28:24 +00:00
|
|
|
|
|
|
|
This will create a new directory drupal-x.x.x/ containing all
|
2005-01-13 16:15:49 +00:00
|
|
|
Drupal files and directories. Move the contents of that directory
|
2003-06-14 17:47:01 +00:00
|
|
|
into a directory within your web server's document root or your
|
2003-03-08 12:28:24 +00:00
|
|
|
public HTML directory:
|
|
|
|
|
2005-01-13 16:15:49 +00:00
|
|
|
mv drupal-x.x.x/* drupal-x.x.x/.htaccess /var/www/html
|
2003-03-08 12:28:24 +00:00
|
|
|
|
|
|
|
2. CREATE THE DRUPAL DATABASE
|
|
|
|
|
2005-01-13 16:15:49 +00:00
|
|
|
This step is only necessary if you don't already have a database
|
|
|
|
set-up (e.g. by your host).
|
|
|
|
|
|
|
|
If you control your databases through a web-based control panel
|
|
|
|
check its documentation for creating databases, as these instructions
|
|
|
|
are for the command-line.
|
|
|
|
|
|
|
|
These instructions are for MySQL. If you are using another database,
|
|
|
|
check the database documentation. In the following examples,
|
2003-06-21 06:44:16 +00:00
|
|
|
"dba_user" is an example MySQL user which has the CREATE and GRANT
|
2005-01-13 16:15:49 +00:00
|
|
|
privileges. You will need to use the appropriate user name for your
|
2003-06-21 06:44:16 +00:00
|
|
|
system.
|
2003-06-14 17:47:01 +00:00
|
|
|
|
2003-03-08 12:28:24 +00:00
|
|
|
First, you must create a new database for your Drupal site:
|
|
|
|
|
2005-01-13 16:15:49 +00:00
|
|
|
mysqladmin -u dba_user -p create drupal
|
2003-03-08 12:28:24 +00:00
|
|
|
|
2003-06-21 06:44:16 +00:00
|
|
|
MySQL will prompt for the dba_user database password and then create
|
2005-01-13 16:15:49 +00:00
|
|
|
the initial database files. Next you must login and set the access
|
2003-03-08 12:28:24 +00:00
|
|
|
database rights:
|
|
|
|
|
2005-01-13 16:15:49 +00:00
|
|
|
mysql -u dba_user -p
|
2003-03-08 12:28:24 +00:00
|
|
|
|
2005-01-13 16:15:49 +00:00
|
|
|
Again, you will be asked for the dba_user database password. At the
|
2003-03-08 12:28:24 +00:00
|
|
|
MySQL prompt, enter following command:
|
|
|
|
|
|
|
|
GRANT ALL PRIVILEGES ON drupal.*
|
2003-06-14 17:47:01 +00:00
|
|
|
TO nobody@localhost IDENTIFIED BY 'password';
|
2003-03-08 12:28:24 +00:00
|
|
|
|
|
|
|
where
|
|
|
|
|
|
|
|
'drupal' is the name of your database
|
2003-06-14 17:47:01 +00:00
|
|
|
'nobody@localhost' is the userid of your webserver MySQL account
|
|
|
|
'password' is the password required to log in as the MySQL user
|
2003-03-08 12:28:24 +00:00
|
|
|
|
|
|
|
If successful, MySQL will reply with
|
|
|
|
|
|
|
|
Query OK, 0 rows affected
|
|
|
|
|
|
|
|
to activate the new permissions you must enter the command
|
|
|
|
|
|
|
|
flush privileges;
|
|
|
|
|
|
|
|
and then enter '\q' to exit MySQL.
|
|
|
|
|
|
|
|
3. LOAD THE DRUPAL DATABASE SCHEME
|
|
|
|
|
2005-01-13 16:15:49 +00:00
|
|
|
Once you have a database, you must load the required tables into
|
|
|
|
the database.
|
|
|
|
|
|
|
|
If you use a web-based control panel, you should be
|
|
|
|
able to upload the file 'database.mysql' from Drupal's 'database'
|
|
|
|
directory and run it directly as SQL commands.
|
|
|
|
|
|
|
|
From the command line, use:
|
2003-03-08 12:28:24 +00:00
|
|
|
|
2005-01-13 16:15:49 +00:00
|
|
|
mysql -u nobody -p drupal < database/database.mysql
|
2003-03-08 12:28:24 +00:00
|
|
|
|
|
|
|
4. CONNECTING DRUPAL
|
|
|
|
|
2004-11-24 22:44:01 +00:00
|
|
|
The default configuration can be found in the
|
|
|
|
'sites/default/settings.php' file within your Drupal installation.
|
2003-06-14 17:47:01 +00:00
|
|
|
Before you can run Drupal, you must set the database URL and the
|
2005-01-13 16:15:49 +00:00
|
|
|
base URL to the web site. Open the configuration file and edit the
|
2003-06-14 17:47:01 +00:00
|
|
|
$db_url line to match the database defined in the previous steps:
|
2003-03-08 12:28:24 +00:00
|
|
|
|
2005-01-13 16:15:49 +00:00
|
|
|
$db_url = "mysql://username:password@localhost/database";
|
2005-01-14 15:31:01 +00:00
|
|
|
|
2005-01-13 16:15:49 +00:00
|
|
|
where 'username', 'password', 'localhost' and 'database' are the
|
|
|
|
username, password, host and database name for your set up.
|
2003-03-08 12:28:24 +00:00
|
|
|
|
2005-01-13 16:15:49 +00:00
|
|
|
Set $base_url to match the address to your Drupal site:
|
2003-06-14 17:47:01 +00:00
|
|
|
|
2004-01-14 06:28:59 +00:00
|
|
|
$base_url = "http://www.example.com";
|
2003-03-08 12:28:24 +00:00
|
|
|
|
2004-11-24 22:44:01 +00:00
|
|
|
In addition, a single Drupal installation can host several
|
|
|
|
Drupal-powered sites, each with its own individual configuration.
|
|
|
|
If you don't need to run multiple Drupal sites, you can skip to the
|
|
|
|
next section.
|
|
|
|
|
|
|
|
Additional site configurations are created in subdirectories within
|
2005-01-13 16:15:49 +00:00
|
|
|
the 'sites' directory. Each site subdirectory must have a
|
|
|
|
'settings.php' file which specifies the configuration settings. The
|
2004-11-24 22:44:01 +00:00
|
|
|
easiest way to create additional sites is to copy the 'default'
|
2005-01-13 16:15:49 +00:00
|
|
|
directory and modify the 'settings.php' file as appropriate. The new
|
|
|
|
directory name is constructed from the site's URL. The
|
2004-11-24 22:44:01 +00:00
|
|
|
configuration for www.example.com could be in
|
|
|
|
'sites/example.com/settings.php' (note that 'www.' should be omitted
|
|
|
|
if users can access your site at http://example.com/).
|
|
|
|
|
2005-01-13 16:15:49 +00:00
|
|
|
Sites do not each have to have a different domain. You can use
|
|
|
|
subdomains and subdirectories for Drupal sites also. For example,
|
2004-11-24 22:44:01 +00:00
|
|
|
example.com, sub.example.com, and sub.example.com/site3 can all be
|
2005-01-13 16:15:49 +00:00
|
|
|
defined as independent Drupal sites. The setup for a configuration
|
2004-11-24 22:44:01 +00:00
|
|
|
such as this would look like the following:
|
|
|
|
|
|
|
|
sites/default/settings.php
|
|
|
|
sites/example.com/settings.php
|
|
|
|
sites/sub.example.com/settings.php
|
|
|
|
sites/sub.example.com.site3/settings.php
|
|
|
|
|
|
|
|
When searching for a site configuration (for example
|
|
|
|
www.sub.example.com/site3), Drupal will search for configuration
|
|
|
|
files in the following order, using the first configuration file it
|
|
|
|
finds:
|
|
|
|
|
|
|
|
sites/www.sub.example.com.site3/settings.php
|
|
|
|
sites/sub.example.com.site3/settings.php
|
|
|
|
sites/example.com.site3/settings.php
|
|
|
|
sites/www.sub.example.com/settings.php
|
|
|
|
sites/sub.example.com/settings.php
|
|
|
|
sites/example.com/settings.php
|
|
|
|
sites/default/settings.php
|
|
|
|
|
|
|
|
Each site configuration can have its own site-specific modules and
|
|
|
|
themes that will be made available in addition to those installed
|
2005-01-13 16:15:49 +00:00
|
|
|
in the standard 'modules' and 'themes' directories. To use
|
2004-11-24 22:44:01 +00:00
|
|
|
site-specific modules or themes, simply create a 'modules' or
|
2005-01-13 16:15:49 +00:00
|
|
|
'themes' directory within the site configuration directory. For
|
2004-11-24 22:44:01 +00:00
|
|
|
example, if sub.example.dom has a custom theme and a custom module
|
|
|
|
that should not be accessible to other sites, the setup would look
|
|
|
|
like this:
|
|
|
|
|
|
|
|
sites/sub.example.com/:
|
|
|
|
settings.php
|
|
|
|
themes/:
|
|
|
|
custom_theme
|
|
|
|
modules/:
|
|
|
|
custom_module
|
|
|
|
|
2003-03-08 12:28:24 +00:00
|
|
|
NOTE: for more information about multiple virtual hosts or the
|
|
|
|
configuration settings, consult the Drupal handbook at drupal.org.
|
|
|
|
|
|
|
|
5. CONFIGURE DRUPAL
|
|
|
|
|
|
|
|
You can now launch your browser and point it to your Drupal site.
|
|
|
|
|
2005-01-13 16:15:49 +00:00
|
|
|
Create an account and login. The first account will automatically
|
2003-03-08 12:28:24 +00:00
|
|
|
become the main administrator account.
|
|
|
|
|
|
|
|
6. CRON TASKS
|
|
|
|
|
2003-06-14 17:47:01 +00:00
|
|
|
Many Drupal modules have periodic tasks that must be triggered by a
|
2005-01-13 16:15:49 +00:00
|
|
|
cron job. To activate these tasks, you must call the cron page by
|
|
|
|
visiting http://www.example.com/cron.php ;
|
|
|
|
This will pass control to the modules and the modules will decide
|
2003-03-08 12:28:24 +00:00
|
|
|
if and what they must do.
|
|
|
|
|
2005-01-13 16:15:49 +00:00
|
|
|
Most systems support the crontab utility for scheduling tasks like
|
|
|
|
this. The following example crontab line will activate the cron
|
|
|
|
tasks automatically on the hour:
|
2003-03-08 12:28:24 +00:00
|
|
|
|
2005-01-13 16:15:49 +00:00
|
|
|
0 * * * * wget -O - -q http://www.example.com/cron.php
|
2003-03-08 12:28:24 +00:00
|
|
|
|
|
|
|
More information about the cron scripts are available in the admin
|
2005-01-13 16:15:49 +00:00
|
|
|
help pages and in the Drupal handbook at drupal.org. Example
|
2003-03-08 12:28:24 +00:00
|
|
|
scripts can be found in the scripts/ directory.
|
|
|
|
|
|
|
|
DRUPAL ADMINISTRATION
|
|
|
|
---------------------
|
|
|
|
|
2003-09-24 08:29:45 +00:00
|
|
|
Upon a new installation, your Drupal website defaults to a very basic
|
|
|
|
configuration with only a few active modules, one theme, and no user
|
|
|
|
access rights.
|
|
|
|
|
|
|
|
Use your administration panel to enable and configure services. For
|
|
|
|
example, set some general settings for your site with "Administration -
|
2005-01-13 16:15:49 +00:00
|
|
|
configuration". Enable modules via "Administration - configuration -
|
|
|
|
modules". User permissions can be set with "Administration - accounts
|
2004-01-14 06:28:59 +00:00
|
|
|
- permissions".
|
2003-09-24 08:29:45 +00:00
|
|
|
|
|
|
|
For more information on configuration options, read through the
|
|
|
|
instructions which accompany the different configuration settings and
|
|
|
|
consult the various help pages available in the administration panel.
|
|
|
|
|
|
|
|
Note that additional community-contributed modules and themes are
|
2004-01-14 06:28:59 +00:00
|
|
|
available at http://drupal.org/.
|
2003-03-08 12:28:24 +00:00
|
|
|
|
|
|
|
CUSTOMIZING YOUR THEME(S)
|
|
|
|
-------------------------
|
|
|
|
|
|
|
|
Now that your server is running, you will want to customize the look
|
2005-01-13 16:15:49 +00:00
|
|
|
of your site. Several sample themes are included in the Drupal
|
2003-03-08 12:28:24 +00:00
|
|
|
installation and more can be downloaded from drupal.org.
|
|
|
|
|
2005-01-13 16:15:49 +00:00
|
|
|
Customizing each theme depends on the theme. In general, each theme
|
2003-03-08 12:28:24 +00:00
|
|
|
contains a PHP file themename.theme which defines a function header()
|
|
|
|
that can be changed to reference your own logos.
|
|
|
|
|
|
|
|
Most themes also contain stylesheets or PHP configuration files to
|
2003-06-14 17:47:01 +00:00
|
|
|
tune the colors and layouts; check the themes/ directory for README
|
2003-03-08 12:28:24 +00:00
|
|
|
files describing each alternate theme.
|
|
|
|
|
2004-01-14 06:28:59 +00:00
|
|
|
UPGRADING
|
|
|
|
---------
|
|
|
|
|
|
|
|
1. Backup your database and Drupal directory - especially your
|
|
|
|
configuration file (www.example.com.conf or includes/conf.php).
|
|
|
|
|
|
|
|
2. Log on as the user with user ID 1.
|
|
|
|
|
2004-10-17 18:38:22 +00:00
|
|
|
3. Remove all the old Drupal files then unpack the new Drupal files
|
|
|
|
into the directory that you run Drupal from.
|
2004-01-14 06:28:59 +00:00
|
|
|
|
|
|
|
4. Modify the new configuration file to make sure it has the
|
|
|
|
correct information.
|
|
|
|
|
|
|
|
5. Run update.php by visiting http://www.example.com/update.php.
|
|
|
|
|
2003-03-08 12:28:24 +00:00
|
|
|
MORE INFORMATION
|
|
|
|
----------------
|
|
|
|
|
|
|
|
For platform specific configuration issues and other installation and
|
|
|
|
administration assistance, please consult the Drupal handbook at
|
2005-01-13 16:15:49 +00:00
|
|
|
http://drupal.org/. You can also find support at the Drupal support
|
2003-06-14 17:47:01 +00:00
|
|
|
forum or through the Drupal mailing lists.
|
2001-01-13 17:16:05 +00:00
|
|
|
|