| <!-- |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you under the Apache License, Version 2.0 (the |
| * "License"); you may not use this file except in compliance |
| * with the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| --> |
| |
| # 关于社区 |
| |
| ## 社区组织架构 |
| |
| 所有抱着推动 Apache IoTDB 前进的共同目的、认同开源文化、遵循相关规范的个人或团体凝聚起来形成了我们的社区。 |
| 参考 Apache 基金会的社区理念,我们的社区存在以下四种身份。 |
| |
| - PMC:Project Management Committee,项目管理委员会成员。需通过评选,得到社区的共同认同。 |
| - 权利: |
| - 对于项目重大决定的投票权 |
| - 获得 PMC 奖杯与礼品 |
| - Committer 的所有权利 |
| - 义务: |
| - 对项目的开发迭代和社区活动的运转提供重要支持 |
| - 指导项目的开源布道和未来发展方向 |
| - Committer 的所有义务 |
| - Committer:对项目的前进有较大帮助的社区成员。需通过评选,得到社区的共同认同。 |
| - 权利: |
| - Pull Request approve 权限(binding) |
| - Merge Pull Request 权限 |
| - 发布新版本权限 |
| - 获得 Committer 奖杯与礼品 |
| - 义务: |
| - 积极参与项目讨论,对项目重大决策给予建议 |
| - 社区咨询支持 |
| - 社区开发或宣传任务支持 |
| - Contributor:对项目的前进有相关贡献的社区成员。无需通过评选。 |
| - 权利: |
| - Pull Request approve 权限 |
| - 获得 Contributor 奖状与礼品 |
| - User: Apache IoTDB 项目的用户。无需通过评选。 |
| - 权利: |
| - 获得 User 礼品 |
| |
| ## 社区评选规章 |
| |
| ### PMC |
| |
| - 获得现有 PMC 的推荐 |
| - 技术层面: |
| - 对项目的整体情况有较全面的了解 |
| - 发展层面: |
| - 对时序数据库行业有深刻见地,并能把握项目发展方向 |
| - 文化层面: |
| - 对开源文化有较强认同感,为项目的开源布道做出贡献 |
| |
| ### Committer |
| |
| - 获得现有 PMC 的推荐 |
| - 开发者途径 |
| - 需对对某个功能模块完全了解 |
| - 开源布道师途径 |
| - 对项目的开源布道起到实质的推进作用,如沉淀技术文档、提供与宣讲用户案例、积极参与社区交流与活动等 |
| - - 了解 Apache Software Foundation 的行为准则 |
| - 请参阅 [ASF 文档](https://www.apache.org/foundation/policies/conduct.html)。特别是,他们致力于: |
| - 保持开放 |
| - 保持善解人意 |
| - 保持热情 |
| - 保持友善 |
| - 保持有耐心 |
| - 团队协作力强 |
| - 好奇心强 |
| - 注意言行 |
| - 恪守 Apache Software Foundation 提交者的职责 |
| - 请参阅 [ASF 文档](https://www.apache.org/dev/committers.html#committer-responsibilities)。 |
| - 他们帮助创造的是一个产品,而不仅仅是某个贡献者的兴趣 |
| - 他们维护 Apache 社区的健康,并帮助社区成长 |
| - 他们帮忙做一些周边工作,例如维护网站、维护文档。 |
| - 他们帮助用户 |
| - 可以信任他们来决定何时准备发布代码,或何时需要别人一起做出判断。 |
| - 可以信任他们来决定何时合并代码(如果是代码贡献者),或何时需要别人一起做出判断。 |
| - 加强 IoTDB 社区的实践 |
| - 他们对项目有坚定的承诺 |
| - 他们与社区分享他们的想法 |
| - 他们接受社区反馈并将其整合到他们的计划,设计,代码等中。 |
| - 他们认真地尝试通过贡献使 IoTDB 更好 |
| - 特别是,如果代码贡献者: |
| - 他们认真尝试通过自己的代码使 IoTDB 更好 |
| - 他们认真地尝试通过代码审查使 IoTDB 更好 |
| - 他们接受并整合有关其代码的反馈 |
| - 他们在查看/合并代码(样式,文档,测试,向后兼容性等)时了解、遵守并不断优化 IoTDB 的专家服务。 |
| |
| ### Contributor |
| |
| - 创建开发平台账号: |
| - 创建 Jira 账号:[https://issues.apache.org/jira/projects/IOTDB/issues](https://issues.apache.org/jira/projects/IOTDB/issues) ,用来认领 issue。 |
| - 创建 Confluence 账号:[https://cwiki.apache.org/confluence/display/IOTDB/Home](https://cwiki.apache.org/confluence/display/IOTDB/Home) ,之后用来写设计文档。 |
| 创建好后,向邮件列表发送一封邮件,包括 **自我介绍** 以及 **Jira ID** 和 **Confluence ID**,社区 PMC 会为账户添加权限。 |
| - 长期事项: |
| - 学习如何调试 IoTDB |
| - [如何调试 IoTDB server](https://my.oschina.net/u/3664598/blog/4500279) |
| - 学习 IoTDB 的基本使用 |
| - [IoTDB 下载与安装](../UserGuide/latest/Deployment-and-Maintenance/IoTDB-Package_apache.md) |
| - [IoTDB 快速上手](https://iotdb.apache.org/zh/UserGuide/Master/QuickStart/QuickStart.html) |
| - [数据模式与概念](https://iotdb.apache.org/zh/UserGuide/latest/Basic-Concept/Data-Model-and-Terminology.html) |
| - [API 接口](https://iotdb.apache.org/zh/UserGuide/latest/API/Programming-Java-Native-API.html) |
| - 了解 IoTDB 的内部设计 |
| - [IoTDB 设计文档](https://cwiki.apache.org/confluence/display/IOTDB/Home) |
| - 寻找待做任务 |
| - [在 Jira 上解决 issue](https://issues.apache.org/jira/projects/IOTDB/issues) |
| |
| ## 社区公约 |
| |
| 遵循 Apache 的社区文化,形成以下公约。 |
| |
| 1. 保持开放。我们诚邀各位加入我们的社区。除了敏感内容以外,我们期待大家在公开的渠道对项目有关内容展开讨论。这也适用于寻求帮助和项目支持的消息; 不仅仅是群众的支持请求更有可能得到问题的答案,还可以确保社区注意到并纠正回答该问题的人无意间犯的错误。 |
| 2. 拥有同理心、热情、友好和耐心。我们共同努力解决矛盾,怀揣善意,并尽最大努力以一种感同身受的方式行动。我们可能会遭受一些挫折,但这并不是进行人身攻击的借口。一个让人感到不舒服或受到威胁的社区不会成为一个卓有成效的社区。 我们应该对打交道的社区成员和社区外部人员都给予尊重。 |
| 3. 懂得协作。我们会互相依赖彼此的工作。我们积极向他人说明我们为项目发展所做的工作,解释相关的原理。那么他们可以在我们原有的基础上进一步提高。我们做出的任何决定都会影响到用户和同事,所以我们在做出决定时必须认真考虑可能产生的后果。 |
| 4. 有一颗好奇心。没有人能知道一切。尽早提出问题可以避免以后出现很多问题,所以我们鼓励大家提出问题,虽然我们可能会将一些问题引导到更合适的论坛。出于我们优化项目代码的共同目标,那些收到问题的人会积极响应并提供帮助。 |
| 5. 注意我们的用词。无论我们是以专业人士还是志愿者的身份参与,我们在所有的互动中都要重视专业精神并对自己的言论负责。善待他人。不要侮辱或贬低其他参与者。骚扰和排斥行为是不允许的。这包括但不限于: |
| - 针对他人的暴力威胁或语言。 |
| - 性别歧视、种族歧视或其他歧视性的笑话和语言。 |
| - 发布色情或暴力内容。 |
| - 发布(或威胁他人发布)其他人的个人身份信息。 |
| - 分享私人内容,如私人或非公开形式发送的电子邮件,或从未登录的论坛,如 IRC 频道历史记录。 |
| - 侮辱他人,尤指使用种族主义或性别歧视用语。 |
| - 骚扰性言语和行为。 |
| - 不文明用语。 |
| - 反复骚扰他人。一般来说,如果别人不希望你继续说下去,那就停下来。 |
| - 提倡或鼓励上述任何行为。 |
| 6. 注意简洁。请记住,随着时间的推移,成百上千的人会读到你写的东西。写一封简短的电子邮件意味着人们可以尽可能高效地理解对话内容。简短的电子邮件应该尽量表现出感同身受、热情、友好和耐心。当需要一个很长的说明时,请考虑在信息的顶部添加一个摘要。 |
| 试着在对话中加入新的想法,这样每封邮件都能给讨论增加一些新的内容。但是请注意,不要忽略已经讨论过的内容。 |
| 注意围绕主题,特别是在较长的讨论中。 |
| 7. 离开项目时请考虑周全。每个项目都会有人加入有人离开。在有人离开或退出项目时,应该告诉其他成员他们离开了,并通过合适的方式以确保其他成员可以接起他们留下的工作。同时,他们应尊重那些继续参与项目的人,不应该歪曲项目的目标或成就。同样,社区成员也应尊重离开项目的人所做的选择。 |
| |
| ## 社区发布新版本流程 |
| |
| ### 发布经理 |
| |
| 我们的项目指定一个提交者作为发布经理,负责发布的机制。发布经理引导从最初的社区共识到将编译的代码包最终分发,并可能参与向项目社区和 ASF 公开发布。 |
| |
| ### 流程总览 |
| |
| 社区发布新版本流程中有两类角色。 |
| |
| - 角色一:RM (发布经理,Release Manager),是发布新版本的发起人。一般为一个人而非多人承担这个角色。 |
| - 角色二:社区开发者。社区开发者将对新版本是否发布进行投票。值得提醒的是,不是所有的社区开发者都强制为新版本的发布进行投票。 |
| |
| 在我们的开源社区中,发布新版本主要由五步进行。 |
| |
| - 第一步 - RM 发起提议:由某位开发者自发作为 RM (发布经理,Release Manager)提起新版本发布的提议。通过邮件,发出相关提议。邮件发出的提议将对新版本的改进进行充分说明。 |
| - 第二步 - 社区开发者查看提议:当收到邮件之后,若社区开发者赞同相关提议,可以不回复相关邮件,默认认同提议。若社区开发者对新版本发布提议存在建议或质疑,可以回复邮件进行说明。 |
| - 第三步 - RM 发布内部测试版(Release Candidate):当社区开发者的建议得到充分考虑后,RM (发布经理,Release Manager)将发布内部测试版(Release Candidate),通过邮件来让大家进行新版本的测试并投票。 |
| - 第四步 - 社区开发者进行投票:社区开发者获取到内部测试版(Release Candidate)进行测验。测验后,通过邮件进行投票。 |
| - 第五步 - 投票通过后 RM 发布正式版本并对外公布:当投票情况符合相关条件,RM 发布正式版本,并通过邮件对外公布这个消息。(若投票失败,则通过邮件公布本次发布新版本失败,并在修改后,重新提起发布新版本的流程。此处将不对投票失败情况展开解释。) |
| |
| ### 常见问题 |
| |
| #### 问题一:作为社区开发者,如何验证新版本,来决定是否支持发布? |
| |
| 请见 <https://iotdb.apache.org/zh/Development/VoteRelease.html>。 |
| |
| #### 问题二:如何决定投票是否通过? |
| |
| 依据 Apache Software Foundation 给出的说明,我们将把投票窗口保留 72 小时及以上。当收到至少三票 PMC 赞同票并且赞同票多余反对票的时候,代表投票通过。投票的结果将由 RM (发布经理,Release Manager)汇总。RM 会通过邮件公布结果。 |
| |
| #### 问题三:作为新手 RM,是否有详细的实践指导? |
| |
| 对于新手的 RM (发布经理,Release Manager),我们提供了详细的实践指导。每一步需要做的事情做了详细的说明,请查看本页面“社区发布新版本流程”章节。 |