### 项目自定义规范

只是一些建议性的东西,大家有什么好的想法,都可以提出来。

- 现在暂时定义为v1版本,所有的api以 /v1/模块/功能
- 采用restFul风格的URL
- 返回数据的格式,全部采用ResponseDto ,data字段为传递的数据
- 前后端分离,采用json格式进行数据传输
- 根据 ResponseDto 的code字段判断请求操作是否成功。如果失败,返回非200的请求码
- *最好将系统的代码和自己的区分开来,自己的代码写在cn.gygxzc.envir.biz 目录下*

- *一键生成数据库相关代码配置在cn.gygxzc.envir.config.orm 包下,请自行配置相关参数*

### 项目说明

项目采用Spring Cloud分布式解决方案。
目前系统中涉及到的知识点有 :
- Eureka服务发现与注册中心,
- Spring Cloud Config Server 微服务配置中心;
- Spring Cloud Gateway 网关
- Spring Cloud Bus 消息总线(结合rabbitmq)
- Spring Session 结合Redis 做分布式权限认证
- Mybatis-Plus 3.0

需要的可以去了解一下。

项目中缓存可以分成三类:
- 系统Spring session缓存,shiro缓存

-  获取当前登录用户信息 SessionUtils 工具类


### 框架项目升级日志
#### 2018/9/27
升级框架的安全认证方式,改成jwt 和Spring session分布式方式认证。权限由网关统一认证。

#### 2018/9/28
已初步完成Spring session的分布式认证,下一步将移除shiro 依赖即权限认证。

- 将数据库 DAO类文件卸载 zen-api 下的 cn.gygxzc.envir.biz.dao 路径下
- 如果需要写 mapper.xml 请写在  resources/mapper 文件夹下,可以在有目录比如;resources/mapper/biz
- 项目包名统一为 cn.gygxzc.envir.**
- 项目对mybatis plus进行了升级,使用的是mybatis-plus 3.0,与之前有一定区别,具体可见[文档](http://mp.baomidou.com/guide/wrapper.html#querywrapper)

#### 2018/9/29
##### 1、添加配置中心,将配置中心与即时通信消息系统结合起来
##### 2、 添加Spring bus。服务间的消息通知。

        这一点举一点应用:业务系统需要向前端或者用户发送消息,
        只需要调用发送消息的sender即可。由消息中心把消息发送给前端用户。

##### 3、 删除shiro配置。
        
        但是因为授权中心使用shiro,导致客户端不能完全移除shiro依赖,但是只引用了shiro的核心包。
        具体原因是:授权中心shiro在生成的session中放入了shiro包中的类实体对象,jdk序列化之后,在各自的业务系统中反序列化,如果不引入shiro核心包,将
        导致jdk反序列化失败,导致各自业务系统无法获取到当前登录的用户信息。
##### 4、 精简大量yml 文件配置,只保留必要的部分。
 有了配置中心的存在,可以将所有项目的公有和私有配置放到配置中心,而无需大量放到本地。
 
##### 5、移除Tomcat依赖,添加jetty依赖
Jetty 更加轻量化,更符合Spring Cloud 分布式部署;当然,这个还需要验证和考量。

#### 2018/9/30
 - 这次项目更新主要是去掉shiro的权限认证,但是保留了shiro的核心包,原因见上昨天更新日志。
 - 删除了很多配置文件,集中到配置中心配置。
 - 保留的配置文件 bootstrap.yml 为配置注册中心,配置中心相关信息,application.yml内只有数据库连接相关配置。
 application-cache.yml为项目的一个内存缓存配置。里面需要修改的有备注,但是暂时可以不修改。
 - 完成了mybatis-plus 的物理删除功能,具体见zen-api 下的test 包。
 
 到目前为止,框架这部分基本上不会有太多更新。目前业务中需要的即时通信相关服务,会单独写一个即时通信服务。
 业务系统通过rabbitmq 消息总线发送消息到 消息推送系统完成这方面的需求。后期会提供相关的接口包。

#### 2018/10/31
- 文件上传已完成,请查看 fastdfs-client 查看上传案例写法。

#### 2018/11/1
- 调整了zen-core 包的目录结构,各位耐心改正一个引入包的路径
- 给每个客户端添加跨域配置,方便调试

#### 2018/12/20
- 修复了IFUserService 无法使用,
- 新增了IFUserService 根据账号信息获取用户信息接口和修改用户的接口
- 新增了获取文件信息的接口,未测试


#### 2019/1/5

- 更新User 字段,添加 avatar字段信息
- 更新两个与安全有关的依赖包

#### 2019/1/8

- 解决docker 从容器无法限制JVM内存问题
- 更改基础镜像为openjdk:8-jre-alpine (以前为8-jdk-alpine),减小镜像体积。

### 后期我的工作计划

- 将继续精简shiro相关配置,直至完全移除;(已完成)
- 消息总线 (已完成)
- 日志记录
- 即时通信(估计会另外建一个项目来做即时通信)
- 网关的权限管理。
- 阿里云对象存储,前后端文件上传功能。


## Docker 相关介绍
### 打包
运行任务 : task dockerBuilder。
特别注意在打包之前需要在idea 的命令行中登陆到镜像中心。
登陆命令为:docker login --username=gxzcalyqy registry.cn-qingdao.aliyuncs.com
密码为:docker20181018


如果一切没有问题,打包成功之后会自动上传到镜像中心。等待上传完成。出现如下提示说明上传完成:

        
    BUILD SUCCESSFUL in 4m 10s
    26 actionable tasks: 5 executed, 21 up-to-date
    17:40:25: Task execution finished 'dockerBuilder'.



### 运行命令

docker run -t  --name `NAME` -m568m --expose=`PORT`  -p `PORT`:`PORT` -e "EUREKA_INSTANCE_IP-ADDRESS=`IP`" -e "SERVER_PORT=`PORT`"  IMAGE_NAME

- IP 宿主机的ip
- PORT 服务部署的端口号
- NAME 容器名称,这个自定义
- IMAGE_NAME 镜像名称或者镜像的ID
- -m ,限制容器使用内存

### 注意事项

- 修改zen-web下的zen-web.gradle 中 task dockerBuilder applicationName为项目自己的内容

以下片段位于zen-web.gradle ,修改其中的applicationName


        task dockerBuilder(type: Docker) {
            registry='registry.cn-qingdao.aliyuncs.com/gxzc-envir'
            applicationName = 'fw'
            tagVersion = jar.version
            addFile("./build/libs/${jar.baseName}-${jar.version}.jar","app.jar")
            entryPoint(["java","-Djava.security.egd=file:/dev/./urandom","-jar",'app.jar'])
            exposePort(11000)
            doFirst {
                copy {
                    from jar
                    into stageDir
                }
            }
            push = true
        }
        
        
 - mysql 时区问题

         -e TZ=Asis/Shanghai   生成容器的时候,指定时区
        set global time_zone = '+8:00'  临时修改,重启后失效
        
## 其他说明