Skip to content
⭐星座空间App(社交类App)项目源码,包括Java后台、Android、管理后台的代码。自主研发了数据库分表、SSO、token权限认证
Branch: master
Clone or download
Latest commit 6a624b6 May 19, 2019
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
doc database sql scripts. May 19, 2019
star-zone-back modify github url Jan 13, 2019
star-zone-common commit message Dec 29, 2018
star-zone-manage manage图片 May 19, 2019
.gitattributes commit message Dec 29, 2018
.gitignore commit message Dec 29, 2018
LICENSE commit message Dec 29, 2018
README.md star-zone-manage May 19, 2019
pom.xml commit message Dec 29, 2018

README.md

社交App系统架构-星座空间

Android客户端https://github.com/liushaoming/star-zone-android

目前社交类应用有App,小程序,网站,微信公众号等,其中最普遍有效的客户端还是App。 本人利用空余时间开发了一款Android版App--星座空间(英文名star-zone)
如果该项目对您有帮忙,您可以右上角'star'支持一下,谢谢!
源码在开源到了github上https://github.com/liushaoming/star-zone Android客户端https://github.com/liushaoming/star-zone-android

星座空间图标

🚀点我--下载Android客户端
大家可以下载后用下用用看。

代码分析

技术选型

下面列举技术栈,并说明选择的原因: 软件分为以下几块:(全部都是我一个人开发的,很辛苦的^_^,全栈工程师+架构师) 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/liushaoming/fpush

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

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

项目地址是星座空间App

源码在开源到了github上https://github.com/liushaoming/star-zone Android客户端https://github.com/liushaoming/star-zone-android
如果该项目对您有帮忙,您可以右上角'star'支持一下,谢谢!

You can’t perform that action at this time.