设为首页 收藏本站
查看: 1296|回复: 0

[经验分享] 更改FastDFS的一点收获

[复制链接]

尚未签到

发表于 2015-9-10 10:22:36 | 显示全部楼层 |阅读模式
  以前一直不理解网络编程的概念和一些实现手法。这几天因为DFS的事情,老是和DFS的服务器代码和客户端代码打交道。  因为需要使用dfs,所以只好自己写了一个DFS的net客户端,因为业务的需要,DFS系统也需要增加了一个批量上传文件的功能。有点收获,共享一下。
  首先是协议。很多刚刚接触网络编程的人对于协议是无从下手的。协议是什么呢?协议就是服务器端和客户端两者之间对于相关数据的约定,这些数据可能包括数据的长度,位置,意义等等。很抽象吧?我们经常能听到http,https,ftp等等这种协议,而这种协议的实现市面上也有书能买到,但是往往我们自己需要实现的时候就没辙了。比如dfs,它的协议其实很简单,一步发送协议,类似于http;第二步,发送header,这步中加入了即将发送的body长度,及其body相关数据的位置;第三步,发送数据。然后服务器端接到数据后,根据协议的约定,解析body数据(就是第三步发送的数据),搞定,就此一次通讯就结束了。服务器也拿到了需要哦东西给予相应,相应完后,服务器会更加协议(又是两者的约定)发送回客户端相关数据,dfs中是groupname和filepath。
  我碰到一些同事问我,这个约定是什么呢? 这个就要看dfs的代码了。因为你不是dfs的作者,又没有他的文档,所以代码是第一手资料。当然了如果这个软件是你自己写的,那么这个约定由你来定。不管你定义成什么样子,只要能完成服务器端和客户端之间的通讯,那么这个就叫两者之间的协议。协议是一个定的东西,他不能变的,变的是里面的数据。记住这句话。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-111834-1-1.html 上篇帖子: 【转】分布式文件系统FastDFS架构剖析 下篇帖子: FastDFS架构剖析(非常值得一看的架构分析和解读)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表