Skip to content

Latest commit

 

History

History
141 lines (114 loc) · 5.87 KB

README.md

File metadata and controls

141 lines (114 loc) · 5.87 KB

Film Build

1. 目录结构说明

  • data 服务容器相关的数据和配置信息存放目录
    • nginx
      • html目录用于上传vite项目构建后的dist下的页面相关文件
      • nginx.conf 配置后端接口的代理和端口等相关信息
    • redis
      • redis.conf 配置redis的远程访问和密码等信息
  • server 服务端资源文件, Dockerfile 生成镜像时所需
  • docker-compose.yml docker 服务配置启动文件
  • Dockerfile go程序镜像构建文件
film                               
├─ data                            
│  ├─ nginx                        
│  │  ├─ html                          
│  │  └─ nginx.conf                
│  └─ redis                        
│     └─ redis.conf                
├─ server                          
├─ docker-compose.yml              
├─ Dockerfile                      
└─ README.md                       

此目录下的client内容和server内容并不一定与client同步 (小更新可能不会实时同步到运行服务器上)

可自行将根目录下的server和client内容与此目录下的对应文件进行替换

2. 程序构建运行

1. 环境准备

  1. Linux 服务器
  2. 安装 docker, docker compose 服务
# Centos 系统安装Docker Engine示例
# 1. 卸载旧版本Docker
sudo yum remove docker \
                  docker-client \
                  docker-client-latest \
                  docker-common \
                  docker-latest \
                  docker-latest-logrotate \
                  docker-logrotate \
                  docker-engine

#2. 设置存储库
sudo yum install -y yum-utils
sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
#3. 安装最新版本Docker
$ sudo yum install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin
#启动 Docker 服务
sudo systemctl start docker

2. 启动流程

如果使用默认配置信息,则执行如下流程

  • 将本项目中的 film 文件夹完整的上传到服务器的 /opt/ 目录下 (放在其他目录下时需同步修改 Dockerfile 以及 docker-compose.yml 文件中的相关路径)
  • 进入服务器中的 /opt/film/ 目录并执行 docker compose build 构建相关docker镜像
  • /opt/film/ 目录下执行命令 docker compose up -d (后台运行服务)
  • 使用 docker ps 命令查看相关服务是否成功启动
  • 等待后端程序初始化工作和数据爬取, 大概3~8分钟左右
  • 停止服务 docker compose down
  • 查看服务容器运行状态 docker ps
  • 在浏览器中访问管理后台: http://xxx.xxx.xxx/manage,
  • 登录 默认 用户名 密码: admin admin
  • 使用后台功能中的采集管理功能进行影视数据采集 (采集任务开启后需等待一段时间)
  • 浏览器中访问前台地址查看效果, 例: http://xxx.xxx.xxx/index (点击管理后台的logo菜单可直接跳转到前台页面)

3.服务配置信息修改

  • film 后端接口服务配置, film/server 下存放了程序的构建文件, 修改后重新构建镜像即可
  • mysql 用户名密码和端口信息直接修改 docker-compose.yml 文件中的相关配置即可
  • redis 服务信息配置需修改 /film/data/redis/redis.conf 文件
  • nginx 配置文件 /film/data/nginx/nginx.conf

注意事项

  • mysql 和 redis 服务配置修改后需要同步修改 /film/server/config/DataConfig.go 中的连接地址和账户名信息
## 配置使用的用户名密码信息需和ocker-compose.yml文件中设置的一致
const (
	// mysql服务配置信息修改
	mysqlDsn = "用户名:密码$@(服务名:服务端口)/FilmSite?charset=utf8mb4&parseTime=True&loc=Local"

	/*
		redis 配置信息
		RedisAddr host:port
		RedisPassword redis访问密码
		RedisDBNo 使用第几号库
	*/
	RedisAddr = `服务名:服务端口`
	RedisPassword = `密码`
	RedisDBNo = 0
)
## docker-compose.yml (设置服务的启动端口和服务名以及账户密码信息)
mysql:
    container_name: film_mysql
    image: mysql
    ports:
    - 3610:3306
    environment:
      MYSQL_ROOT_PASSWORD: root
      MYSQL_DATABASE: FilmSite
 redis:
    container_name: film_redis
    image: redis
    ports:
      - 3620:6379

4. 常见问题

  1. CPU 架构为 ARM 的服务器部署时 需修改Dockerfile 文件中的 GOARCH=amd64GOARCH=arm
  2. 服务器内存偏小时, 可能自行将redis容器关闭, 需在宿主机 /etc/sysctl.conf 文件中追加 vm.overcommit_memory = 1 配置, 并执行 sysctl vm.overcommit_memory=1 使其生效

5. 管理后台基本使用说明

  • 访问 http://xxx.xxx.xxx/manage 进行登录, 用户名 密码: admin admin , 登录成功后自行修改
  • 使用 采集管理 -> 影视采集 功能进行采集站信息的添加和更新, 系统初始化时有预留站点信息, 自行斟酌选择
  • 首先选择一个站点为主站点, 然后选择 采集一周, 一天, 或 全部, 进行主站点的数据采集, (前台数据全来自于主站点, 因此主站点只需要存在一个, 否则会冲突)
  • 主站点信息采集完成后则可在 影片管理 -> 影视分类 中进行主页分类展示信息的设置, 选择需要展示的分类信息, 以及分类的名称管理 (自行摸索如何使用)
  • 附属站点即影片的多个播放来源, 可自行进行选择性的采集添加
  • 定时任务:
    • 系统默认添加一条规则, 但未启用, 该规则为每20分钟更新一次所有已开启的采集站的近3小时内更新的数据, 开启后则基本满足资源更新需求
    • 可自定义定时任务, 使用相关功能可自主选择对某些站点进行定时更新功能