gitlab Clone Pull Push 日志信息
2020/12/11 8:25:32
本文主要是介绍gitlab Clone Pull Push 日志信息,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
背景:
公司抓信息安全,使用gitlab进行代码管理,要求所有用户的远程操作(推送、同步)都记录下来。
通过查看Gitlab官方文档,整理信息如下:
gitlab 后台的各种日志保存位置 /var/log/gitlab/
production.log
> 注意:本日志只记录通过http操作的日志
存放目录:/var/log/gitlab/gitlab-rails/
production_json.log
里面是Json请求串。
{ "method": "GET", "path": "/test_user/test_project.git/info/refs", "format": "*/*", "controller": "Projects::GitHttpController", "action": "info_refs", "status": 200, "duration": 268.22, "view": 0.48, "db": 14.41, "time": "2019-06-27T10:59:56.324Z", "params": [ { "key": "service", "value": "git-receive-pack" }, { "key": "namespace_id", "value": "test_user" }, { "key": "project_id", "value": "test_project.git" } ], "remote_ip": "192.168.XX.XX", "user_id": 3, "username": "test_user", "ua": "git/2.21.0.windows.1", "queue_duration": null, "correlation_id": "b02c02f9-0167-49bf-965f-e4cc86d6751f" }
日志中有价值的信息:
- 同步动作:
service:git-receive-pack
- 推送操作:
service:git-upload-pack
- 项目名:
project_id:test_project.git
- IP地址:
remote_ip:192.168.XX.XX
- 用户名:
username:test_user
- 时间:
time:2019-06-27T10:59:56.324Z
(UTC格式,加上8个小时等于北京时间) - 状态:
status:200
(200表示操作成功,其他表示失败) - 动作信息:
action:info_refs
(每次同步、推送操作出现的标志,需要通过这个字段来来筛选日志是否是更新或者推送操作)
对存在Json嵌套的数据操作,建议看看这篇文章,能够提高工作效率。
[Go 如何优雅的获取嵌套Json数据内容]www.bigyoung.cn/posts/153/
gitlab-shell.log
> **注意:此日志只记录Gitclone协议的操作
日志目录:/var/log/gitlab/gitlab-shell
以下日志就不是Json格式了,需要自己对字符串进行操作处理。
time="2019-07-02T11:17:48+08:00" level=info msg="executing git command" command="gitaly-receive-pack unix:/var/opt/gitlab/gitaly/gitaly.socket {\"repository\":{\"storage_name\":\"default\",\"relative_path\":\"test_user/test_project.git\",\"git_object_directory\":\"\",\"git_alternate_object_directories\":[],\"gl_repository\":\"project-5\",\"gl_project_path\":\"test_user/test_project\"},\"gl_repository\":\"project-5\",\"gl_project_path\":\"test_user/test_project\",\"gl_id\":\"key-3\",\"gl_username\":\"test_user\",\"git_config_options\":[],\"git_protocol\":null}" pid=23657 user="user with id key-3"
日志中有价值的信息:
- 同步动作:
command:gitaly-receive-pack
- 推送操作:
command:gitaly-upload-pack
- 项目名:
gl_project_path:test_user/test_project
- IP地址:
remote_ip:192.168.XX.XX
- 用户名:
gl_username:test_user
- 时间:
time:2019-07-02T11:17:48+08:00
(UTC格式,加上8个小时等于北京时间) - 状态:
status:200
(200表示操作成功,其他表示失败) - 动作信息:
action:info_refs
(每次同步、推送操作出现的标志,需要通过这个字段来来筛选日志是否是更新或者推送操作)
参考文档:
- [Gitlab官方日志解释文档]docs.gitlab.com/ee/administration/logs.html#production_jsonlog
> 本文首发于[BigYoung小站] bigyoung.cn
这篇关于gitlab Clone Pull Push 日志信息的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-09-20whatsapp webhook 回调的签名验证偶尔会失败是什么原因-icode9专业技术文章分享
- 2024-09-19Excel数据导出课程:初学者必备教程
- 2024-09-19Excel数据导入课程:新手入门指南
- 2024-09-19RBAC的权限管理入门教程
- 2024-09-19如何使用Svg Sprite Icon制作图标
- 2024-09-19uniapp 如何实现点赞后全局更新数据-icode9专业技术文章分享
- 2024-09-19云函数怎么运行wx-server-sdk-icode9专业技术文章分享
- 2024-09-19"dependencies": { "wx-server-sdk": "latest" },是什么意思-icode9专业技术文章分享
- 2024-09-16优化批处理流程:自定义BatchProcessorUtils的设计与应用
- 2024-09-15laravel collect游标批量插入的方法示例-icode9专业技术文章分享