安装docker

参考链接:树莓派安装Docker

硬盘挂载

参考链接:Linux 挂载移动硬盘

1.查看移动硬盘信息

sudo fdisk -l

nextcloud1.png

2.初始化硬盘

sudo umount /dev/sda1      # 必须先卸载该分区
sudo mkfs.ext4 /dev/sda1    # 格式化为ext4分区

3.挂载移动硬盘

mkdir ~/disk #创建目录用于挂载移动硬盘
sudo mount /dev/sda1 ~/disk #挂载硬盘到该目录

4.查看挂载信息

sudo lsblk -lf #查看是否成功挂载,并且记录UUID

5.配置开机自动挂载

sudo vim /etc/fstab #根据自己挂载信息写入对应内容

例如: UUID=xxxxxxxxxxxx /home/tuolong/disk ext4 defaults 0 0

正文开始 docker 部署 NextCloud

部署nextcloud

创建docker配置文件

mkdir ~/disk/nextcloud  #在外置硬盘挂载目录下创建容器映射目录
vim ~/disk/nextcloud/docker-compose.yml #创建docker-compose.yml并填写如下配置信息

修改挂载目录的权限

sudo chmod -R 777 ~/disk # docker构建目录时需要权限

填入docker-compose.yml 配置信息

version: '2'

services:
  db:
    image: ibex/debian-mysql-server-5.7
    restart: always
    volumes:
      - ./cloud/db:/var/lib/mysql
    environment:
      - MYSQL_ROOT_PASSWORD=ROOT密码 # 根据需要替换
      - MYSQL_PASSWORD=数据库密码 # 根据需要替换
      - MYSQL_DATABASE=nextcloud # 根据需要替换
      - MYSQL_USER=tuolong # 根据需要替换

  app:
    image: arm32v7/nextcloud
    ports:
      - 8888:80  # 端口映射,将Docker的80端口,映射成主机的8888端口。根据需要可以自行修改。
    links:
      - db
    volumes:
      - ./cloud/config:/var/www/html/config
      - ./cloud/data:/var/www/html/data # 因为树莓派本身存储太小,这里是映射到一个外置2T硬盘
      - ./cloud/apps:/var/www/html/apps
    restart: always

进入配置文件目录,并运行docker环境构建命令

cd ~/disk/nextCloud #进入配置文件docker-compose.yml所在目录
docker-compose up -d #docker 会根据docker-compose.yml配置信息下载镜像并创建映射

配置数据库

  • 通过浏览器访问IP地址 xxx.xxx.xxx.xxx:8888配置数据库
  • 配置数据库选择:Mysql/MariaDB
  • database host填写:db
  • 其他内容按配置文件填写

nextcloud2.png

配置动态域名解析DDNS

如果你有固定的公网ip,这一步可以直接跳过 参考链接: No-ip ddns动态域名解析

配置 Nginx

(头铁的小伙伴可以直接将局域网服务器端口映射到外部,DDNS域名加端口号就能访问,这一步就可以省略了)

nextcloud3.png

安装 nginx(配置反向代理服务器)

参考链接: 搭建私人博客—Halo

  • 反向代理: Nginx 充当反向代理服务器,它接收来自客户端的请求并将其代理到不同的后端服务,根据请求的路径来区分
  • 路径分发: 通过配置不同的 location 块,Nginx 可以根据请求的路径将流量分发到不同的后端服务。例如,/nextcloud 被代理到 Nextcloud,/blog 被代理到个人博客。
  • 简化访问: 这种配置方式允许您使用单个域名来访问多个不同的服务,而无需使用不同的端口或子域名。这样,外部用户可以方便地访问您的 Nextcloud 和个人博客,而不需要记住多个不同的地址。
# 安装gcc g++的依赖库
sudo apt-get install build-essential
sudo apt-get install libtool

# 安装pcre依赖库
sudo apt-get update
sudo apt-get install libpcre3 libpcre3-dev

# 安装zlib依赖库
apt-get install zlib1g-dev

# 安装ssl依赖库
apt-get install openssl

# 安装Nginx
sudo apt-get install nginx
  • 更改监听端口(如果80端口被其他web服务器占用)

    将 Nginx 配置中的监听端口从 80 更改为 8080:

    sudo vim /etc/nginx/sites-available/default #打开 Nginx 配置文件:
    

    在配置中找到类似以下的行并更改端口: server { listen 8080 default_server; listen [::]:8080 default_server; #...}

    保存并退出配置文件,然后重新加载 Nginx:

    sudo systemctl reload nginx #重新加载 /	# sudo systemctl start nginx #启动命令
    
    sudo systemctl enable nginx #开机自启
    systemctl status nginx.service #查看nginx是否正常工作
    

Nginx配置

  • 在 /etc/nginx/sites-available/ 目录中创建一个新的配置文件,例如 zhangzhewang.ddns.net:
sudo vim /etc/nginx/sites-available/zhangzhewang.ddns.net

在文件中粘贴个人配置信息

server {
    listen 8080;
    server_name zhangzhewang.ddns.net;  # 主域名
    client_max_body_size 1024M; #nginx 默认上传文件大小一般是2M,修改传输文件大小上限
    location / {
        proxy_pass http://***.***.**.***:8888;  # Nextcloud 的局域网 IP 地址和端口
        #proxy_set_header Host $host; #当监听80端口时可以省略请求头端口号$server_port
        proxy_set_header Host $host:$server_port;#非80端口时不能省略,不然向服务器发送请求,无法重定向到正确URL,导致404
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }

}

启用该配置:

#创建一个符号链接以启用该配置文件:
sudo ln -s /etc/nginx/sites-available/zhangzhewang.ddns.net /etc/nginx/sites-enabled/

#检查 Nginx 配置是否有语法错误:
sudo nginx -t

#重新加载 Nginx 以应用新的配置
sudo systemctl reload nginx

购买并配置域名解析

-如果你是固定的公网ip,那么直接解析到公网ip地址,如果不是,解析DDNS域名地址。

nextcloud4.png

设置路由器端口转发

有些路由器管理界面会占用外部80端口。然,则映射其他端口;访问时需要域名加端口号。

nextcloud5.png

疑难杂症

  • docker-compose up运行错误1

    TypeError: kwargs_from_env() got an unexpected keyword argument 'ssl_version'

    pip install docker==6.1.3        #解决方法:降低版本 7.0.0 -->6.1.3
    
  • docker-compose up运行错误2

    raise DockerException( docker.errors.DockerException: Error while fetching server API version: ('Connection aborted.', PermissionError(13, 'Permission denied'))

    sudo usermod -aG docker your_username #将你的用户添加到 Docker 用户组,这将允许你在不使用 sudo 的情况下运行 Docker 命令。
    newgrp docker #重新加载用户组使其生效
    
  • 数据库权限问题

nextcloud6.png

方法一:

chmod 0770 /your_data_dir #更改数据目录权限
sudo chown www-data:www-data /your_data_dir #更改用户组

 sudo lsblk -lf #查看挂载数据目录的硬盘格式是不是ext4
 sudo mkfs.ext4 /dev/sda1    # 格式化为ext4分区
  • Nginx 80端口被占用

    Job for nginx.service failed because the control process exited with error code. See "systemctl status nginx.service" and "journalctl -xe" for details.

    systemctl status nginx.service #令查看 Nginx 服务的状态和详细错误信息
    

    将 Nginx 配置中的监听端口从 80 更改为 8080:

    sudo vim /etc/nginx/sites-available/default #打开 Nginx 配置文件:
    

    在配置中找到类似以下的行并更改端口: server { listen 8080 default_server; listen [::]:8080 default_server; #...}