善用 GitHub

公众号关注 「奇妙的 Linux 世界」

设为「星标」,每天带你玩转 Linux !

c2e207868a65dc67e9480dae506324ef.jpeg

GitHub是微软旗下的一个在线软件源代码托管服务平台,也是一个拥有八千多万开发者用户的社区。很多开发者应该对GitHub有一定的了解,但非技术人员大多可能并不会去使用它。本文更多是想给非技术人员来介绍这个平台,看完这篇文章,希望能让更多人在上面来学习、创作与展示自己的作品。

GitHub 是好的学习平台

GitHub拥有非常多的开源项目,这些开源项目中的一些已经成为了 IT 行业的软件基石,比如Linux内核项目。

如果你想学一门软件开发的技术,比如学会用 Python 做一些数据分析,那 GitHub 就是这方面最好的一个学习平台。为什么这么说?

924941915f55bcfdebd159a427cfa0ea.png

学习首先是需要找一个好的教程,在 GitHub 上最不缺的就是教程类的项目。以 Python 为例,通过在 GitHub 上搜索,可以很容易找到这个Awesome Python的项目,它收集了很多 Python 相关的教程、项目、库等等,你可以在这个项目中找到你想要的学习资料。而且因为它是一个 Star 数近十五万的明星项目,被很多开发者认可,所以上面推荐的资料质量也是非常高的。

当然 GitHub 并不完全是英文的,中文资料也很多,不过我还是推荐尽可能使用英文的资料,如果你要走技术之路,英文是必须的。

找到教程学习后,接下来就是去开发一个真正的项目了。按正常的流程,我们需要在我们的电脑上配置复杂的软件开发环境,就这一步已经让很多人望而却步了。但是在GitHub上,你可以直接在网页上编辑代码,然后提交到 GitHub 上,这样你就可以在任何一台电脑上开发你的项目了。这个功能叫做GitHub Codespaces。

比如下面就是我在开发的一个开源项目,其是一个基于 Python 的项目,我可以在网页上直接编辑代码,然后提交到 GitHub上。

2fe8c3a36ee9d77232d257f67fb876a2.jpeg

在上图红框部分可以创建一个免费在线的开发环境,打开后就是一个网页版的 VSCode。也就是说 GitHub 给了你一个云端开发环境(一个拥有Root用户权限的Linux系统,可以配置安装任何软件)!这个开发环境可以一直存储在云端,在任何时候打开就可以继续开发,保存在上面的文件也不会被删除。

outside_default.png

有时候当你只想阅读其他人的代码时,在 GitHub 网页上按下 . 键就会自动打开一个在线 VSCode 的开发环境,相比网页可以更方面的阅读与搜索代码。

GitHub 还提供了强大的代码搜索功能,除了在 GitHub.com 上搜索外,还可以在GitHub code search上搜索,这个搜索引擎可以搜索 GitHub 上的所有的公开仓库代码。我觉得它提供了类似sourcegraph的体验,包括更好的代码符号跳转功能。

在一个浏览器内搞定代码的搜索、阅读与开发功能,我觉得这是非常震撼的,起码在十几年前是不可能的。

如果你并不想写代码,只想写点文字,GitHub也能给你带来非常好的写作体验。

GitHub 是好的写作平台

基于Markdown的写作一直是我推崇的,早在十年前,我在Wordpress上写作,Wordpress 提供了最简单的网站搭建体验,以至于全球有超过四成的网站都是用 Wordpress 搭建的,包括个人博客。但 Wordpress 的搭建还是太麻烦了,虽然现在很多国内的云服务商都提供了一键搭建 Wordpress 的功能,但还是有很多限制,比如不是免费的,需要备案,需要维护服务器等。

在 GitHub 上写作非常简单,只需要一个 GitHub 账号,然后在 GitHub 上创建一个仓库,然后在仓库里创建一个 Markdown 文件,就可以开始写作了。写作的内容就是 Markdown 格式的文本,GitHub 会自动将 Markdown 转换为 HTML,然后在浏览器上显示出来。

除了这种方式,还可以使用Cloudflare Pages,它可以将GitHub仓库里的内容自动部署到 Cloudflare 的 CDN 上,这样就可以使用自定义域名了。

如果你想要更好的写作体验,还可以使用这个vuepress-theme-hope的开源项目,它提供了非常强大的定制能力,使用方式却很简单,比如我用它在 GitHub 上搭建了一个文档网站:free4chat开发手记。在每个页面的底部都有一个 在GitHub上编辑此页 的按钮,点击后就可以直接在 GitHub 上修改这个页面,修改后提交,GitHub 会自动重新构建网站,然后你就可以在网站上看到修改后的内容了。

由于 GitHub 的仓库会自动保存每次修订的历史记录,如果出错也可以回退到之前的版本,再也不担心数据丢失的问题了。

当然这个博客也是在 GitHub 上搭建的,你可以在这个仓库查看到它的原始文件:bmpi-dev/bmpi.dev。

如果想给网站添加评论功能,可以使用giscus,它会自动将评论保存到 GitHub 仓库的 Discussions 里,这样就不用担心评论数据丢失的问题了。比如本博客的评论数据都在这里:bmpi-dev/bmpi.dev/discussions。

GitHub 是好的开发平台

