社交App系统架构--自己亲手写的App系统(含github源码)

版权声明:本文为刘少明原创文章,未经博主允许不得转载。 https://blog.csdn.net/lsm135/article/details/80887160

社交App系统架构

目前社交类应用有App,小程序,网站,微信公众号等,其中最普遍有效的客户端还是App。
本人利用空余时间开发了一款Android版App–星座空间(英文名star-zone)

源码在开源到了github上https://github.com/flylib/star-zone
Android客户端https://github.com/flylib/star-zone-android

项目地址是星座空间App

星座空间图标

大家可以下载后用下用用看。

技术选型

下面列举技术栈,并说明选择的原因:
软件分为以下几块:(全部都是我一个人开发的,很辛苦的_,全栈工程师+架构师)
1.Android
采用原生Android开发

很多人以为用React Native开发App就不需要处理兼容性问题。其实使用React Native开发,也会遇到类似于原生开发里的gradle jar包依赖的冲突的问题。 而且,比如需要用到一些第三方厂商的硬件驱动程序jni等,或者原生android的库。 这种情况下React Native来调用这些库,就异常艰难。以国际大厂Airbnb为例,该公司曾是比较早采用React Native来在生产环境开发App的公司,极力推进React Native。结果后来还是放弃了。
Airbnb 在 Medium 上发博文宣布,“由于许多技术上和组织上的问题,我们决定放弃 React Native,将所有精力投入到原生应用上。”
另外一个原因:我是一个Java架构师,对Java语言比较熟悉,也会Android开发,于是就采用了原生开发

2.后台服务
基于Java,Spring Boot, Spring Cloud
数据库MySQL
缓存Redis

3.后台管理网站(纯静态网站)
做了前后端分离,动态和静态分离,静态网站放在nginx上,可以应对高并发访问
前端使用ES6语法,
框架采用vue.js,
插件使用babel,
样式使用element-ui

4.App的推广官网(纯静态网站)
做了前后端分离,动态和静态分离,静态网站放在nginx上,可以应对高并发访问

总体架构

  1. 后台总体架构
    Android通过网络,到达服务器后,经过nginx反向代理到后台服务。
    调用后台接口的时候, 一部分接口是进行了权限验证的,权限验证使用userId+token
    参考我的另外一个框架fpassport

    点击后可以访问github

    其中使用了Redis存放userId和token的对应关系。提高了系统的响应速度。
    由于app里后面会加上电商功能,对于下单功能。订单数量是商品数量的很多倍。
    采用了分表的架构。分表原理采用一致性Hash。

  2. 微服务采用了Spring Cloud
    Spring Cloud是采用HTTP协议, Dubbo采用RPC方案,采用TCP协议通信。
    性能方面Spring Cloud略差一点。 但是影响不大。两种框架各有利弊。我采用了自己熟悉的Spring Cloud

  3. 数据库分表操作
    基于一致性hash,见github源码

  4. 前后端分离,动静分离
    Java动态网站比较吃内存,操作系统允许的线程数也是一定的。 最多几千个线程。
    而且一个线程一般就要占用512KB的内存。 光这些HTTP连接就至少占用1G内存。
    还有其他的CPU计算,也要占用1G以上的内存。

动静分离后。 页面的每次请求不需要经过后端渲染,减少了Java Http连接数,减小了内存开销。
nginx部署静态网站后。不做优化,nginx本身就能承受上万个并发连接,很适合做静态资源的服务。

  1. 推送服务,即时通讯
    使用了小米的推送服务,我自己也自主研发了一个推送服务基于netty,项目地址
    ttps://github.com/flylib/fpush

5.前端方案
vue,双向数据绑定,提高编程效率。
element-ui界面简洁,使用简单,适合后台管理系统开发,跟vue结合有天然的便利。
有饿了么公司强大后盾。
使用es6或者js都行。

上班比较忙。暂时写这么多。
本文后面还会继续编辑更新。把更多内容分享给大家。

项目地址是星座空间App

源码在开源到了github上https://github.com/flylib/star-zone
Android客户端https://github.com/flylib/star-zone-android

个人主页是appjishu.com

猜你喜欢

转载自blog.csdn.net/lsm135/article/details/80887160