近期,我们在GitHub上开源了微服务任务调度框架SIA-TASK,82天,收获了1000+个star!由于这是SIA团队第一次开源项目,开源的相关工作,团队之前并没有太多的经验,因此我们特别整理了本次开源的各种记录事项,希望给今后开源的项目做参考。
创新互联专注为客户提供全方位的互联网综合服务,包含不限于做网站、成都网站制作、海盐网络推广、重庆小程序开发公司、海盐网络营销、海盐企业策划、海盐品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;创新互联为所有大学生创业者提供海盐建站搭建服务,24小时服务热线:18982081108,官方网址:www.cdcxhl.com
在开源项目的开发过程中要注意以下几点:
最后要说的就是开源协议的选择了,目前最流行的开源协议有以下六种:GPL、BSD、MIT、Mozilla、Apache和LGPL。
不同的开源协议之间的差别还是挺大的,具体如何选择,可以参考一张图看懂开源协议(https://blog.csdn.net/cwt19902010/article/details/53736746),如果这些常用的开源协议都不适合你的项目,你也可以自己写一个自己的开源协议。
为了更方便查看开源协议选择图,参考图如下:
以Apache License Version 2.0协议为例,比较常用协议与Apache协议冲突情况,冲突图如下:
项目开发完成之后,需要梳理出项目中使用到的协议(包含项目引用的组件中用到的协议),此处推荐使用maven许可证插件。插件配置参见License Maven Plugin(https://www.mojohaus.org/license-maven-plugin/),maven许可证插件在主pom中配置示例如下(此处开源协议采用Apache 2.0)
Apache License, Version 2.0 http://www.apache.org/licenses/LICENSE-2.0.html repo org.codehaus.mojo license-maven-plugin 1.13 ${main.basedir} LICENSE-3RD-PARTY /org/codehaus/mojo/license/third-party-file-groupByLicense.ftl true ${main.basedir}/LICENSE-3RD-PARTY.properties ${main.basedir}/LICENSE-3RD-PARTY.properties Apache 2.0|ASL, version 2|http://www.apache.org/licenses/LICENSE-2.0.txt|http://asm.ow2.org/license.html|The Apache License, Version 2.0|Apache License|Apache License Version 2|Apache License Version 2.0|Apache Software License - Version 2.0|Apache 2.0 License|Apache License 2.0|ASL|Apache 2|Apache-2.0|the Apache License, ASL Version 2.0|The Apache Software License, Version 2.0|Apache License, Version 2.0|Apache Public License 2.0 BSD|The BSD 3-Clause License|The BSD License|Modified BSD License|New BSD License|New BSD license|Two-clause BSD-style license|BSD licence|BSD New|The New BSD License|BSD 3-Clause|BSD 3-clause MIT|MIT License|The MIT License LGPL|LGPL, version 2.1|GNU Library or Lesser General Public License (LGPL) V2.1|GNU Lesser General Public License (LGPL), Version 2.1|GNU Lesser General Public License, Version 2.1|LGPL 2.1 CDDL|CDDL+GPL|CDDL+GPL License|CDDL + GPLv2 with classpath exception|CDDL License|CDDL 1.0|CDDL 1.1|COMMON DEVELOPMENT AND DISTRIBUTION LICENSE (CDDL) Version 1.0|Common Development and Distribution License (CDDL) v1.0 EPL|Eclipse Public License - Version 1.0 GPL|GPL2 w/ CPE|GPLv2+CE|GNU General Public Library MPL|MPL 1.1 Public Domain Common Public License|Common Public License Version 1.0 CC0|CC0 1.0 Universal|Public Domain, per Creative Commons CC0 Unknown License|Unknown license true ${main.basedir}/lic/licenses.xml ${main.basedir}/lic/licenses/ apache_v2 2019 sia task src/main/java src/test/java **/*.java **/*.xml **/*.sh **/*.py **/*.properties **/*.sql **/*.html **/*.less **/*.css **/*.js **/*.json true true false true << >> == ${main.basedir}/LICENSE org.jasig.maven maven-notice-plugin 1.0.6.1 false https://source.jasig.org/licenses/NOTICE.template - https://source.jasig.org/licenses/license-mappings.xml
配置完成之后,执行如下命令即可生成相应的协议到对应的文件,命令如下:
- #### Updates (or creates) the main project license file according to the license defined in the licenseName parameter.
- `mvn license:update-project-license`
- #### Generates a file containing a list of all dependencies and their licenses for a multi-module build.
- `mvn license:aggregate-add-third-party`
- #### Downloads the license files associated with each dependency for a multi-modules build.
- `mvn license:aggregate-download-licenses`
- #### Generate NOTICE?
- `mvn notice:generate`
项目开源时,需要在源文件的顶部添加一个保护许可,修改、检查、删除源文件头部保护许可命令如下:
- #### how to generate/update source code header?
- ## Updates the license header of the current project source files.
- mvn license:update-file-header
- ## Checks the license header of the current project source files.
- mvn license:check-file-header
- ## Remove any license header of the current project source files.
- mvn license:remove-file-header
执行完上述命令之后,会生成几个协议文件,其中有两个关键的文件:
- LICENSE文件:存放当前开源项目中用到的开源协议信息。
- LICENSE-3RD-PARTY文件:组件使用到的协议。
在LICENSE-3RD-PARTY文件中查看组件使用的协议,参考前面介绍的各协议冲突情况,查看看组件中用到的协议是否与当前开源项目选择的开源协议有冲突,如果有冲突,需要替换掉协议冲突的接口。
安全扫描是项目开源流程中必不可少的一步,安全扫描关注的点主要有以下几个:
GitHub上开源的项目需要有个版本号,版本格式为:
主版本号.次版本号.修订号,版本号递增规则如下:
先行版本号及版本编译元数据可以加到“主版本号.次版本号.修订号”的后面,作为延伸。
更形象的解释如下
:标准的版本号必须采用 X.Y.Z 的格式,其中 X、Y 和 Z 为非负的整数,且禁止在数字前方补零。X 是主版本号、Y 是次版本号、而 Z 为修订号。每个元素必须以数值来递增。例如:1.9.1 -> 1.10.0 -> 1.11.0。
备注:
开源版本规范引自
GitHub命名规范:语义化版本2.0.0
:
https://semver.org/lang/zh-CN/
做完上述几步的工作之后,我们就可以把项目上传到GitHub上进行开源了。GitHub的使用网上有很多文章介绍,这里不再赘述,可以参考 在GitHub上参与开源项目日常流程:https://blog.csdn.net/five3/article/details/9307041
开源后期维护服务是开源项目时最容易被忽视的,为了让用户更好地使用开源项目,我们可以通过GitHub issue、微信答疑群、论坛、社区文章分享等互动形式做好开源后期服务工作。
GitHub上迭代开发流程如下:项目owner给项目开发者设置member权限,member用户fork开源项目的资源成自己的资源,然后修改fork之后的资源,修改完成之后,提merge请求,只有项目owner才有权限merge。如何同步fork项目可参见如下文章如何同步fork项目:https://blog.csdn.net/t111t/article/details/45894381
开源项目:
微服务任务调度框架 :https://github.com/siaorg/sia-task
微服务路由网关 :https://github.com/siaorg/sia-gateway
【本文是专栏机构宜信技术学院的原创文章,微信公众号“宜信技术学院( id: CE_TECH)”】
分享文章:82天突破1000star,项目团队梳理出软件开源必须注意的8个方面
分享链接:http://www.csdahua.cn/qtweb/news36/83136.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网