[Django]-Attempt to write a readonly database โ€“ Django w/ SELinux error

103๐Ÿ‘

โœ…

You have to add writing rights to the directory in which your sqlite database is stored. So running chmod -R u+w /srv/mysite/ should help.

If a server is using custom user (e.g. www-data) to access the database, the solution could be to change the owner of your database:

chown www-data:www-data /srv/mysite
chown www-data:www-data /srv/mysite/DATABASE.sqlite
๐Ÿ‘คniekas

19๐Ÿ‘

In short, it happens when the application which writes to the sqlite database does not have write permission.

This can be solved in three ways:

  1. Granting ownership of db.sqlite3 file and its parent directory (thereby write access also) to the user using chown (Eg: chown username db.sqlite3 )
  2. Running the webserver (often gunicorn) as root user (run the command sudo -i before you run gunicorn or django runserver)
  3. Allowing read and write access to all users by running command chmod 777 db.sqlite3 (Dangerous option)

Never go for the third option unless you are running the webserver in a local machine or the data in the database is not at all important for you.

Second option is also not recommended. But you can go for it, if you are sure that your application is not vulnerable for code injection attack.

8๐Ÿ‘

This issue is caused by SELinux. After setting file ownership just as you did, I hit this issue. The audit2why(1) tool can be used to diagnose SELinux denials from the log:

(django)[f22-4:www/django/demo] ftweedal% sudo audit2why -a
type=AVC msg=audit(1437490152.208:407): avc:  denied  { write }
      for  pid=20330 comm="httpd" name="db.sqlite3" dev="dm-1" ino=52036
      scontext=system_u:system_r:httpd_t:s0
      tcontext=unconfined_u:object_r:httpd_sys_content_t:s0
      tclass=file permissive=0
    Was caused by:
    The boolean httpd_unified was set incorrectly. 
    Description:
    Allow httpd to unified

    Allow access by executing:
    # setsebool -P httpd_unified 1

Sure enough, running sudo setsebool -P httpd_unified 1 resolved the issue.

Looking into what httpd_unified is for, I came across a fedora-selinux-list post which explains:

This Boolean is off by default, turning it on will allow all httpd
executables to have full access to all content labeled with a http file
context. Leaving it off makes sure that one httpd service can not
interfere with another.

So turning on httpd_unified lets you circumvent the default behaviour that prevents multiple httpd instances on the same server โ€“ all running as user apache โ€“ messing with each othersโ€™ stuff.

In my case, I am only running one httpd, so it was fine for me to turn on httpd_unified. If you cannot do this, I suppose some more fine-grained labelling is needed.

๐Ÿ‘คfrasertweedale

5๐Ÿ‘

I faced the same problem but on Ubuntu Server.
So all I did is changed to superuser before I activate virtual environment for django and then I ran the django server.
It worked fine for me.

First copy paste

sudo su

Then activate the virtual environment if you have one.

source myvenv/bin/activate

At last run your django server.

python3 manage.py runserver

Hope, this will help you.

๐Ÿ‘คoctogenex

5๐Ÿ‘

I had this issue and I solved it by creating a directory in mysite folder to hold my db.sqlite3 file. so I did /home/user/src/mysite/database/db.sqlite3. In my django setting file I change my

 DATABASES = {
'default': {
    'ENGINE': 'django.db.backends.sqlite3',
    'NAME': "/home/user/src/mysite/database/db.sqlite3" ,
}}

I did this to make Django aware that I am storing my database in a sub directory of the base directory, which mysite in my case. Now you need to grant the permission to apache to be able read write the database.

chown user:www-data database/db.sqlite3
chown user:www-data database 
chmod 755 database
 chmod 755 database/db.sqlite3

This solved my problem. Here is a list of the different permissions. You can use choose the one that fits you
but avoid 777 and 666

-rwโ€”โ€”- (600) โ€” Only the user has read and write permissions.

-rw-rโ€“rโ€“ (644) โ€” Only user has read and write permissions; the group and others can read only.

-rwxโ€”โ€” (700) โ€” Only the user has read, write and execute permissions.

-rwxr-xr-x (755) โ€” The user has read, write and execute permissions; the group and others can only read and execute.

-rwxโ€“xโ€“x (711) โ€” The user has read, write and execute permissions; the group and others can only execute.

-rw-rw-rw- (666) โ€” Everyone can read and write to the file. Bad idea.

-rwxrwxrwx (777) โ€” Everyone can read, write and execute. Another bad idea.

Here are a couple common settings for directories:

drwxโ€”โ€” (700) โ€” Only the user can read, write in this directory.

drwxr-xr-x (755) โ€” Everyone can read the directory, but its contents can only be changed by the user.

Here is a link to an article to learn more: Fun with Numbers in chmod

๐Ÿ‘คSeanDp32

2๐Ÿ‘

Here is how I solved it.

sudo chmod 774 . || sudo chmod 776 .  

Pay particular attention to the . because most of the time the reason why this doesnt work is because we try this:

sudo chmod 774 db.sqlite3

But what your trying to do is open access to the folder that contains: db.sqlite3 not the database itself. If this doesnโ€™t solve it completely then try this:

sudo chmod 774 db.sqlite3

Then it should work. Cheers!

๐Ÿ‘คMekanic

1๐Ÿ‘

I ran into a similar issue. To check if SELinux is the problem, one can check its running status with

sestatus

and temporarily disable it with

setenforce 0

This could at least help to narrow down the problem.

๐Ÿ‘คbdoering

0๐Ÿ‘

You can change acls without touching the ownership and permissions of file/directory.

Use the following commands:

setfacl -m u:www-data:rwx /home/user/website
setfacl -m u:www-data:rw /home/user/website/db.sqlite3

0๐Ÿ‘

You can change the owner of your database file and itโ€™s folder to django:

chown django:django /home/django/mysite
chown django:django /home/django/mysite/my_db.sqlite3

This work for DigitalOceanโ€™s 1-Click Django Droplet

๐Ÿ‘คeugder

-12๐Ÿ‘

Here my solution:

root@fiq:/home/django/django_project# chmod 777 db.sqlite3
root@fiq:/home/django/django_project# cd ..
root@fiq:/home/django# chmod 777 *

Go to <'your_website/admin'> put username and password.. Thatโ€™s it.

๐Ÿ‘คsaffiq

Leave a comment