質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.47%
Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

4回答

2375閲覧

Djangoのサーバーにアクセスできない

Tomo0225

総合スコア67

Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2022/01/03 13:04

CentoOSにDjangoとApacheとWSGIをいれてサーバーを立ち上げ外部から接続を試みたところです。
サーバーを起動し接続しようとしたらInternal Server Errorで接続できませんでした。
ログを確認したところ以下のログがでていたのですが意味が分かりません。
このログから考えられる原因をおしえていただきたいです。

sqlite3について調査した結果は下記です。
which sqlite3
/usr/local/bin/sqlite3

sqlite3 --version
3.31.1 2020-01-27 19:55:54 3bfa9cc97da10598521b342961df8f5f68c7388fa117345eeb516eaa837bb4d6

sudo tail /var/log/httpd/error_log

[Mon Jan 03 21:57:44.236953 2022] [wsgi:error] [pid 1876] [client 192.168.81.1:56693] backend = load_backend(db['ENGINE']) [Mon Jan 03 21:57:44.236956 2022] [wsgi:error] [pid 1876] [client 192.168.81.1:56693] File "/home/yasue/.pyenv/versions/3.6.2/lib/python3.6/site-packages/django/db/utils.py", line 111, in load_backend [Mon Jan 03 21:57:44.236957 2022] [wsgi:error] [pid 1876] [client 192.168.81.1:56693] return import_module('%s.base' % backend_name) [Mon Jan 03 21:57:44.236960 2022] [wsgi:error] [pid 1876] [client 192.168.81.1:56693] File "/home/yasue/.pyenv/versions/3.6.2/lib/python3.6/importlib/__init__.py", line 126, in import_module [Mon Jan 03 21:57:44.236962 2022] [wsgi:error] [pid 1876] [client 192.168.81.1:56693] return _bootstrap._gcd_import(name[level:], package, level) [Mon Jan 03 21:57:44.236965 2022] [wsgi:error] [pid 1876] [client 192.168.81.1:56693] File "/home/yasue/.pyenv/versions/3.6.2/lib/python3.6/site-packages/django/db/backends/sqlite3/base.py", line 73, in <module> [Mon Jan 03 21:57:44.236966 2022] [wsgi:error] [pid 1876] [client 192.168.81.1:56693] check_sqlite_version() [Mon Jan 03 21:57:44.236969 2022] [wsgi:error] [pid 1876] [client 192.168.81.1:56693] File "/home/yasue/.pyenv/versions/3.6.2/lib/python3.6/site-packages/django/db/backends/sqlite3/base.py", line 69, in check_sqlite_version [Mon Jan 03 21:57:44.236974 2022] [wsgi:error] [pid 1876] [client 192.168.81.1:56693] 'SQLite 3.9.0 or later is required (found %s).' % Database.sqlite_version [Mon Jan 03 21:57:44.236985 2022] [wsgi:error] [pid 1876] [client 192.168.81.1:56693] django.core.exceptions.ImproperlyConfigured: SQLite 3.9.0 or later is required (found 3.7.17).

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答4

0

半年前くらいに同じ現象になりました。
アップデートしたりリンクを変更したりしましたが解決しませんでした。
バージョンをうまく認識してもらえないのが原因みたいです。

あまりお勧めしませんが、django/db/backends/sqlite3/base.pyの69行目のcheck_sqlite_version関数がエラー判定しないように書き換えて動作させました。

投稿2022/01/04 12:21

kyokio

総合スコア560

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Tomo0225

2022/01/05 15:19

プログラムに精通している人はそんな方法も取れるのですね。
guest

0

SQLiteのバージョンが要件を満たしているのにエラーが発生するのは、pyenvでPythonをインストールする際に、適切な環境変数が設定されていないために、最新のSQLite用のライブラリ等が使用されていない可能性があります。
私が試したとき(UbuntuだったかCentOSだったかは不明)は、

export C_INCLUDE_PATH=/usr/local/include export CPLUS_INCLUDE_PATH=/usr/local/include export LD_RUN_PATH=/usr/local/lib

を実行したターミナルからpyenvでPythonをインストールして解消できました。

投稿2022/01/04 05:51

m-take

総合スコア249

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

ベストアンサー

CentOSに入っているSQLiteのバージョンが古いことが原因でエラーになっています。

なので、対応方針としてはいくつかパターンがあります。

個人的には別サーバーを建てる必要がありますが、MySQLやPostgresを使用すればDBのバージョンに悩まされる心配はなくなると思います。

投稿2022/01/03 13:20

Supernove

総合スコア1154

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Tomo0225

2022/01/05 15:20

今回はPostgresSQLに切り替えることで無事接続できるようになりました。
guest

0

django.core.exceptions.ImproperlyConfigured: SQLite 3.9.0 or later is required (found 3.7.17).

をGoogle翻訳すると以下です。

django.core.exceptions.ImproperlyConfigured:SQLite 3.9.0以降が必要です(3.7.17で見つかりました)。

django.core.exceptions.ImproperlyConfigured: SQLite 3.9.0 or later is required (found 3.7.17).をGooleで検索すると、[検索結果](https://www.google.com/search?q=django.core.exceptions.ImproperlyConfigured%3A+SQLite+3.9.0+or+later+is+required+(found+3.7.17).&rlz=1C1PWSB_jaJP984JP984&oq=django.core.exceptions.ImproperlyConfigured%3A+SQLite+3.9.0+or+later+is+required+(found+3.7.17)がいろいろと出てきます。

いろいろな解決策が書かれているので、読んでみてください。。

投稿2022/01/03 13:19

ppaul

総合スコア24666

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.47%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問