GitHub 是最好的开发平台。从上面的内容相信你可以看出来,GitHub 围绕软件的搜索、阅读与开发体验方面做了很多改进。甚至用一个浏览器就可以完成软件产品的开发、测试与部署。本文不会详细的介绍 GitHub 的全部功能,但以下这些功能是我感觉非常值得尝试的:

  • GitHub Codespaces:提供一个在线的云端IDE,可以在浏览器里直接编辑代码,然后在云端编译、运行、调试代码,非常方便。

  • GitHub Copilot:提供一个在线的AI代码自动补全功能,可以根据上下文对你的代码自动补全,甚至包括写博客!(这篇文章的一部分就是这个AI小助手自动撰写的,你能看出来吗?)

  • GitHub Actions:提供一个 Pipeline as CodeCI/CD 服务。比如可以实现,当博客文章更新时,自动发送通知给订阅者,我的博客就实现了类似的功能,具体的实现可以看这个文件:.github/workflows/gh-pages.yml。

  • GitHub Packages:提供类似Docker Hub的软件包管理功能。

最重要的是,这些功能很多都提供了免费的额度,足够日常使用了,你要做的就是去创作,利用技术杠杆去实现自己的想法。

利用 GitHub 打造个人技术影响力

打造个人技术影响力,可能是很多开发者无偿在 GitHub 上创造各种开源项目的一个主要原因。而技术影响力又可以让开发者能获得更多的机会,比如获得更多的工作机会,影响更多的人等。

在 GitHub 上你可以找到很多很厉害的人,比如前端大佬antfu,Elixir 的作者José Valim,通过关注这些人的动态,了解最新的技术趋势,不断提高自己的技术能力。

GitHub 也是一个很好的技术展示平台,你可以通过创建自己的 GitHub Profile 来展示自己的技术栈,比如我的GitHub Profile。也可以用这个工具GitHub Profile README Generator来生成自己的 GitHub Profile。

outside_default.png

基于 GitHub 的生态

GitHub 的生态系统非常庞大,有很多 SaaS 服务可以与其集成,从而提供完美的开发体验,比如:

  • SSO:很多技术网站都提供了 GitHub 的 SSO 集成,尤其是和开发者 SaaS 服务相关的网站,如果要使用这些服务,则必须要有一个 GitHub 账号。

  • Cloudflare:全球最流行的 CDN,和 GitHub 集成后,Cloudflare Pages 可以实现自动部署,当代码 push 到 GitHub 后,Cloudflare 会自动将网站发布到 Cloudflare 的全球网络节点中。

  • Vercel:和 Cloudflare Pages 一样,集成 GitHub 后,可以自动部署网站到 Vercel 的 CDN 网络中。我的一些小工具就是部署到 Vercel 上的。

  • Railway:提供了后端服务包括数据库的托管,集成 GitHub 后,可以自动部署应用到 Railway 的服务器上。

这些 SaaS 服务同样都提供了一些免费额度,轻度使用,可以免费做很多小项目。

GitHub Next

GitHub Next正在探索一些能影响软件开发未来的方向,目前有几个方向挺有意思的:

  • AI:或者说深度学习模型,正在逐渐的改变世界,比如 GitHub Copilot 正是基于深度学习模型来实现代码自动补全的功能。未来基于 GitHub Copilot 的代码重构、写自动化测试、与开发者结对编程也不是不可能的事情,当然让 AI 帮我们写文章,或者合写文章也是一件自然而然的事情。

  • 语音编程:如果能通过自然语言与 GitHub Copilot 沟通,那编程将会变成搭积木一样的简单,一些基本的功能就可以通过语音来实现,而不需要写代码。这事想想就觉得不可思议,甚至有种托尼·斯塔克与贾维斯对话去制造钢铁侠战甲的感觉。

  • 协作:由于疫情的出现,远程工作正变得越来越流行(或者说需要),远程结对编写代码目前还没有什么比较好的方式,解决多人如何在同一个代码库实时协作是个有意思的领域。

  • 可交互文档:虽然 GitHub 现在对 Markdown 的支持已经非常好了,但这种支持还仅限静态的,如何让文档变得可交互,让文档更有表达性,也是一个值得进一步挖掘的方向。

outside_default.png

虽然我注册 GitHub 有很多年了,但逐渐投入越来越多的时间在上面还是在这几年。尤其是这两年来,我愈发觉得GitHub正在逐渐改变软件开发的常规模式,尤其是 GitHub Copilot 的出现,以及一条龙式的开发体验,甚至以后从代码的设计、开发、测试到部署都可以在GitHub网页上完成,这些都是我之前想象不到的。

希望这篇文章能让读者对 GitHub 有个全新的了解,如果你还没有注册 GitHub,那就赶紧去注册一个吧。

本文转载自:「 构建我的被动收入 」,原文:https://url.hi-linux.com/iAiiN ,版权归原作者所有。欢迎投稿,投稿邮箱: editor@hi-linux.com。

abbaed4a50845a5b110602c618674aee.gif

最近,我们建立了一个技术交流微信群。目前群里已加入了不少行业内的大神,有兴趣的同学可以加入和我们一起交流技术,在 「奇妙的 Linux 世界」 公众号直接回复 「加群」 邀请你入群。

d0b336a715c1126e30e0600228f596bb.png

你可能还喜欢

点击下方图片即可阅读

d51bba3cb141c019d98f1d31e1ccbffd.png

Java 应用容器化最佳实践

956cce0c0ab7e80aeea0bb906544cc7b.png
点击上方图片,『美团|饿了么』外卖红包天天免费领

280c03b7d00aafcaca74df2923e24eb1.png

更多有趣的互联网新鲜事,关注「奇妙的互联网」视频号全了解!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值