注意: 任务估计所需时间为一周,请在国庆后例会 10 月 13 日之前完成。否则,视为没有完成任务。 10 月 13 日例会会总结此次学习,并给大家更详细地介绍 Git.
-
任务描述:
Git 是一个版本控制工具。在加入我们进行多人协作的开发之前,你必须学会使用它,不然你将几乎无法为我们的项目做出有效的贡献。
虽然 Git 有为数众多的图形工具(比如 TortoiseGit、Git GUI(没错,这货是 Git Windows 版自带的)、GitKraken,甚至是各种 IDE 自带的 Git 组件(比如 JetBrains 系列 IDE 中的 Git 功能、微软 Visual Studio Code 中的 Git 功能等等)),但如果要从根本上掌握 Git 的使用方法,大家仍然需要在命令行中使用 Git,在 Git 命令行提供的各种命令中熟悉 Git 的各种操作。(太过功利可是学不到真东西的哦)
GitHub,最为活跃的开源社区之一,是一个使用 Git 作为版本控制系统的代码托管平台。如无特殊情况,我们部门的项目都会托管于 GitHub,并遵循各种开源协议的规范和要求。所以要加入先锋网络部的大家庭,毫无疑问地你需要注册一个自己的 GitHub 帐号。有这样一种说法,一个程序员的 GitHub 帐号相当于这个程序员的门面,一个好的 GitHub 帐号是无声而最有力的简历和推荐信,而事实上你注册的 GitHub 帐号(如不出意外)将会陪伴你整个代码生涯,所以请慎重地为自己选择一个 GitHub ID,然后给自己上传一个合适的头像(也可以使用 GitHub 自动为你生成的像素风头像)。所以你还在等什么呢,快快为你的开源社区生涯打开第一扇门吧!
完成注册 GitHub 之后,请学习并完成 try.github.io 上有关 Git/GitHub 的命令行教程。同时你也可以参考网络上各种优质的 Git/GitHub 学习资料,自学 Git 版本控制系统,自学有关如何在 GitHub 上进行协作的内容。我们也为大家精选了一些学习资料,列举如下,供大家参考。也欢迎发现高质量学习资源的同学们发起 Pull Request,积极为大家补充!
- 开源图书《Pro Git 第二版》
- 网络部2018招新宣讲宣讲《Git版本控制与GitHub》演示文稿(by 舒意恒)
- 博文《Git入门与基础》(by 舒意恒) on GitHub
- GitHub Guides:https://guides.github.com/
- Learn Git Branching:https://learngitbranching.js.org/
另外要说明的一点是,虽然 GitHub 是英文的,还请大家尽量避免使用全文翻译来浏览 GitHub 上的内容。英文是每个合格的开发者必须要精通的,建议英文基础不太好的同学们常备词典(或电子辞典),记下自己不会的生词然后想办法掌握他们,而非直接通过全文翻译等工具绕过他们。提升英文阅读能力,将让你在以后阅读(和书写)纯英文文档时如虎添翼,极大的提升开发效率(以及与国际友人的沟通能力)。学英语,不吃亏!
-
任务提交:
在 GitHub 上 fork 这个(
mengxin-2018
)仓库,然后将你的姓名加入文章末尾的列表中,再发起 pull request。 -
注意事项:
- 你可能需要稍微了解一点 Markdown 语法知识
- 请使用命令行进行 commit, i.e. 你的 commit 中不能出现
committed on GitHub
字样。 - 请尽量避免使用会污染原文的工具进行编辑(比如会自动添加 BOM 头的 Windows 记事本、会自动调整 Markdown 空白字符格式的可视化 Markdown 编辑器等),就算使用也请在提交前对更改详情进行审查,避免向版本库提交有毒内容。
-
任务描述: 了解前端、后端和运维的工作及技能需求,结合自己的兴趣与他人的建议,决定自己的主力方向。 一些可能的方向需求列举如下:
-
前端方向:
- 需要对基础三件套(HTML、CSS、JavaScript)熟练掌握,尽量掌握较新版本(如HTML5、CSS3、ECMAScript6)等的特性;
- 需要对浏览器渲染时的各种细节做到准确把握,在出现玄学问题时能系统地分析问题原因;
- 至少掌握基础三件套的一组预处理器组合(如处理到 HTML 的 Pug、Haml、Slim 等,处理到 CSS 的 Sass、LESS、SCSS、Stylus 等,处理到 JavaScript 的 TypeScript、CoffeeScript 等,以及通用的预处理器 Emmet Abbreviation 等);
- 熟悉现代化 Web 处理技法,如 Babel、Webpack、响应式设计、PWA、ServiceWorker、异步 XMLHTTP 请求、WebSocket 等;
- 掌握现代化前端框架(如 Vue.js、Angular、React 等)中的一个或多个;
- 掌握前端 UI 框架(如 Bootstrap、jQuery DOM、jQuery EasyUI、Ant Design、ElementUI、iView、ECharts、Handlebars 等)中的一个或多个,以及其所依赖的前置技术栈;
- 掌握前端模块化编程现代理念(如 RequireJS、CommonJS、Browserify、AMD 等);
- 掌握前后端通讯技术与框架(如 Websocket、jQuery XMLHTTP、Axios、HTML5
fetch
等),熟悉对应的 HTTP 协议规范,了解基本的通讯归约与语义规范; - ...
-
后端方向:
- 需要对 Java、Python、Ruby、Golang、Kotlin、Groovy、JavaScript 等语言中的一种或几种有较好的掌握;
- 对 Oracle、MySQL(或 MariaDB)、PostgreSQL 等关系型数据库系统(RDBMS)中的一种或几种的基本使用熟悉;
- 对 Redis、MongoDB 等常见的非关系型数据库基本熟悉掌握;
- 对 RabbitMQ、RocketMQ、Kafka 等消息队列系统(MQ)的原理熟悉,掌握使用方法;
- 对 JSON-RPC、SOAP、RESTful、GraphQL、APIJSON 等调用归约模式中的一个或几个做到熟练掌握;
- 对常用的后端敏捷开发框架(如 Flask、Sanic、Tornado、aiohttp、Vibora 等 Python Web 框架,Vert.x、Spring Boot、JFinal、Resty、Cloudopt Next 等 JVM Web 框架,Express、Meteor 等 NodeJS Web 框架,以及许多语言的许多 Web 框架)中的一个或几个做到熟练掌握;
- ...
-
运维方向:
- 对 Linux 操作系统的指令有全面的了解,熟悉 Bash 脚本(或 Zsh 脚本)编程;
- 需要对常见服务器 Linux 发行版本(如 Ubuntu LTS、CentOS 等)的安装、重装、安装新软件、配置特定环境等操作熟悉;
- 对常见的服务器软件(如 nginx、Apache 等 Web 服务器,MySQL、PostgreSQL、MySQL(MariaDB)、Redis、MongoDB 等数据库服务器,RabbitMQ、Kafka 等消息队列服务器,以及其他服务器软件)中大多数的配置与日常维护熟悉,要能与后端开发人员协同对服务器进行停机更新或不停机更新;
- 对网络安全方面的知识有一定的了解,会及时将服务器上的软件或操作系统更新到较新的版本以修复安全漏洞,会配置服务器防火墙、用户及用户组权限到最小权限要求;
- (深入 Linux)对 Linux 内核编程有了解和研究,能自己魔改 Linux 内核,给内核提交 Patch 等。
- ...
-
-
任务提交:10 月 13 日例会前后将会统计大家的方向志愿,并根据部门的实际情况作出一定的调剂。
-
任务描述:在服务器上搭建 LAMP 环境。
开发环境的搭建十分重要。在去年里我们大量的成员在开发环境搭建问题上花费了巨量的时间,所以今年在刚进来的时候考察各位搭建开发环境的能力,和利用互联网解决问题的能力。同时你可以寻求身边的人(包括部里的学长们)的帮助,不过你应该知道没有人有义务解答你的问题,能不能得到答案要靠你问问题的艺术。
LAMP 环境是新人入门 Web 所搭建的环境中比较普遍的一种,在网上可以找到大量搭建 LAMP 环境的教程。其中 L 代表 Linux,A 代表 Apache,M 为 MySQL, P 为 PHP。与之并列的,可以有 WAMP,LNMP 等等多种。之所以选择 Linux 作为大家的任务,一是因为 Linux 下安装 Apache 比较简单,二是我们的服务器都是 Linux 系统,作为 Web 开发大家有必要掌握一些终端的知识,另外学会使用 Linux 也有诸多好处。
公网服务器可以到一个公有云服务商那里去注册一个 VPS 来获得。我见到的很多技术圈的人都有自己的网站服务器,而拥有自己一个服务器也是很有好处的。阿里云和腾讯云都提供学生优惠(大约每月1~10元),GitHub 的学生包提供 DigitalOcean 十个月的免费试用(不过貌似需要绑定国外的信用卡认证),此外正常价格的话最低配的服务器大约每月 5 美元 / 45 人民币左右。大家也可以合租来节省开支。
-
任务提交:
在一台公网可以访问的服务器上完成 LAMP 环境搭建,并创建一个网页来显示 PHP 探针,如提交列表中的 example 所示。
-
任务描述:
写博客是一个好的习惯。许多大佬都是写博客的!把自己踩到的一些坑、学习过程中的经验总结成文章,放在你自己搭建的网站博客上吧!动态的博客引擎有 WordPress、Typecho 等,静态的如 Jekyll、Hexo 等。
-
任务提交:
在一台公网可以访问的服务器上完成博客搭建,并将博客的链接提交到文末的列表中,如列表中的
VOID001
所示。 -
注意事项:
- 博客必须是自己搭建的,请不要把 CSDN、博客园甚至 QQ 空间之类当成自己搭建的博客发上来!
- 已有自己搭建的博客的人可以直接提交此任务,不需要重新再做一个(不过我觉得应该都有改进的空间)
Please add the link of your website to the bottom of the list, and then start a pull request.
Let your link display with your official name or widely-known nickname. Make sure the link leads to the right place on click.
Please do NOT edit or remove others' link.
- your name
- SJJ
- wangjue
- BYL
- packy
- 1chig0
- Luobendong
- LiuDedong
- Yuren
- ChenYi
- pengyang
- Lanyu
- XuZhengqi
- WangYang
- Swinggcat
- 灼眼のシャナ
- 克莉斯丁
- 颜扬升
- Desnity
- ZhouXinji
- 二階堂夢月
- 陈杰南
Submission is not required here.