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

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

ただいまの
回答率

90.35%

  • Python

    13396questions

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

  • Django

    1862questions

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

Djangoの本番環境でのsqlite3書込み権限について

受付中

回答 0

投稿

  • 評価
  • クリップ 0
  • VIEW 390

teosu

score 17

[やりたいこと]
sqlite3ファイルに書込み権限を付与したい(が、うまくいかない)

[概要]
Djangoアプリケーションをさくらvpsにデプロイしています。
クローラーでWebの情報を取得→sqlite3に書き込むというアプリケーションですが、開発環境では問題なく動作していましたが、本番環境ではうまく動作せず

sqlite3.OperationalError: attempt to write a readonly database


とエラーが発生します。
sqlite3に書込み権限を付与するだけで解決しそうだと思い、

chmod 764 db.sqlite3
chmod: `db.sqlite3' のパーミッションを変更しています: 許可されていない操作です


とパーミッションを変更できません。
rootユーザーの他にdjangoユーザーを作成しており、djangoユーザーで全て作業をしています。

sudo chmod 764 db.sqlite3


としても、うまくいきません。

$ ll
-rwxrw-r-- 1 root root 180224 11月  8 21:44 db.sqlite3


色々試してみましたが、解決策が見出せず質問させていただきます。よろしくお願いします。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正の依頼

  • gh640

    2018/11/26 22:52

    `-rwxrw-r--` というのを見ると `sudo chmod 764 db.sqlite3` は成功しているようにも見えるのですが、これは期待されている結果とは異なるのですか?

    キャンセル

  • teosu

    2018/11/27 08:42

    djangoユーザー $ python3.6 xxx.py(sqlite3に書き込むコード)でコマンドを打つと上記のsqlite3.OperationalError: attempt to write a readonly databaseエラーが発生します。sudo python3.6 xxx.pyにすると今度はなぜかimportエラー(requests)になります。requestsはpip installしているので問題ないとは思いますが...

    キャンセル

  • matsuand

    2018/11/27 09:03

    gh640さんの言われるように、sudo chmod 764 db.sqlite3 がどのように「うまくいきません」なのか説明が不足していますよ。ディレクトリの権限も確認してください。たぶんそっちが原因かと想像します。

    キャンセル

  • matsuand

    2018/11/27 11:15

    sudo をつけないと readonly エラー、sudo をつけると import エラー。両者を同一原因と見るのは早急では? 理路整然と順序立てて論理的に検証しましょう。まずは質問(説明)を論理的に行ってください。今はそうなっていません。そうすると自己解決しているかもしれません。

    キャンセル

まだ回答がついていません

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

  • ただいまの回答率 90.35%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る

  • Python

    13396questions

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

  • Django

    1862questions

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