关于android:有声小说源码付费小说网站源码带支付系统开源小说站源码全自动采集

38次阅读

共计 4603 个字符,预计需要花费 12 分钟才能阅读完成。

读书是一个人能够领有的最好的习惯之一。浏览能够减少创造力和想象力。它还能够帮忙您减少记忆力和词汇量。然而一个人得不到他 / 她想读的书。因而,应用软件开发公司制作的应用程序在线浏览书籍能够帮忙他们,因为他们能够在网上找到各种书籍。几天前,我发现了有声小说网站源码我的项目——同一个库,应用同一个数据库,但能够通过浏览器拜访。

有声小说源码: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

正文完
 0