前言
想像自己还是一名刚接触计算机的的小白,如何去学习呢,当然是从互联网开始啦,如何让我们的学习路线不偏航呢,下面就给大家梳理一条“捷径”,让你快速走上人生巅峰,迎娶白富美。
由浅入深的你会了解到
互联网相关的协议
基本的前端知识
操作系统相关的知识
学习一门语言
版本控制工具
数据库相关
API相关
缓存相关
网络安全知识
测试相关知识
持续集成、持续交付
设计和开发原则
架构模式
搜索引擎
消息队列
WEB服务器
容器化技术
可扩展性
互联网
互联网是一个全球性的计算机网络,它们相互连接,通过一组标准化的协议进行通信。
HTTP协议
- 什么是HTTP协议
- HTTP协议是如何运作的
- 如何自己实现一个网络协议?要注意哪些点?
DNS协议
- DNS协议是如何运行的
- 什么是域名?
- 域名是如何运作的
基本的前端知识
- 学习HTML
HTML是网络的通用语言,一种简单、通用的全置标记语言。
- 学习CSS
CSS全称为Cascading Style Sheets,中文翻译为“层叠样式表”,简称CSS样式表,是一种用来表现HTML或XML等文件式样的计算机语言,是一种标准的样式表语言,用于描述网页的表示,即布局和格式。
- 学习JavaScript
一种具有函数优先的轻量级,解释型或即时编译型的编程语言
操作系统和基本常识
- 终端的使用
- 操作系统是如何工作的
- 进程管理
- 线程与并发
- 基本的终端命令
grep, awk, sed, lsof, curl, wget,tail, head, less, find, ssh, kill
- 内存管理
- 进程间的通讯
管道、信号、消息队列、共享内存、信号量、套接字
- I/O
- POSIX基础知识
stdin 输入
stdout 输出
stderr 异常
pipes 管道
- 网络基本概念
当你了解了以上的概念之后呢,你就可以开始着手学习一门计算机语言了,学习的同时你要着重关注它的细节、核心概念,例如并发、内存模型等等。
开始学习一门语言
- Java
- C#
- PHP
- JavaScript
- Python
- Ruby
版本控制系统
知道它们是什么,为什么你应该使用它们
- Git的基本使用
- 仓库托管服务
GitHub,GtiLab,Bitbucket
关系型数据库
- PostgreSQL
- MySQL
- MariaDB
- MS SQL
- ORACLE
熟悉SQL语法,了解各种数据库的优劣,多尝试复杂SQL,需要具备一些数据库的调优方式。
非关系型数据库
- 文档数据库 MongoDB CouchDB
- 列数据库 Cassandra
- 时间序列数据库 InfluDB TimescaleDB
- 实时数据库 Firebase RethinkDB
更多数据库相关
- ORM
- ACID
是指数据库管理系统(DBMS)在写入或更新资料的过程中,
为保证事务(transaction)是正确可靠的,所必须具备的四个特性:
原子性(atomicity,或称不可分割性)
一致性(consistency)
隔离性(isolation,又称独立性)
持久性(durability)
- 事务 Transactions
事务是由什么来保证的
事务的传播特效
事务何时会失效等等
- n + 1问题
- 数据库范式
- 索引Index相关
- 数据复制 Data Replication
- 分片策略
- CAP理论
CAP
一致性(Consistency)
可用性(Availability)
分区容错性(Partition tolerance)
最多满足其中的两个特性。也就是下图所描述的。分布式系统要么满足CA,要么CP,要么AP。无法同时满足CAP。
API相关信息
- HATEOAS
- 开放API规范和Swagger
- 身份验证
基于Cookie、OAuth、基于Authentication、TOKEN、JWT、OpenID、SAML
OPENID工作原理
客户端向验证服务器申请了一个OPENID帐号,然后在支持OPENID验证的网站用OPENID进行登录,这个网站以它会请求你的验证服务器对你的身份进行验证,验证服务器验证合法,该网站接受你的身份
- JSON API
- SOAP
- gRPC
缓存相关
- CDN
- 服务端处理
CDN的全称是Content Delivery Network,即内容分发网络。 其目的是通过在现有的internet中增加一层新的网络架构, 将网站的内容发布到最接近用户的网络边缘,使用户可以就近 取得所需的内容,提高用户访问网站的响应速度。
Redis、Memcached
- 客户端处理
紧接着要具备一些网络安全知识
安全知识
- MD5及为什么不用它
- SHA家族
- scrypt算法
- bcrypt算法
测试
- 继承测试
- 单元测试
- 功能测试
CI/CD
持续集成、持续交付
设计和开发原则
- GOF设计模式
- 领域驱动设计 DDD
- 测试驱动开发
- SOLID 原则
单一职责原则(SRP)一个类应该只负责一件事情
开放封闭原则(OCP)对修改封闭,对扩展开放
里氏替换原则(LSP)所有引用基类的地方必须能够透明地使用其子类的对象
接口隔离原则(ISP)不依赖不需要的接口
依赖倒置原则(DIP)解耦,依赖抽象而不是具体
迪米特原则(LOD)一个对象应该对其他对象保持最小的了解
- KISS原则 (Keep It Stupid Simple 或 Keep It Simple,Stupid) 简单清晰原则
- YAGNI (You Ain’t Gonna Need It)你不会需要它 不设计用不到的功能
- DRY (Don’t Repeat Yourselt)不要写重复代码
架构模式
- 单体应用
- 微服务
- SOA
服务治理,面向服务架构(SOA)是一个组件模型,
它将应用程序的不同功能单元(称为服务)进行拆分,
并通过这些服务之间定义良好的接口和协议联系起来。
- CQRS 和 Event Sourcing
- Serverless
搜索引擎
- Elasticsearch
- Solr
Message Brokers (消息代理)
- Kafka
- RabbitMQ
- RocketMQ
容器化
- Docker
Docker 项目的目标是实现轻量级的操作系统虚拟化解决方案。
Docker 的基础是 Linux 容器(LXC)等技术,屏蔽很多底层细节,
让用户操作 Docker 的容器就像操作一个快速轻量级的虚拟机一样简单。
- RKT
Rkt诞生于2014年12月,是一种与Docker类似的容器引擎,
由CoreOS公司主导,得到了Redhat、Google、Vmware
等公司的支持,更加专注于解决安全、兼容、执行效率等方面的问题。
- LXC
提供轻量级的虚拟化,以便隔离进程和资源,
而且不需要提供指令解释机制以及全虚拟化的其他复杂性。
了解它们的由来和作用,系统的学习它们,熟悉它们的生态,尝试了解底层原理。
GraphQL (图状数据)
- Apollo
- Relay Modern
图数据库
- Neo4J
WebSockets
协议
Web服务器
- Nginx
- Apache
- Caddy
- IIS
知道各种服务器各自的优势和劣势,知道如何部署应用,能够根据实际的业务场景选取合适的服务器,
可扩展性
构建可持续性的产品价值
- 缓解策略
优雅、降解、节流、背压、负载转移、断路器
- 可视化监控
仪器仪表、监测、遥测
-
迁移策略
-
水平和垂直扩展
-
可观察性
具有可观察的指标,能够在问题发生前及时发现,
或者及时定位已经发生的问题。
总结
成功没有捷径,请保持学习~
❤️/ 感谢支持 /
以上便是本次分享的全部内容,希望对你有所帮助^_^
喜欢的话别忘了 分享、点赞、收藏 三连哦~
欢迎关注公众号 程序员巴士,来自字节、虾皮、招银的三端兄弟,分享编程经验、技术干货与职业规划,助你少走弯路进大厂。