读书是一个人能够领有的最好的习惯之一。浏览能够减少创造力和想象力。它还能够帮忙您减少记忆力和词汇量。然而一个人得不到他 / 她想读的书。因而,应用软件开发公司制作的应用程序在线浏览书籍能够帮忙他们,因为他们能够在网上找到各种书籍。几天前,我发现了有声小说网站源码我的项目——同一个库,应用同一个数据库,但能够通过浏览器拜访。
有声小说源码:xsymz.icu
我的想法是不再将书籍存储在设施中中,而是在挪动设施上和通过浏览器应用其电子书阅读器,但依然可能从任何中央拜访我的图书馆,并领有书籍的浏览地位同步性能。当初我的库自身存储在云端中,我将在我的 Android 设施上应用有声小说源码。
NGINX,让咱们加密
NGINX + Let’s Encrypt 设置已在明码管理工具中形容:组织的明码管理器自托管版本装置在 AWS EC2 帖子中。
口径网络启动
查看云存储下的库目录,咱们的有声小说源码将应用该目录:
$ ll /data/cloud/app/data/setevoy/files/Books/CALIBRE/ | head
total 1212
drwxr-xr-x 3 www-data www-data 4096 Dec 13 07:53 A. A. Orlov
drwxr-xr-x 7 www-data www-data 4096 Dec 13 07:53 A. Avramienko
drwxr-xr-x 3 www-data www-data 4096 Dec 13 07:55 A. Bielash
drwxr-xr-x 3 www-data www-data 4096 Dec 13 07:55 Adol_f Gitlier
drwxr-xr-x 3 www-data www-data 4096 Dec 13 07:55 Al_bier Kamiu
...
应用有声小说源码运行一个 Docker 容器,将库的目录装置在外面 /books:
$ docker run -ti --name books -p 8083:8083 -v /data/cloud/app/data/setevoy/files/Books/CALIBRE/:/books technosoft2000/calibre-web
查看是否 metadata.db 存在:
$ docker exec -ti books ls -l /books/metadata.db
-rw-r--r-- 1 xfs xfs 752640 Dec 13 07:51 /books/metadata.db
在浏览器中关上您的 URL,并设置一个目录门路,该 /books 目录必须蕴含 metadata.dbCalibre 用来存储图书馆所有书籍信息的文件:
应用默认 admin:admin123 登录:
你当初会看到你的图书馆:
这里的类别菜单只是来自有声小说源码的标签:
和一般的有声小说源码一样——您能够从浏览器查看、增加、编辑和浏览书籍:
“无奈创立门路 /books/(权限被回绝)”谬误
如果您当初尝试上传文件,您可能会遇到以下谬误:
无奈创立门路 /books/Mark Menson/Tonkoe iskusstvo pofigizma_Paradoksal’nyi sposob zhit’ schastlivo(权限被回绝)。
对我来说,这是一个预期的谬误,因为云存储和有声小说源码 Docker 容器 /data/cloud/app/data/setevoy/files/Books/CALIBRE/ 当初都在应用该目录。
查看有声小说源码容器中的用户:
$ docker exec -ti books ps | grep cali
0:08 /usr/bin/python /calibre-web/app/cps.py
还有他的 UID:
$ docker exec -ti books id calibre
uid=15000(calibre) gid=15000(calibre) groups=15000(calibre),15000(calibre)
主机上的本地目录归以下所有:
$ ls -l /data/cloud/app/data/setevoy/files/Books/
total 4
drwxr-xr-x 117 www-data www-data 4096 Dec 16 09:32 CALIBRE
以及 www-data 用户的 UID:
$ id www-data
uid=33(www-data) gid=33(www-data) groups=33(www-data)
即有声小说源码应用 calibreUID 15000 的用户,但主机上的 NGINX 和 云存储容器都应用 www-dataUID 33 的用户。
要解决这个问题——在主机上创立一个 UID 为 15000 的新用户 calibre:
$ sudo useradd -u 15000 calibre
$ id calibre
uid=15000(calibre) gid=15000(calibre) groups=15000(calibre)
更改目录所有权:
$ sudo chown -R calibre:calibre /data/cloud/app/data/setevoy/files/Books/CALIBRE/
重启口径:
$ docker restart calibre-web
calibre-web
当初查看上传 – 当初必须工作:
下一个云 PUT403
然而当初云存储坏了——在桌面客户端上,我在同步期间遇到 403 谬误,例如:
172.29.0.2 – setevoy [16/Dec/2019:13:22:24 +0000]“PUT /remote.php/dav/files/setevoy/Books/CALIBRE/Pol'%20Diubua/MySQL%20(68)/cover .jpg HTTP/1.1”403 759“-”“Mozilla/5.0 (Linux) mirall/2.6.1git”
要解决此问题,请将下面创立的 calibre 用户增加到 www 数据组:
$ usermod -a -G www-data calibre
Check his groups now:
立刻查看他的组:
$ id calibre
uid=15000(calibre) gid=15000(calibre) groups=15000(calibre),33(www-data)
递归地更改所有权–向 www 数据组成员(例如,g)授予 www 数据和 calibre 用户的齐全权限:
$ find /data/cloud/app/data/setevoy/files/Books/CALIBRE/ -type d -exec chmod g+rwx {} +
并更改所有者:
$ chown -R calibre:www-data /data/cloud/app/data/setevoy/files/Books/CA
这曾经实现,同步当初也在工作。
Docker 合成
要实现数据持久性,首先让咱们查找容器中存储的数据地位,例如应用程序的数据库及其所有设置。
您能够浏览文档,或连贯到容器:
$ docker exec -ti calibre-web bash
Find all _*.db_ files:
bash-4.4# find / -name "*.db"
/calibre-web/app/app.db
/calibre-web/app/gdrive.db
...
在主机上为 Docker Compose 文件和应用程序数据创立目录:
$ mkdir /opt/calibre-web/
$ mkdir -p /data/calibre/app
$ chown -R calibre:calibre /data/calibre/
在 /opt/ 有声小说源码 / 目录中创立 calibre-compose.yml 文件:
version: '3'
services:
calibre-web:
user: "root:root"
image: technosoft2000/calibre-web
container_name: calibre-web
ports:
- 8083:8083
volumes:
- /data/cloud/app/data/setevoy/files/Books/CALIBRE/:/books
- /data/calibre/app:/calibre-web/app/
- /var/run/docker.sock:/tmp/docker.sock:ro
restart: unless-stopped
启动服务:
$ docker-compose -f calibre-compose.yml up -d
在 Linux:systemdсервисдляDocker Compose 中形容了单元文件的创立,在本例中,我增加了 /etc/systemd/system/cacalibre.service 文件:
[Unit]
Description=Calibre library service
Requires=docker.service
After=docker.service
[Service]
Restart=always
WorkingDirectory=/opt/calibre-web
ExecStart=/usr/local/bin/docker-compose -f calibre-compose.yml up
ExecStop=/usr/local/bin/docker-compose -f calibre-compose.yml down
[Install]
WantedBy=multi-user.target
开箱即用的有声小说源码有两个主题——轻主题,默认为:
将 metadata.db 与云存储合并
这一问题与云存储作为存储的以后设置无关,因为它在我本人的服务器上运行,有时可能处于脱机状态,这可能会导致桌面上的数据不同步。
问题是,当您应用有声小说源码从浏览器编辑书籍时,主 Calibre 文件(metadata.db)将在主机的文件系统上更新,但当它像服务器一样运行时,此更改不会触发本地云存储实例将此更改推送到其客户端,因为它不是客户端局部。
而后,如果您的有声小说源码桌面在配置为应用雷同的云存储,并且具备相似云存储桌面的桌面客户端,如果您将运行本地在线浏览桌面并对其库进行任何更改,这将影响您的 metadata.db 文件,这将触发您的云存储客户端将这些更改推送到云存储服务器,这将笼罩服务器上的更改。
因而,为了防止这种状况,须要在应用云存储服务器之前手动同步桌面的在线浏览目录内容。
为此,只需收回以下命令:
$ cloudcmd --user setevoy -p PASSWORD /home/setevoy/cloud/Books/CALIBRE/ https://cloud.example.org.ua/Books/CALIBRE