- data 服务容器相关的数据和配置信息存放目录
- nginx
- html目录用于上传vite项目构建后的dist下的页面相关文件
- nginx.conf 配置后端接口的代理和端口等相关信息
- redis
- redis.conf 配置redis的远程访问和密码等信息
- nginx
- 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内容与此目录下的对应文件进行替换
安装说明:
- 新增 1Panel 安装方式(类似于宝塔, 宝塔要注册且下载很慢, 所以后续应该也不会出宝塔安装)
- Readme文件内容保持简洁, 所以详细安装说明放到GithubPage的博客页了
- 完整的详细安装文档请前往个人博客页查看: GoFilm安装文档
- Linux 服务器
- 安装 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
如果使用默认配置信息,则执行如下流程
- 将本项目中的 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菜单可直接跳转到前台页面)
- 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
- CPU 架构为 ARM 的服务器部署时 需修改Dockerfile 文件中的
GOARCH=amd64
为GOARCH=arm
- 服务器内存偏小时, 可能自行将redis容器关闭, 需在宿主机
/etc/sysctl.conf
文件中追加vm.overcommit_memory = 1
配置, 并执行sysctl vm.overcommit_memory=1
使其生效
- 访问 http://xxx.xxx.xxx/manage 进行登录, 用户名 密码:
admin admin
, 登录成功后自行修改 - 使用
采集管理 -> 影视采集
功能进行采集站信息的添加和更新, 系统初始化时有预留站点信息, 自行斟酌选择 - 首先选择一个站点为主站点, 然后选择 采集一周, 一天, 或 全部, 进行主站点的数据采集, (前台数据全来自于主站点, 因此主站点只需要存在一个, 否则会冲突)
- 主站点信息采集完成后则可在 影片管理 -> 影视分类 中进行主页分类展示信息的设置, 选择需要展示的分类信息, 以及分类的名称管理 (自行摸索如何使用)
- 附属站点即影片的多个播放来源, 可自行进行选择性的采集添加
- 定时任务:
- 系统默认添加一条规则, 但未启用, 该规则为每20分钟更新一次所有已开启的采集站的近3小时内更新的数据, 开启后则基本满足资源更新需求
- 可自定义定时任务, 使用相关功能可自主选择对某些站点进行定时更新功能