【Django-Docker】Sqlite3.db读取权限不够attempt to write a readonly database-20220803

39 篇文章 1 订阅
这篇博客介绍了在Django中遇到SQLite3数据库读取权限不足的错误时的两种解决方案。首先,可以通过在settings.py中确认数据库文件路径,并使用chmod命令提升数据库文件及其所在文件夹的权限。其次,如果第一种方法无效,可以在Docker容器内部直接修改文件权限。文章提供了具体的chmod命令示例,并给出了Dockerfile的相关修改建议。
摘要由CSDN通过智能技术生成

问题:Sqlite3.db读取权限不够。

OperationalError at /user_login/ attempt to write a readonly database

参考链接:

https://blog.csdn.net/u013920085/article/details/51045709

解决办法1:

1.通过django项目的settings.py可以看到关联数据库文件名称

DATABASES = {
‘default’: {
‘ENGINE’: ‘django.db.backends.sqlite3’,
‘NAME’: os.path.join(BASE_DIR, ‘db.sqlite3’),
}
}

2.将django项目中的数据库文件(db.sqlite3)和数据库文件所在文件夹提升权限

chmod 777 db.sqlite3

cd …

chmod 777 *

3.再次访问数据库就没问题

修改dockfile如下

RUN chmod 777 /code/package/GAGA/SQL
RUN chmod 777 /code/package/GAGA/SQL/db.sqlite3

FROM python:3.8-slim

RUN apt-get update -y && apt-get install gcc -y

COPY ./Django /code
WORKDIR /code/package


RUN pip install -i https://pypi.tuna.tsinghua.edu.cn/simple -r requirements.txt
RUN pip install -i https://pypi.tuna.tsinghua.edu.cn/simple uwsgi
EXPOSE 8000

RUN chmod 777 /code/package/runserver-docker.sh
RUN chmod 777 /code/package/start.sh
RUN chmod 777 /code/package/GAGA/SQL
RUN chmod 777 /code/package/GAGA/SQL/db.sqlite3

# Windows环境下编写的start.sh每行命令结尾有多余的\r字符,需移除。
RUN sed -i 's/\r//' ./start.sh

 
# 设置start.sh文件可执行权限
RUN chmod +x ./start.sh

# 设置start.sh文件可执行权限
RUN chmod 777 *

#CMD ["/bin/sh","/code/package/start.sh"]


解决方法2:

如果上述方法失效,可以进入container内部,提升SQL 和 SQL/db.sqlite3的权限。

chmod 777 /code/package/GAGA/SQL
chmod 777 /code/package/GAGA/SQL/db.sqlite3
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值