jpsite-v1环境搭建

2019-12-09 14:19:24 浏览数 (1)

技术选型

技术

版本

Spring boot

2.0.6

Swagger2

Spring security

5.0.9

docker

最新

Mysql

5.8

java

8

mybatis-plus

3.0.6

Redis

最新

Vue

2.x

Element-UI

项目介绍

git 地址:==> jpsiet-v1

  • 集成Swagger API文档自动生成功能,提供丰富的API管理
  • 支持一二级缓存,使得性能到达极致(一级缓存是由 ConcurrentHashMap ,二级缓存使用 redis )
  • session登录成功存储 redis 中,实现 sso单点登录
  • session 并发数,过期时间可随意指定
  • 带有@ResponseBody 的返回 json 格式实现自定义 type 返回格式
  • 所有http请求拦截打印日志
  • 支持开启异步线程配置,处理多任务
  • REST接口开发规范
  • 基于Spring boot构建,配置文件能少则少
  • 基于Spring security 的权限验证
代码语言:txt复制
1. 图形验证码,短信验证码,手机登录,微信登录,QQ登录
2. 可用配置文件指定哪些 request url 需要验证码校验及验证码类型
3. 记住我功能集成xxl-job轻量级分布式任务调度平台
  • 集成Apollo配置中心
  • 集成 actuator 详细的应用监控,包括http,线程栈,内存等信息
  • 集成 docker 的容器化构建,开箱即用
  • 集成Zookeeper
  • 集成 MyBatis-Plus
代码语言:txt复制
1. 指定表名生成对应的 entity, dao, service , impl ,controller 类文件。
2. 自定义风格包名名称,模块名称,文件名称
3. 热加载、代码生成、分页、性能分析等功能一应俱全。集成Spring Data Elastic方便使用ElasticSearch
  • (后续开发)mybatis动态多数据源配置与分布式事务控制
  • (后续开发)动态渲染.docx合同文件协议模板,并生产pdf与快照
  • (后续开发)集成腾讯云电子合同签章
  • (后续开发)集成Spring Cloud Alibaba
  • (后续开发)前端实现在线预览pdf、word、xls、ppt等文件
  • (后续开发)集成自动化测试报告框架Allure
  • (后续开发)使用drools规则引擎的风控系统基础功能
代码语言:txt复制
1. 账号:垃圾注册、撞库、盗号等
2. 交易:盗刷、恶意占用资源、篡改交易金额等
3. 活动:薅羊毛
4. 短信:短信轰炸
5. 原则上可以动态配置规则

mysql 环境安装

代码语言:txt复制
docker pull mysql
docker run --name mysql -e MYSQL_ROOT_PASSWORD=root -p 3306:3306 -d mysql

xxl-job本地docker安装

git clone https://github.com/xuxueli/xxl-job.git

修改配置文件

Spring Boot 属性配置和使用

xxl-job/xxl-job-admin/src/main/resources/application.properties

代码语言:txt复制
### xxl-job, datasource
spring.datasource.url=jdbc:mysql://${MYSQL_PORT_3306_TCP_ADDR:MYSQL_PORT_3306_TCP_PORT}/xxl-job?Unicode=true&characterEncoding=UTF-8
spring.datasource.password=root
  • MYSQL_PORT_3306_TCP_ADDR
  • MYSQL_PORT_3306_TCP_PORT

分别是获取系统环境变量配置

调度中心docker镜像构建

可以通过以下命令快速构建调度中心,并启动运行;

代码语言:txt复制
mvn clean install package   //maven打包
docker build -t xuxueli/xxl-job-admin ./xxl-job-admin  //构建image
docker run --name xxl-job-admin -p 8089:8080 --link mysql -d xuxueli/xxl-job-admin    // 创建并启动container
docker exec xxl-job-admin env   //查看系统env

--link后mysql的系统环境变量

http://localhost:8089/xxl-job-admin/

apollo配置中心搭建

代码语言:txt复制
git clone https://github.com/nobodyiam/apollo-build-scripts.git

创建ApolloPortalDB

通过各种MySQL客户端导入sql/apolloportaldb.sql即可。

创建ApolloConfigDB

通过各种MySQL客户端导入sql/apolloconfigdb.sql即可。

配置数据库连接信息

编辑demo.sh,修改ApolloPortalDB和ApolloConfigDB相关的数据库连接串信息。

代码语言:txt复制
# apollo config db info
apollo_config_db_url=jdbc:mysql://${MYSQL_PORT_3306_TCP_ADDR}:${MYSQL_PORT_3306_TCP_PORT}/ApolloConfigDB?characterEncoding=utf8
apollo_config_db_username=root
apollo_config_db_password=root

# apollo portal db info
apollo_portal_db_url=jdbc:mysql://${MYSQL_PORT_3306_TCP_ADDR}:${MYSQL_PORT_3306_TCP_PORT}/ApolloPortalDB?characterEncoding=utf8
apollo_portal_db_username=root
apollo_portal_db_password=root

注意:不要修改demo.sh的其它部分

docker容器化

apollo-build-scripts目录下

代码语言:txt复制
build -t apollo-quick-start .  #dockerfile所在目录
docker run --name apollo-admin -p 8070:8070 -p 8080:8080 -p 8090:8090 --link mysql -d apollo-quick-start

启动成功,如果启动失败可以把启动日志copy到宿主机查看

代码语言:txt复制
docker cp apollo-admin:/apollo-quick-start/service/apollo-service.log .
docker cp apollo-admin:/apollo-quick-start/portal/apollo-portal.log .

因为Eureka的Instance Info IP为docker内部IP,外部无法使用

所以添加vm启动参数为宿主机ip

源码阅读解惑

代码语言:txt复制
/Users/haha/.m2/repository/com/ctrip/framework/apollo/apollo-client/1.0.0/apollo-client-1.0.0-sources.jar!/com/ctrip/framework/apollo/internals/RemoteConfigRepository.java:313
/Users/haha/.m2/repository/com/ctrip/framework/apollo/apollo-client/1.0.0/apollo-client-1.0.0-sources.jar!/com/ctrip/framework/apollo/internals/ConfigServiceLocator.java:64
/Users/haha/.m2/repository/com/ctrip/framework/apollo/apollo-client/1.0.0/apollo-client-1.0.0-sources.jar!/com/ctrip/framework/apollo/internals/ConfigServiceLocator.java:75

http://localhost:8080 http://localhost:8070 http://localhost:8090

0 人点赞