docker

关注公众号 jb51net

关闭
首页 > 网站技巧 > 服务器 > 云和虚拟化 > docker > docker AI-Codereview-Gitlab部署

基于docker的AI-Codereview-Gitlab部署实战教程

作者:一点空白

AI-Codereview-Gitlab是一个基于大模型的自动化代码审查工具,帮助开发团队在代码合并或提交时,快速进行智能化的审查(Code Review),提升代码质量和开发效率,这篇文章主要介绍了基于docker的AI-Codereview-Gitlab部署实战 ,需要的朋友可以参考下

AI-Codereview-Gitlab是一个基于大模型的自动化代码审查工具,帮助开发团队在代码合并或提交时,快速进行智能化的审查(Code Review),提升代码质量和开发效率。

主要功能

工作原理

当用户在 GitLab 上提交代码(如 Merge Request 或 Push 操作)时,GitLab 将自动触发 webhook事件,调用本系统的接口。系统随后通过第三方大模型对代码进行审查,并将审查结果直接反馈到对应的 Merge Request 或 Commit 的Note 中,便于团队查看和处理。

以上均为官方描述,下面进行实战部署操作。

部署实战

官方给了两种部署方案,分别是Docker部署和本地Python环境部署,我们采用的是第一种,并且根据实战操作对部分内容进行了修改。

1. 前期环境准备

操作系统:centos7

Docker版本:24.0.0

Docker-Compose版本:v2.28.0

git版本:1.8.3.1

2.获取源码

实战命令(由于访问GitHub经常超时或者时间较长):

cd /opt
git clone https://gitcode.com/gh_mirrors/ai/AI-Codereview-Gitlab.git
cd AI-Codereview-Gitlab

官方命令:

cd /opt
git clone https://github.com/sunmh207/AI-Codereview-Gitlab.git
cd AI-Codereview-Gitlab

3. 配置文件

获取源码后,在AI-Codereview-Gitlab目录下,创建配置文件,执行如下命令:

cp conf/.env.dist conf/.env
vim conf/.env

编辑 conf/.env 文件,配置以下关键参数:

大模型供应商配置参数,此处采用本地ollama部署的Deepseek:32B的大模型,因此修改如下参数部分:

#大模型供应商配置,支持 deepseek, openai,zhipuai,qwen 和 ollama
LLM_PROVIDER=ollama
...
#OllaMA settings; 注意: 如果使用 Docker 部署,127.0.0.1 指向的是容器内部的地址。请将其替换为实际的 Ollama服务器IP地址。
OLLAMA_API_BASE_URL=http://127.0.0.1:11434
OLLAMA_API_MODEL=deepseek-r1:32b
...

Gitlab配置,由于本地GitLab端口不是默认80,因此修改如下参数部分:

#Gitlab配置
GITLAB_URL=http://192.168.1.111:9080/ #部分老版本Gitlab webhook不传递URL,需要开启此配置,示例:https://gitlab.example.com
#GITLAB_ACCESS_TOKEN={YOUR_GITLAB_ACCESS_TOKEN} #系统会优先使用此GITLAB_ACCESS_TOKEN,如果未配置,则使用Webhook 传递的Secret Token

同时还需要修改api.py文件内容,修改内容如下:

将
def handle_github_webhook(event_type, data):
    # 获取GitHub配置
    github_token = os.getenv('GITHUB_ACCESS_TOKEN') or request.headers.get('X-GitHub-Token')
...
改为:
def handle_github_webhook(event_type, data):
    # 获取GitHub配置
    github_token = os.getenv('GITHUB_ACCESS_TOKEN')
...

4. 镜像修改

官方配置的镜像源部分位于境外,导致部署过程中下载较慢或者网络异常,因此需要修改docker-compose.yml和Dockerfile中的部分参数,具体如下:

修改Dockerfile中Python 基础镜像和依赖源参数:

# 使用官方的 Python 基础镜像改为swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/python:3.10-slim国内
FROM swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/python:3.10-slim AS base
...
# 安装依赖加上国内源
RUN pip install --no-cache-dir -r requirements.txt -i https://pypi.mirrors.ustc.edu.cn/simple/

修改完成后进行保存。

5. 启动服务

docker-compose up -d

6. 验证部署

7. 配置 GitLab Webhook

创建Access Token

方法一:在 GitLab 个人设置中,创建一个 Personal Access Token。

方法二:在 GitLab 项目设置中,创建Project Access Token。

注:创建的Access Token需要复制后单独保存,否则无法再次获取。

配置 Webhook

在 GitLab 项目设置中,配置 Webhook:

备注

8. 配置消息推送

配置钉钉推送

更新 .env 中的配置:

#钉钉配置
DINGTALK_ENABLED=1  #0不发送钉钉消息,1发送钉钉消息
DINGTALK_WEBHOOK_URL=https://oapi.dingtalk.com/robot/send?access_token=xxx #替换为你的Webhook URL

企业微信和飞书推送配置类似。

最终效果

到此这篇关于基于docker的AI-Codereview-Gitlab部署实战教程的文章就介绍到这了,更多相关docker AI-Codereview-Gitlab部署内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文