文档贡献 | 技术文档贡献流程及注意事项(保姆级教程)
内容目录
一、注册流程
二、创建分支(Fork)
三、使用GitLab界面更新文件的MR流程
四、使用Git命令行工具更新文件的MR流程
五、注意事项
一、注册流程
1、注册页面
在长安链平台注册页面,输入手机号码 ,点击 “获取验证码”。注册即表示同意《长安链用户使用协议》《长安链服务条款》《长安链用户隐私保护协议》,填写完成后点击 “注册” 。若已有账号,可点击 “回到登录”。
2、注册成功后,按照要求填写邮箱等信息
系统会发送一封邮件到填写的邮箱,邮件中包含激活链接,点击 “Confirm your email address” 进行邮箱激活。
激活后账号方可正常使用。
其他:
点击“Update profile settings”,完成信息更新。
进入项目主页,可按照进行邮箱填写的完成检查,如果前面步骤均已完成,此步骤可忽略。
注册完成后,若想使用 “邮箱 + 密码” 登录,需按照提示,点击 “set a password”,跳转至密码设置页面进行密码设置。设置完成后,在登录页面,输入已激活的邮箱和设置好的密码,即可登录长安链代码托管平台。
注册流程到此结束,接下来可开展具体的开发任务。
二、创建分支(Fork)
1、项目页面
登录后,进入长安链项目页面,找到感兴趣的项目(如 chainmaker-docs) ,点击项目名称进入项目详情页。
2、创建分支
在项目详情页中,点击 “Fork” 按钮,选择要创建分支的命名空间,点击 “Select” 完成分支创建
3、查看分支
创建成功后,可在 “Your projects” 中查看新创建的分支
三、使用GitLab界面更新文件的MR流程
1、进入项目仓库,找到要更新的文件(如 readme.md),点击文件名进入文件详情页
2、在文件详情页中,点击 “Edit” 按钮,对文件内容进行修改
例如,将 “联系电话” 修改为 “电话”。修改完成后,在 “Commit message” 中填写修改说明(如 “Update readme.md communicate”),选择目标分支(通常为 develop),点击 “Commit changes” 提交修改 。
3、修改提交成功
4、创建 Merge Request
提交修改后,点击 “New merge request” 创建合并请求。
在 “Source branch” 和 “Target branch” 中选择相应分支。
·源分支 (Source Branch):包含待合并变更的起始分支(通常是您的功能分支或修复分支);
·目标分支 (Target Branch):接收合并变更的基准分支(如发布分支);
填写 “Title” 和 “Description”(如 “测试:将‘联系电话’修改为‘电话’” )。
确认无误后点击 “Compare branches and continue” 。
5、合并请求详情
在合并请求详情页中,可查看请求的详细信息,如提交者、提交时间、修改内容等,等待管理员审核并合并请求。
【注意】错误:CLA未签署!
按照提示进入https://chainmaker.org.cn/user/cla,进行CLA签署。
【注意!】gitlab id和邮箱信息务必填写正确且对应 否则平台仍然会提示CLA未签署!
其中,“GitLab-ID”为下图“@”后的内容。
信息填写完整后确认签署。
签署成功。
等待管理员合并请求。
管理员合并请求。
合并成功后可查看文件修改情况。
合并成功。
查看修改情况:
修改成功。
四、使用Git命令行工具更新文件的MR流程
1、 准备工作
(1) Fork 主仓库
1.访问主仓库(如 https://git.chainmaker.org.cn/chainmaker/chainmaker-docs)
2.点击 Fork 创建个人副本仓库(如 your-username/chainmaker-docs)
(2) 克隆你的 Fork 仓库
git clone git@git.chainmaker.org.cn:your-username/chainmaker-docs.git
cd chainmaker-docs
【注意】需要在gitlab上事先配置SSH
配置流程:
终端获取ssh公钥:
cat ~/.ssh/id_rsa.pub
获取后复制公钥。
(3) 添加上游仓库(主仓库)
git remote add upstream git@git.chainmaker.org.cn:chainmaker/chainmaker-docs.git
git fetch upstream
2、创建功能分支
(1) 从主仓库的最新 develop 分支创建新分支
git checkout -b docs/your-feature-name upstream/develop
·分支命名建议:docs/xxx(文档类)、fix/xxx(修复类)、feat/xxx(新功能)
3、修改代码并提交
(1) 修改文件
vim README.md # 或其他文件
(2) 提交更改
git add .
git commit -m "fix: 更新 README 中的联系邮箱"
·Commit 规范:
-fix: 表示问题修复
-feat: 表示新功能
-docs: 表示文档更新
4、推送到你的 Fork 仓库
git push -u origin docs/your-feature-name
·-u 设置远程跟踪分支,后续可直接 git push
5、创建 Merge Request (MR)
(1) 访问 GitLab 仓库页面
进入你的 Fork 仓库(https://git.chainmaker.org.cn/your-username/chainmaker-docs)
(2) 点击 Create Merge Request
·Source branch: docs/your-feature-name(你的分支)
·Target branch: 主仓库的分支(如v2.3.6分支)
·填写 MR 信息:
-Title: fix: 更新 README 中的联系邮箱
-Description: 描述修改内容(可选附加截图或测试说明)
(3) 提交 MR
·等待维护者审核
·如需修改,继续在本地提交并 git push 更新 MR
(4) 删除远程分支
git push origin --delete docs/your-feature-name
MR流程到此结束。
五、注意事项
【注意-1】修改页面显示语言为中文
点击右上角头像→点击“Preferences”。
滑动至页面底部,找到“Localization”的“Language”选项,选择熟悉的页面语言。
【注意-2】Gitlab中已fork代码与官方原项目代码同步问题
·通过可视化页面同步最新项目代码
1.在GitLab上,导航到你的Fork仓库页面。
2.点击左侧栏中“Settings”选项卡。
3.找到“Advanced”部分,点击“Expend”后,选择“Delete project”。
4.重新fork分支。
·通过Git命令行同步最新项目代码
1.克隆你的fork到本地:
git clone https://github.com/your-username/your-fork.git
2.确认你的remote中已经添加了上游地址,【如果已经存在上游地址,则可以跳过第4步】:
git remote -v
3.进入克隆的目录:
cd your-fork
4.添加原始项目的远程仓库:
git remote add upstream https://github.com/original-owner/original-project.git
5.拉取原始项目的最新更改:
git fetch upstream
6.切换到主分支(以main为例):
git checkout main
7.合并原始项目的更改到你的分支(如果有冲突,解决冲突并提交更改):
git merge upstream/main
8.将更新推送到你的fork:
git push origin main
【提示-3】关于普通MR与Draft MR
Merge Request(MR)是 GitLab提供的代码审查与合并机制,用于将一个分支的变更合并到另一个分支(如 main 或 develop)。Draft MR(草稿合并请求)是标记为“未完成”的 MR,用于提前发起审查(代码未完成时获取早期反馈)、阻塞自动合并(防止误合并半成品代码)、协作讨论(团队成员可提前评论或提出建议)。
核心规则:同一分支不能同时存在多个活跃 MR(目标分支相同)。
Merge requests与Draft merge requests的区别:
如何使用 Draft MR?
1.创建 MR 时勾选 "Mark as draft" 复选框。
2.或在 MR 标题前添加 Draft: 或 WIP:(如 Draft: 用户登录功能)。
3.将 Draft MR 转为就绪状态:① 在 MR 页面点击 "Mark as ready"。② 或修改标题,移除 Draft:/WIP: 前缀。
常见问题与注意事项
Q:能否对同一分支提交多个 Draft MR?
·允许,但目标分支必须不同(例如:feature/login → main 和 feature/login → staging)。
·禁止同一分支对同一目标分支提交多个 MR(无论是 Draft 还是普通 MR)。
【注意-4】提交MR,出现“Validate branches Another open merge request already exists for this source branch”报错
可以看到是因为有提交的MR未审核的原因,可以和社区联络推动加快审核或关闭无效的MR。
若是无用请求,点击“Close merge request”,关闭没用的MR。
问题解决。
【注意-5】遇见创建MR冲突,关闭无用MR需要在目标仓库close MR ,而不是在源仓库
由于不能同一分支对同一目标分支提交多个 MR,当遇到创建MR冲突时我们需要关闭之前创建的无用MR,这就需要在目标仓库关闭MR。
重复MR报错提醒:
为了关闭无用MR,进入目标仓库查看:
点击“Close merge request”关闭无用仓库:
相关文章:

文档贡献 | 技术文档贡献流程及注意事项(保姆级教程)
内容目录 一、注册流程 二、创建分支(Fork) 三、使用GitLab界面更新文件的MR流程 四、使用Git命令行工具更新文件的MR流程 五、注意事项 一、注册流程 1、注册页面 在长安链平台注册页面,输入手机号码 ,点击 “获取验证码”…...

open-vscode-server +nodejs 安装
GitCode - 全球开发者的开源社区,开源代码托管平台GitCode是面向全球开发者的开源社区,包括原创博客,开源代码托管,代码协作,项目管理等。与开发者社区互动,提升您的研发效率和质量。https://gitcode.com/gh_mirrors/op/openvscode-server/?utm_sourceartical_gitcode&ind…...

知行之桥如何将消息推送到钉钉群?
在钉钉平台中,机器人主要分为企业机器人和自定义机器人两类。本文将重点介绍如何通过自定义机器人,实现将知行之桥 EDI 系统的通知消息高效推送至钉钉群,帮助企业第一时间掌握业务动态。 一、在钉钉群中添加自定义机器人 在需要接收知行之桥…...

09《从依赖管理到容器化部署:Maven 全链路实战笔记,解锁 Java 项目自动化构建的终极奥秘》
目录 一、Maven 核心基础强化 (一)Maven 架构与工作原理 1. 核心组件解析 2. 工作流程图示编辑 (二)项目结构深度实践 1. 标准目录扩展说明 2. 多模块项目典型结构示例编辑 二、依赖管理高级进阶 (一&…...

<el-date-picker>组件传参时,选中时间和传参偏差8小时
遇到一个bug,不仔细看,都不一定能发现,bug描述:我们有一个搜索框,里面有一个时间选择器,当我使用<el-date-picker>时,我发现当我选择时分秒之后,显示都正常,但是当…...

ST MCU CAN模块--TTCAN模式浅析
ST MCU CAN模块使用总结 1 前言 传统CAN 采用事件触发消息传输机制,CSMA/ CD AMP( Carrier-Sense Mult iple Access w ith Co llision Detect ion and Arbit ration on Message Priorit ies, 载波侦听、多路访问、冲突检测、优先级仲裁) 介质访问控制机制, 即多个消息同时…...
MySQL数据库零基础入门教程:从安装配置到数据查询全掌握【MySQL系列】
第1章:认识MySQL 1.1 什么是MySQL? MySQL是一种开源的关系型数据库管理系统(RDBMS),由瑞典MySQL AB公司开发,现由Oracle公司维护。它使用结构化查询语言(SQL)进行数据库的管理和操…...
动态规划(7):背包问题
引言 背包问题是动态规划中最经典、最重要的问题类型之一,它不仅在算法竞赛中频繁出现,也在实际应用中有着广泛的用途。从资源分配到投资组合优化,从生产计划到网络路由,背包问题的思想几乎无处不在。正因如此,背包问题被誉为动态规划的"必修课",掌握背包问题…...

谷歌浏览器Google Chrome v137.0.7151.41 中文版本版+插件 v1.11.1
一、软件介绍 这个版本解压就可以用,界面是中文的。 保留了核心功能, 二、软件特点 便携性 :解压即可使用,不想用了直接删掉整个文件夹。 增强功能 :通过Chrome增强软件劫持补丁chromev1.11.1 x64 (version.dll)实现多…...
《深入解析UART协议及其硬件实现》-- 第三篇:UART ASIC实现优化与低功耗设计
第三篇:UART ASIC实现优化与低功耗设计 1. ASIC与FPGA设计差异 1.1 标准单元库选型 库类型对设计的影响 : 高性能库(High-Speed) :使用低阈值电压晶体管,速度快但漏电功耗高,适合关键路径优化…...
Hadoop常用端口号和配置文件
常用端口号有: hadoop2.x Hadoop3.x 访问HDFS端口 50070 9870 访问MR执行情况端口 8088 8088 历史服务器 19888 19888 客户端访问集群端口 9000 8020 常用配置文件 hadoop2.x core-site.xml、hdfs-site.xml、mapred-site.xml、yarn-si…...
Apache Paimon:存储结构、写入及其源码分析
Apache Paimon (此前称为 Flink Table Store)是一种流式数据湖存储技术,采用 LSM(Log-Structured Merge-tree)树结构来存储数据,支持高吞吐、低延迟的数据摄入和实时查询,尤其适用于流式和批量统一的场景。 1. 创建表…...
19、Python字符串高阶实战:转义字符深度解析、高效拼接与输入处理技巧
适合人群:零基础自学者 | 编程小白快速入门 阅读时长:约6分钟 文章目录 一、问题:Python的转义字符?1、例子1:快递地址格式化打印2、答案:(1)转义字符 二、问题:Python的…...

国芯思辰| 同步降压转换器CN2020应用于智能电视,替换LMR33620
在智能电视不断向高画质、多功能、智能化发展的当下,其内部电源管理系统的性能至关重要。同步降压转换器可以为智能电视提供稳定、高效的运行。 国芯思辰CN2020是一款脉宽调制式同步降压转换器。内部集成两个功率MOS管,在4.5~18V宽输入电压范围内可以持…...
6个月Python学习计划 Day 8 - Python 函数基础
第一周 Day 1 - Python 基础入门 & 开发环境搭建 Day 2 - 条件判断、用户输入、格式化输出 Day 3 - 循环语句 range 函数 Day 4 - 列表 & 元组基础 Day 5 - 字典(dict)与集合(set) Day 6 - 综合实战:学生信息…...

DeepSeek 提示词大全
目录 前言一、提示词基础理论 什么是提示词提示词的类型提示词的基本结构 二、提示词设计原则 明确指令结构化表达情境化需求渐进式引导边界与限制 三、场景化提示词模板 写作创作类角色扮演类信息提取类代码编程类教育学习类商业营销类生活助手类 四、提示词优化技巧 迭代式优…...

俄罗斯无人机自主任务规划!UAV-CodeAgents:基于多智能体ReAct和视觉语言推理的可扩展无人机任务规划
作者:Oleg Sautenkov 1 ^{1} 1, Yasheerah Yaqoot 1 ^{1} 1, Muhammad Ahsan Mustafa 1 ^{1} 1, Faryal Batool 1 ^{1} 1, Jeffrin Sam 1 ^{1} 1, Artem Lykov 1 ^{1} 1, Chih-Yung Wen 2 ^{2} 2, and Dzmitry Tsetserukou 1 ^{1} 1单位: 1 ^{1} 1斯科尔…...

结构性设计模式之Bridge(桥接)
结构性设计模式之Bridge(桥接) 摘要 桥接模式是一种结构性设计模式,其核心思想是将抽象部分与实现部分分离,使二者能够独立变化。本文通过汽车产品生产案例(产品A/B与颜色红/蓝/黄)展示了桥接模式的应用&…...
CSS篇-1
1. CSS 有哪些基本选择器?它们的权重是如何表示的? 这是一个关于 CSS 基础且极其重要的问题,因为它直接关系到我们如何精准地控制页面元素的样式,以及在样式冲突时浏览器如何决定哪个样式生效。理解 CSS 选择器及其权重ÿ…...

Android 16系统源码_无障碍辅助(一)认识无障碍服务
前言 Android 的无障碍辅助功能(Accessibility)是一套专为残障用户或特殊场景设计的核心技术框架,旨在让所有用户都能便捷地操作设备。其功能覆盖视觉、听觉、运动能力和认知障碍支持,同时为开发者提供标准化 API 以实现应用适配…...

分布式数据库备份实践
在分布式备份中可以采取两种方式进行备份,一种是采用手动编写backup.yml文件进行备份,另外一种是吧备份过程交给备份工具自动执行。如果需要个性化进行备份,建议采用手动编写备份文件方式进行备份。 以下是针对两种备份方式的实践:…...

如何发布npm包?
如何发布npm包? 1. 注册账号[npm官网](https://www.npmjs.com/)2. 检查 npm 源是否在官方 npm 仓库,如果不在,进行切换3. 检查4. 打包配置5. 发布6. 使用错误:版本更新命令 1. 注册账号npm官网 2. 检查 npm 源是否在官方 npm 仓库…...
鸿蒙---使用真机模拟器的时候,图片不加载问题
使用真机模拟器的时候,图片不加载问题 解决方案: 1,找到 module.json5 文件,路径 entry -> src -> main -> module.json5 2,在module.json5 文件中,开头的’module’中添加 "requestPermiss…...

实验设计与分析(第6版,Montgomery)第5章析因设计引导5.7节思考题5.6 R语言解题
本文是实验设计与分析(第6版,Montgomery著,傅珏生译) 第5章析因设计引导5.7节思考题5.6 R语言解题。主要涉及方差分析,正态假设检验,残差分析,交互作用图,等值线图。 dataframe <-data.frame…...
.NET 8使用AOT发布ASP.NET Core应用
.NET 8 使用 AOT 发布 ASP.NET Core 应用 一、AOT 编译简介 在 .NET 开发中,编译方式有多种,其中 AOT(Ahead-Of-Time)编译是一种区别于传统 JIT(Just-In-Time)编译的方式。传统的 JIT 编译是在 .NET 应用…...

OpenCV计算机视觉实战(8)——图像滤波详解
OpenCV计算机视觉实战(8)——图像滤波详解 0. 前言1. 线性滤波1.1 均值滤波1.2 高斯滤波1.3 拉普拉斯滤波1.4 Sobel 滤波 2. 非线性滤波3. 自定义卷积核小结系列链接 0. 前言 在本文中,我们将深入探索线性与非线性滤波的算法原理、性能优化及…...
Docker 前端镜像容器部署指南
1. 编写 Dockerfile 文件 # 使用轻量级的 Nginx Alpine 作为基础镜像 FROM nginx:alpine# 设置工作目录 WORKDIR /usr/share/nginx/html# 删除默认的 Nginx 静态文件 RUN rm -rf ./*# 复制本地 dist 目录下的文件到容器中 COPY ./dist /usr/share/nginx/html# 暴露容器端口 EX…...
OpenAI大模型不听人类指令事件的技术分析与安全影响
OpenAI大模型不听人类指令事件的技术分析与安全影响 OpenAI大模型o3确实存在不遵从人类关闭指令的现象,这一行为已被第三方安全机构验证,但其本质是技术缺陷而非AI意识觉醒。帕利塞德研究所的测试显示,在100次实验中o3有7次成功绕过关闭指令…...
图神经网络实战——图的可视化
图神经网络实战——图的可视化 0. 前言1. networkx2. Gephi相关链接0. 前言 图结构可通过图形化方式直观呈现。节点通常用圆形表示,边则用连接线表示。 然而当节点和边数量增加时,绘制清晰的图形表示可能会变得相当困难,这主要源于节点在二维坐标系中的布局问题。对于包含数…...

自动化安全脚本学习
1.目录扫描器 目标:使用python编写一个自动化目录扫描工具,实现简单信息收集,判断目标网站是否存在常见路径。 import requests #用于发HTTP请求 from concurrent.futures import ThreadPoolExecutor #实现多线程扫描# 扫描目标 target h…...