三年了,WebServer已死,我来继续搅Golang的浑水

hi,牛客网的同学们,大家好,我是社长。

2020年,我在牛客的C++方向分享了一个TinyWebServer的项目,在我进腾讯工作后,就没再继续维护这个项目。到现在差不多3年,从最初的火热变成了现在的烂大街,无人问津....我想我是推波助澜的那个恶人,搅浑了C++后端开发的浑水。

工作后,慢慢接触了Golang语言、Docker、K8S等工具,发现这个方向还不错。我最近写的一个go语言练手项目osproxyosproxy-grpc,代码已完全开源到github,希望对go方向的同学有所帮助。

相信不少接触go语言的读者,都是被它"极简协程","高并发","高性能"的特性所吸引,我也不例外,想着学完之后,能快速上手享受一把。

但当我看完基本语法,想找个练手项目时,才发现github上大部分都是博客/后台管理系统之类的,这些项目都是经验丰富的工程师快速迁移经验,写出来的go代码,对初学者不太友好;甚至不少博主推荐Docker/k8s这样的大项目,看的让人心里直打退堂鼓。

我也才接触go语言不久,明白初学者想快速实践,但找不到靠谱项目的心情,所以我希望这个基于go语言,非博客,非后台管理系统的项目能满足你的需求。

我之前有写过C++练手项目TinyWebServer,被不少人喷,也让不少人入了服务器开发的门,所以完全不要担心osproxy这个项目会很复杂,但也不要担心项目让你学不到什么东西。

正如之前很多人对TinyWebServer的评价,osproxy同样是一个"麻雀虽小又五脏俱全"的项目。

osproxy是一个使用Go语言开发的对象存储分布式代理(object-storage-distributed-proxy),可以作为文件存储微服务,支持docker一键部署,包括但不限于以下功能:

  • 分布式uid及秒传,支持相同文件不同命名
  • 分片读写,大文件上传,merge接口不用等待数据合并,分片上传完直接下载
  • 异步任务,易扩展的event-handler,支持分片合并及其他文件处理任务
  • 统一封装,降低业务接入复杂度,业务侧只需要存储文件uid
  • 代理下载,不直接暴露底层存储厂商及格式
  • 支持集群部署,proxy模块处理不同机器的分片转发
  • 支持MinIO/腾讯COS/阿里OSS等对象存储,易于扩展
  • 支持Docker一键部署

你能实践这些东西:

  • go:协程,sync包(waitgroup/once/mutex),channel,interface(可插拔组件注册)等
  • grpc:一元RPC,服务器流RPC,客户端流RPC,RPC拦截器,RPC数据转发
  • gin:路由组,http服务转发,文件数据转发,中间件
  • gorm:简单文件元数据的存储
  • nginx:http和grpc的反向代理,及证书自签
  • redis:数据缓存,缓存与DB双写,简单的服务注册与发现,分布式锁
  • uuid:分布式ID
  • docker:dockerfile的书写,docker一键部署等

如果你正在学习Go语言,并且该项目给你的学习带来了一些帮助,欢迎star,欢迎交流。

#23届找工作求助阵地##go开发##golang##go实习##go#
全部评论
大佬开个教程嘛
3 回复 分享
发布于 2023-06-15 12:35 浙江
楼主有没有考虑搞一个OsProxy项目交流**?
3 回复 分享
发布于 2023-06-21 21:20 广东
mark
2 回复 分享
发布于 2023-06-15 00:02 江苏
请问会有教程开发文档么
2 回复 分享
发布于 2023-06-15 08:48 湖北
mark
2 回复 分享
发布于 2023-06-15 10:09 陕西
牛逼
2 回复 分享
发布于 2023-06-15 11:06 湖南
大佬牛批
2 回复 分享
发布于 2023-06-15 12:11 湖南
大佬牛批
2 回复 分享
发布于 2023-06-15 12:52 上海
github那个tinywebserve是楼主的吗
1 回复 分享
发布于 2023-06-15 00:03 吉林
大佬牛逼
1 回复 分享
发布于 2023-06-15 10:41 吉林
大佬牛逼
1 回复 分享
发布于 2023-06-15 12:48 北京
m
1 回复 分享
发布于 2023-06-15 20:43 北京
来个java项目就好了
1 回复 分享
发布于 2023-06-15 23:39 浙江
1 回复 分享
发布于 2023-06-23 11:35 海南
mark,大佬牛逼
点赞 回复 分享
发布于 2023-06-15 14:01 湖北
mark
点赞 回复 分享
发布于 2023-06-15 14:38 陕西
m
点赞 回复 分享
发布于 2023-06-15 15:13 河北
学长nb
点赞 回复 分享
发布于 2023-06-15 19:40 广东
大佬牛逼,以前看您的项目
点赞 回复 分享
发布于 2023-06-16 08:24 北京
大佬我的神
点赞 回复 分享
发布于 2023-06-16 09:26 湖北

相关推荐

今天 18:13
已编辑
南京理工大学 研发工程师
#拼多多2025届春招##面试#一面3.151.自我介绍2.项目相关安卓和IOS更倾向于哪个?有开发app的项目,问了一些安卓相关:activity和fragment作用、角色、区别联系。C++和Java从源代码到最后在机器上执行,过程区别。为什么要java中要有虚拟机?编译原理:编译阶段具体做了什么?最后产物是什么?项目中用了WebSocket,问了 WebSocket和Socket有什么区别。回答时候谈到了Http的版本,问:http各个版本迭代有什么区别?(属于给自己挖坑)session机制id存在哪里?Http get  post区别;用户登录时,用户名密码是放在post的body里面吗?写一个mysql语句(项目里有mysql)学习过程中,遇到过什么不好解决的问题,最后学到了什么。3.代码题:判断单链表是不是回文的。4反问:咱们岗位需要学习哪些技术栈?负责哪些业务?面试官没有问一点数据结构、计算机网络(常规的),操作系统的问题,也没问Java八股。二面3.291.自我介绍2.八股+项目使用虚拟内存如何突破物理内存大小的限制。有哪些页面置换算法。设计LRU cache使用什么样的数据结构。锁的操作和原子操作有什么区别为什么原子操作开销更小创建进程和创建线程所需要什么资源,创建过程会发生什么分配什么样的情况会造成一个死锁如何设计解决死锁的方法,怎么预防和避免解释一下银行家算法;怎么检查不安全状态;如果让你设计一个线上的观察和上报的系统,用来检测一个软件之中是否发生了死锁,怎么设计浏览器地址栏输入URL到出现页面,过程发生了什么视频聊天的传输过程为什么视频传输是用UDP为什么TCP需要建立连接拥塞控制的策略和思想拥塞窗口的大小是如何决定的发生拥塞之后TCP会有哪些策略和算法3.代码题  判断一棵树是不是AVL,不能用递归,要用栈4.反问 简历存在的问题二面面试问了不少操作系统和计网的问题。
点赞 评论 收藏
分享
评论
121
555
分享

创作者周榜

更多
牛客网
牛客企业服务