• Stars
    star
    223
  • Rank 178,458 (Top 4 %)
  • Language
    Java
  • License
    Apache License 2.0
  • Created almost 6 years ago
  • Updated over 1 year ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

⭐星座空间App(社交类App)项目源码,包括Java后台、Android、管理后台的代码。自主研发了数据库分表、token权限认证

社交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'支持一下,谢谢!

小米推送的jar包 为什么maven编译的时候会找不到?

比如下面两个jar MiPush-Server.jar, MiPush-json-simple.jar依赖会找不到

<dependency>
    <groupId>com.xiaomi</groupId>
    <artifactId>MiPush-Server</artifactId>
    <version>2.2.19</version>
</dependency>
<dependency>
    <groupId>com.xiaomi</groupId>
    <artifactId>MiPush-json-simple</artifactId>
    <version>1.1.1</version>
</dependency>

解决办法:

这个是需要本地jar instal到本地maven仓库的。具体操作如下

添加本地jar到maven springboot项目中

maven项目中,如果想引用第三方提供的,或者自己的本地jar包。  是非常困难的事情。

因为这些jar没有groupId, artifactId, maven命令打包无法引用。
解决思路:
用mvn install:install-file命令把本地的jar安装到local maven repository。 然后就可以在pom里像普通的maven引用来引用这个jar了
实例如下:

step1 首先把本地的jar都放到项目根路径下新建的lib中去

step2,命令行进入lib路径

mvn install:install-file -DgroupId=com.xiaomi -DartifactId=MiPush-Server -Dversion=2.2.19 -Dpackaging=jar -Dfile=MiPush-Server-2.2.19.jar

mvn install:install-file -DgroupId=com.xiaomi -DartifactId=MiPush-json-simple -Dversion=1.1.1 -Dpackaging=jar -Dfile=MiPush-json-simple-1.1.1.jar


这这两个jar包都install到local repository了。 
然后,在自己的springboot项目里。 就可以直接添加dependency就可以了 

<dependency>
    <groupId>com.xiaomi</groupId>
    <artifactId>MiPush-Server</artifactId>
    <version>2.2.19</version>
</dependency>
<dependency>
    <groupId>com.xiaomi</groupId>
    <artifactId>MiPush-json-simple</artifactId>
    <version>1.1.1</version>
</dependency>


groupId 和artifactId和version都是我自己创建制定的。 并非官方给的

注意这里MiPush的jar包官方在不断升级。version自己可以改成最新的,比如2.2.21 在本项目里的MiPush_SDK_Server.jar路径为 MiPush_SDK_Server_2_2_21.jar

json-simple-1.1.1.jar

百度云短信 qcloudsms_java

More Repositories

1

jseckill

Java秒杀 抢购 (Seckill based on Spring Boot)
Java
769
star
2

bootpush

📶即时消息推送服务(即时通讯),基于Netty- Instant Messaging push service based on Netty
Java
153
star
3

distarch

Java分布式系统架构。包括分布式锁,一致性哈希,分库分表,单点登录,缓存,消息队列等
Java
141
star
4

java-interview

Java interview-高级Java面试题2019
Java
135
star
5

jpassport

token登录模块, SpringBoot2. App的用户登陆后台
Java
108
star
6

containerx

⚡简单的Java依赖注入框架,代码量少,实现了依赖注入和AOP。适合Spring源码的初学者掌握其核心原理
Java
77
star
7

flycache

一致性哈希的redis分片存储 (Redis sharding by consistent-hashing)
Java
58
star
8

microsvc

Spring Cloud 2.X 最新实践. Gateway, Consul
Java
47
star
9

fly-auth

Java JWT解决分布式环境下的认证和session一致性问题
JavaScript
45
star
10

flylib-boot

spring boo应用的通用架构(全局异常处理等机制)
Java
45
star
11

frpc

Flylib RPC framework基于protobuf编码协议
Java
41
star
12

algorithm4j

用java实现的算法 Algorithm implemented by Java
Java
36
star
13

jframe

揭秘开发Java开源框架需要用到哪些技术。{name}-spring-boot-starter, ConnectionPool, ThreadLocal, 动态代理等的实现
Java
36
star
14

apidoc4j

APIDOC java implementation via ANTLR
Java
32
star
15

star-zone-android

星座空间-Android客户端代码
Java
30
star
16

guardkit

基于Java的监控框架
Java
25
star
17

fastsso

Spring Boot实现单点登录. Redis, JWT
Java
23
star
18

starzone-doc

22
star
19

svctracer

spring cloud micro-service tracer. 跟踪微服务的调用链,Spring Cloud Sleuth获取调用链+zipkin显示
Java
9
star
20

concurrentapp

多线程的核心技术Demo. 这些例子,都是深入到技术底层。并发技术的顶尖高手必备
Java
4
star
21

android-bootlib

Android classic mini lib
Java
4
star
22

netty-im

Java
3
star
23

dubbo-demo

Demo for senior Dubbo application
Java
3
star
24

cloud-lib

Spring Cloud Gateway + JWT
Java
3
star
25

bootblog

2
star
26

drouter

Java
2
star
27

bootsrc.github.io

HTML
1
star