Django のインストール方法

このドキュメントを読めば、Django をセットアップして、起動することができます。

Python をインストールする

Django は Python のウェブフレームワークです。詳細は どのバージョンの Python で Django が使えますか? を参照してください。

最新版のPythonを https://www.python.org/downloads/ もしくはOSのパッケージ管理ツールで取得してください。

Python on Windows

もし Windows を使っていてこれから Django を始めるなら、 Windows での Django のインストール方法 を読むとよいでしょう。

Apache と mod_wsgi のインストール

もし単に Django を使って実験したいだけなら、このセクションは飛ばしてください。 Django には軽量 web サーバーが含まれており、テスト用にそれが使えます。本番環境にデプロイするときまで、 Apache をセットアップする必要はありません。

本番サイトでDjangoを使用する場合は、Apachemod_wsgi を使用します。mod_wsgiは、埋め込みモードまたはデーモンモードの2つのモードのいずれかで動作します。埋め込みモードでは、mod_wsgi は mod_perl と似ています。つまり Apache に Python を埋め込み、サーバーの起動時に Python コードをメモリにロードします。コードは Apache プロセスの存続期間中、メモリに残ります。これにより、他のサーバー配置よりも大幅にパフォーマンスが向上します。デーモンモードでは、mod_wsgi はリクエストを処理する独立したデーモンプロセスを生成します。デーモンプロセスはウェブサーバーとは異なるユーザーとして実行できるため、セキュリティが向上する可能性があります。デーモンプロセスは、Apache ウェブサーバー全体を再起動せずに再起動できるため、コードベースの更新がよりシームレスになります。mod_wsgi のドキュメントを参照して、セットアップに適したモードを判断してください。mod_wsgi モジュールをアクティブにして Apache がインストールされていることを確認してください。Django は、mod_wsgi をサポートするすべてのバージョンの Apache で動作します。

インストール完了後の mod_wsgi の設定方法に関する情報については、Django を Apache と mod_swgi とともに使うには? を読んでください。

何らかの理由により mod_wsgi が使えなかったとしても、心配はいりません。Django は他にもさまざまな開発オプションをサポートしています。そのうちの一つは uWSGI で、nginx と非常に上手く連携できます。さらに、Django は WSGI の仕様 (PEP 3333) を満たしているので、各種のサーバープラットフォーム上で動作することが保証されています。

データベースを動かす

DjangoのデータベースAPI機能を使用する場合は、データベースサーバーが実行されていることを確認する必要があります。Djangoは多くの異なるデータベースサーバーをサポートし、PostgreSQLMariaDBMySQLOracle および SQLite で公式にサポートされています。

If you are developing a small project or something you don't plan to deploy in a production environment, SQLite is generally the best option as it doesn't require running a separate server. However, SQLite has many differences from other databases, so if you are working on something substantial, it's recommended to develop with the same database that you plan on using in production.

公式にサポートされているデータベースの他に、サードパーティ製のバックエンドもあります(これらを使うと、他のデータベースを Django から使えます)。

バックエンドに加えて、 Python のデータベースバインディングをインストールする必要があります。

  • もし PostgreSQL を使うなら、 psycopg2 パッケージが必要になります。詳細は PostgreSQL notes を見てください。
  • If you're using MySQL or MariaDB, you'll need a DB API driver like mysqlclient. See notes for the MySQL backend for details.
  • SQLite を使うなら、 SQLite backend notes を読むと良いでしょう。
  • Oracle を使うなら cx_Oracle のコピーが必要ですが、 notes for the Oracle backend を読んで、 Oracle と cx_Oracle の両方について、 Django がサポートするバージョンを確認してください。
  • もし非公式のサードパーティ製バックエンドを使う場合、その他の動作要件についてはそのドキュメントを確認してください。

If you plan to use Django's manage.py migrate command to automatically create database tables for your models (after first installing Django and creating a project), you'll need to ensure that Django has permission to create and alter tables in the database you're using; if you plan to manually create the tables, you can grant Django SELECT, INSERT, UPDATE and DELETE permissions. After creating a database user with these permissions, you'll specify the details in your project's settings file, see DATABASES for details.

データベースのクエリをテストするために Django の testing framework を使う場合、テスト用データベースを作成するためのパーミッションが Django に必要です。

Install the Django code

Installation instructions are slightly different depending on whether you're installing a distribution-specific package, downloading the latest official release, or fetching the latest development version.

Installing an official release with pip

This is the recommended way to install Django.

  1. Install pip. The easiest is to use the standalone pip installer. If your distribution already has pip installed, you might need to update it if it's outdated. If it's outdated, you'll know because installation won't work.

  2. Take a look at venv. This tool provides isolated Python environments, which are more practical than installing packages systemwide. It also allows installing packages without administrator privileges. The contributing tutorial walks through how to create a virtual environment.

  3. After you've created and activated a virtual environment, enter the command:

    $ python -m pip install Django
    
    ...\> py -m pip install Django
    

Installing a distribution-specific package

Check the distribution specific notes to see if your platform/distribution provides official Django packages/installers. Distribution-provided packages will typically allow for automatic installation of dependencies and supported upgrade paths; however, these packages will rarely contain the latest release of Django.

Installing the development version

Tracking Django development

If you decide to use the latest development version of Django, you'll want to pay close attention to the development timeline, and you'll want to keep an eye on the release notes for the upcoming release. This will help you stay on top of any new features you might want to use, as well as any changes you'll need to make to your code when updating your copy of Django. (For stable releases, any necessary changes are documented in the release notes.)

If you'd like to be able to update your Django code occasionally with the latest bug fixes and improvements, follow these instructions:

  1. Make sure that you have Git installed and that you can run its commands from a shell. (Enter git help at a shell prompt to test this.)

  2. Check out Django's main development branch like so:

    $ git clone https://github.com/django/django.git
    
    ...\> git clone https://github.com/django/django.git
    

    This will create a directory django in your current directory.

  3. Make sure that the Python interpreter can load Django's code. The most convenient way to do this is to use a virtual environment and pip. The contributing tutorial walks through how to create a virtual environment.

  4. After setting up and activating the virtual environment, run the following command:

    $ python -m pip install -e django/
    
    ...\> py -m pip install -e django\
    

    This will make Django's code importable, and will also make the django-admin utility command available. In other words, you're all set!

When you want to update your copy of the Django source code, run the command git pull from within the django directory. When you do this, Git will download any changes.

Back to Top