litemall是一个简单的商场系统,基于现有的开源项目,重新实现一个完整的前后端项目,包含小程序客户端和网页管理端。
项目的架构是三个系统和六个模块:
- 基础系统(core),由数据库、数据库业务模块litemall-db、对象存储模块litemall-os-api组成;
- 小商场系统(wxmall),由litemall-wx-api模块和litemall-wx模块组成;
- 后台管理系统(admin),由litemall-admin-api模块和litemall-admin模块组成。
- 简单商城系统(mall),这里仅列出,目前没有开发计划。
而六个模块的开发设计到三种技术栈:
- Spring Boot技术栈,采用IDEA开发工具,开发litemall-db、litemall-os-api、litemall-admin-api和litemall-wx-api共四个模块;
- miniprogram(微信小程序)技术栈,采用微信小程序开发工具,开发litemall-wx模块;
- Vue技术栈,采用VSC开发工具,开发litemall-admin模块。
从业务功能上,目前由五个业务模块(参考nideshop-mini-program和platform)组成:
- 会员业务模块
- 商场业务模块
- 商品业务模块
- 推广业务模块
- 系统业务模块(仅管理平台)
-
首页
-
专题列表
-
专题详情
-
分类列表
-
分类详情
-
品牌列表
-
品牌详情
-
新品首发
-
人气推荐
-
商品搜索
-
商品详情
-
商品评价列表
-
商品评价
-
购物车
-
下单
-
我的主页
-
订单列表
-
订单详情
-
地址列表
-
地址添加
-
我的收藏
-
我的足迹
-
支付页面(待定)
-
优惠券选择(待定)
-
我的优惠券(待定)
- 会员管理
- 会员管理
- 收货地址管理
- 会员收藏
- 会员足迹
- 搜索历史
- 购物车
- 会员等级(待定)
- 会员优惠劵(待定)
- 商城管理
- 区域配置
- 品牌制造商
- 订单管理
- 商品类目
- 通用问题
- 关键词
- 渠道管理(待定)
- 商品管理
- 商品管理
- 商品参数
- 商品规格
- 货品管理
- 用户评论
- 团购设置(待定)
- 商品满减搭配(待定)
- 推广管理
- 广告列表
- 专题管理
- 优惠劵管理(待定)
- 系统管理
- 管理员
- 对象存储
- 权限管理(待定)
- 定时任务(待定)
- 参数管理(待定)
- 系统日志(待定)
存在以下特点:
- 数据库方面,只是简单的表,表和表之间的依赖关系没有采用外键设计,而是依赖Java代码在service层面或者业务层面保证。这样做的好处是数据库频繁改动很方便,不会因为外键而导致数据库难以修改;
- 涉及三种技术栈,但是每种技术栈仅涉及最基础的技术;
- 后端技术栈,仅涉及 Spring,Spring Boot, Spring MVC和Mybatis技术,其他后端技术暂时不采用;
- 小程序技术栈,仅涉及miniprogram官方文档和nideshop-mini-program项目;
- 前端技术栈,仅涉及vue, vuex, vue-route,element-ui技术和vue-element-admin项目;
- 安全方面,仅采用最基本的代码,提供简单基本的安全服务;
- 性能方面,没有涉及内存数据库缓存功能,而是完全依赖MySQL;
- 对象存储服务(图片上传和下载)方面,没有采用云存储方案,而是实现自有的简单文件上传下载功能。对象只是简单存储在后台主机的一个文件夹中,从而解耦当前项目对对象存储云平台的依赖,同时加强对对象存储概念的理解。
总之,目前的系统只是为了学习技术和业务而开发的一个简单商场原型系统。虽然缺失很多企业级功能,但是是完整和合理的原型系统。
注意:
以上特点并不一定是优点。
如图所示,当前开发阶段的方案:
- MySQL数据访问地址
jdbc:mysql://localhost:3306/litemall
- litemall-os-api对象存储服务地址
http://localhost:8081
- litemall-wx-api后台服务地址
http://localhost:8082
,数据则来自MySQL - litemall-admin-api后台服务地址
http://localhost:8083
,数据则来自MySQL - litemall-admin前端访问地址
http://localhost:9527
, 数据来自litemall-admin-api - litemall-wx没有前端访问地址,而是直接在微信小程序工具上编译测试开发,最终会部署到微信官方平台(即不需要自己部署web服务器),而数据则来自litemall-wx-api
- 安装JDK8
- 安装maven
- 安装Git(可选)
- 安装IDEA Community 建议安装maven插件和Git插件
- IDEA导入本项目
- 采用maven命令行或者IDEA的maven插件安装本项目依赖库
- 编译本项目
- 运行litemall-os-api, 打开浏览器,输入
如果出现JSON数据,则Spring Boot开发环境部署成功,litemall-os-api模块运行正常。
http://localhost:8081/storage/index/index
- 同上,运行litemall-wx-api, 打开浏览器,输入
如果出现JSON数据,则litemall-wx-api模块运行正常。
http://localhost:8082/wx/index/index
- 同上,运行litemall-admin-api, 打开浏览器,输入
如果出现JSON数据,则litemall-admin-api模块运行正常。
http://localhost:8083/admin/index/index
注意:
由于设置了三个不同的端口,因此开发时,IDEA可以同时运行litemall-os-api、litemall-wx-api和litemall-admin-api三个Spring Boot程序。
- 安装微信小程序开发工具
- 导入本项目的litemall-wx模块文件夹
- 编译前,请确定litemall-wx-api模块已经运行,而litemall-wx模块的config文件夹中的api.js已经设置正确的后台数据服务地址;
- 点击
编译
,如果出现数据和图片,则运行正常
-
安装npm(或者cnpm)
-
安装VSC(Visual Studio Code)
-
导入本项目的litemall-admin模块文件夹
-
安装依赖库
cnpm install
-
编译并运行
cnpm run dev
然后,打开浏览器,输入
http://localhost:9527
。 如果出现管理后台登录页面,则表明管理后台的前端运行正常; -
请确定litemall-admin-api模块已经运行,然后点击
登录
,如果能够成功登录,则表明管理后台的前端和后端对接成功,运行正常。
在1.4节中介绍的是开发阶段时一些关键性开发流程。本节将介绍代码开发成功以后开始部署项目时一些关键性流程。
首先,需要明确的是开发时项目使用的服务地址是本地地址,即localhost;而部署时则应该根据具体情况设置合理的服务器地址和端口。
其次,需要明确的是各模块之间的关系:
- litemall-os-api模块会包含litemall-db模块,部署在服务器中
- litemall-wx-api模块会包含litemall-db模块,部署在服务器中
- litemall-admin-api模块会包含litemall-db模块,部署在服务器中
- litemall-wx模块部署在腾讯官方平台中,此外数据API地址指向litemall-wx-api所在服务qi地址
- litemall-admin编译出的静态文件放在web服务器或者tomcat服务器,此外服务器地址设置指向3中litemall-admin-api所在地址
注意
- 这里litemall-os-api、litemall-admin-api和litemall-wx-api也可以选择编译成jar模式的可执行文件(因为内嵌tomcat服务器),然后直接运行。
- litemall-wx正式部署时需要设置https开头的合法域名,因此litemall-wx-api所在的服务器需要配置合适的域名和SSL证书,具体参见官方文档。
最后,如果项目正式部署,请一定要在以下文件中或代码中修改相应的配置。
- MySQL数据库设置合适的用户名和密码等信息,同时在litemall-os-api、litemall-wx-api和litemall-admin-api模块
的
resources/application-prod.properties
中设置正确的数据库配置信息。 - litemall-wx模块
config/api.js
设置正确的WxApiRoot
和StorageApi
。 如果采用第三方对象存储服务,StorageApi
指向第三方即可。 - litemall-wx-api模块
config/WeixinConfig.java
中设置所申请的微信小程序APP和微信支付相应的信息。 - litemall-os-api模块
resources/application-prod.properties
中设置litemall-os-api服务所在的域名和端口地址如果采用第三方对象存储服务,那么litemall-os-api可以不部署,这里的配置开忽略。org.linlinjava.litemall.os.address=http://XXX.com org.linlinjava.litemall.os.port=80
- litemall-admin模块
config/prod.env.js
中设置正确的BASE_API
和OS_API
。 如果采用第三方对象存储服务,OS_API
指向第三方即可。
实际上,最终的部署方案是灵活的:
- 可以单一云主机中仅安装一个tomcat服务器并配置一个端口,然后同时部署四个项目的模块,从而提供四种服务 (即litemall-admin静态页面,litemall-os-api存储服务、litemall-amdin-api后台服务和litemall-wx-api后台服务)。
- 也可以是同一云主机中安装四个服务器分别配置四个端口,分别提供四种服务
- 也可以是四个云主机各自安装服务器配置端口,分别提供四种服务
- 当然,甚至多个服务器,并发提供服务。
注意
本机
指的是是当前的开发机云主机
指的是用户购买并部署的远程主机
以下简单列举几种方案。
这里,我们是把window作为开发环境进行本项目的开发工作。 而项目开发完毕以后,在正式部署之前,可以先进行一个简单的本机测试部署方案。
首先,需要确保本地MySQL已经安装并且导入了litemall.sql数据;
其次,项目打包
cd litemall
mvn clean
mvn package
最后,本机测试性部署三个Spring Boot应用
cd litemall
java -jar ./litemall-os-api/target/litemall-os-api-0.1.0.jar &
java -jar ./litemall-wx-api/target/litemall-wx-api-0.1.0.jar &
java -jar ./litemall-admin-api/target/litemall-admin-api-0.1.0.jar &
如果,能够访问以下链接的数据,则表明本地测试部署成功:
http://localhost:8081/storage/index/index
http://localhost:8082/wx/index/index
http://localhost:8083/admin/index/index
注意
由于这里使用
&
设置成后台运行,因此测试结束以后,用户需要自行通过任务管理器或其他软件关闭这三个后台Spring Boot应用。
局域网方案,面向的是最终服务器数据和部分应用程序部署在局域网内的场景。
单机云部署方案,面向的是服务器数据和应用部署在云主机单机中用于演示的场景。
主要流程是:创建云主机,安装ubuntu操作系统,按照JDK和MySQL应用运行环境,部署三个Spring Boot微服务后台应用, 以及部署管理后台静态文件到tomcat。
请参考腾讯云官方文档进行相关操作。
-
创建云主机虚拟机
-
安装操作系统
本项目采用ubuntu 16.04.1,但是并不限制其他操作系统。
-
创建安全组
目前允许的端口:8081,8082,8083,8080,80,443,22,3306
-
设置SSH密钥(可选)
建议用户设置SSH密钥,可以免密码登录云主机,以及用于脚本自动上传应用。
-
使用PuTTY远程登录云主机
如果用户设置SSH密钥,可以采用免密码登录;否则采用账号和密码登录。
https://www.digitalocean.com/community/tutorials/how-to-install-java-with-apt-get-on-ubuntu-16-04 http://www.webupd8.org/2012/09/install-oracle-java-8-in-ubuntu-via-ppa.html
sudo add-apt-repository ppa:webupd8team/java
sudo apt-get update
sudo apt-get install oracle-java8-installer
sudo apt-get install oracle-java8-set-default
警告
"ppa:webupd8team/java" 不是Oracle官方PPA,可能存在安全隐患。
https://www.digitalocean.com/community/tutorials/how-to-install-mysql-on-ubuntu-16-04 https://www.linuxidc.com/Linux/2017-01/139502.htm
sudo apt-get update
sudo apt-get install mysql-server
sudo apt-get install mysql-client
下面是可选地设置root账号远程访问MySQL
-
MySQL默认不支持远程访问,因此需要修改配置文件
sudo vi /etc/mysql/mysql.conf.d/mysqld.cnf
添加'#'注释掉其中的
bind-address
,#bind-address= 127.0.0.1`;
-
设置root账号远程访问权限
mysql -u root -p GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '123456' WITH GRANT OPTION; FLUSH PRIVILEGES; quit;
-
登录腾讯云,设置云主机的
安全组
,允许3306
端口访问,然后重启云主机,使得这些配置生效。
警告
- 因为安全的原因,MySQL不应该设置远程访问, 这里仅仅用于方便数据导入操作。
- MySQL应该部署在专门的服务器中, 这里仅仅用于演示远程部署MySQL。
这里可以采用命令行式,也可以采用MySQL自带的Workbench导入。
- 命令行导入
- 采用FileZilla把本项目的litemall.sql上传到云主机
- 使用PuTTY登录云主机
- 进入MySQL,输入上节所设置的MySQL的root密码
- 创建数据库、 创建用户并分配访问权限
- 导入数据
- 退出
- MySQL Workbench导入
- 先确认已经在1.4.3节中设置了root可以远程访问;
- 创建一个新的连接,设置
Hostname
、Username
和Password
, 然后点击Test Connection
测试是否能够连接到云主机; 如果测试成功,则进入; - 用户自行学习文档,完成
创建数据库
、创建用户
和分配权限
三个操作; - 利用Workbench的
Server
菜单下的Data Import
完成数据导入。
- 命令脚本
cd deploy
mysql -h localhost -u root -p123456
source ./litemall-db/litemall_schema.sql
source ./litemall-db/litemall.sql
其中123456是用户所设置的MySQL的管理员密码。
-
本项目中采用二进制jar包方式来部署Spring Boot后端应用,因此可以不需要部署在tomcat中。 但是,litemall-admin前端项目最终会编译出静态文件,需要部署在服务器中,因此这里仍需安装tomcat(或者其他服务器)。
sudo apt-get install tomcat8
-
为了配置tomcat支持外部文件夹中,修改tomcat的server文件的
Host
标签sudo vi /var/lib/tomcat8/conf/server.xml
在其中添加一行新的内容
<Host> ... <Context path="/" docBase="/home/ubuntu/deploy/litemall-admin/dist" reloadable="true" /> ... </Host>
-
重启tomcat
sudo service tomcat8 restart
- Spring Boot打包
通常项目打包方案存在两种:
- 一是打包war格式,因此云主机需要专门安装tomcat
- 二是打包可执行jar格式,此时内部包含嵌入式tomcat
这里仅采用第二种方案,简化tomcat的安装配置过程。
采用如下命令进行项目打包
cd litemall
mvn clean
mvn package
此时,在litemall-os-api项目的target文件夹中看到litemall-os-xxx.jar; 在litemall-wx-api项目的target文件夹中看到litemall-wx-xxx.jar; 在litemall-admin-api项目的target文件夹中看到litemall-admin-xxx.jar。
- Vue项目打包
采用如下命令进行项目打包
cd litemall/litemall-admin
cnpm run build:prod
此时,litemall-admin模块的dist文件夹中就是最终部署时的代码,可以先压缩,上传到云主机,再解压缩。
https://docs.spring.io/spring-boot/docs/1.5.10.RELEASE/reference/htmlsingle/#deployment-service
-
项目进一步打包到deploy文件夹中:
- litemall-os-api模块编译得到的litemall-os-api-xxx.jar 保存到deploy的litemall-os-api文件夹中,同时重命名成litemall-os-api.jar
- litemall-wx-api模块编译得到的litemall-wx-api-xxx.jar 保存到deploy的litemall-wx-api文件夹中,同时重命名成litemall-wx-api.jar
- litemall-admin-api模块编译得到的litemall-admin-api-xxx.jar 保存到deploy的litemall-admin-api文件夹中,同时重命名成litemall-admin-api.jar
- litemall-admin模块编译以后,把dist文件夹压缩,然后放到deploy的litemall-admin文件夹中。
-
使用FileZilla把deploy整个文件夹上传到云主机的/home/ubuntu文件夹中
-
使用PuTTY登录云主机
-
如果用户没有部署litemall数据库,可以运行以下命令:
cd deploy mysql -h localhost -u root -p123456 source ./litemall-db/litemall_schema.sql source ./litemall-db/litemall.sql
注意,123456是用户所设置的MySQL管理员密码 警告:
litemall_schema.sql会尝试删除litemall数据库然后重建一个新的数据。
-
运行脚本部署运行
sudo ./deploy/bin/deploy.sh
-
测试部署是否成功
请确保云主机的安全组已经允许相应的端口(见1.5.3.1); 然后测试是否部署成功(xxx.xxx.xxx.xxx是云主机IP):
http://xxx.xxx.xxx.xxx:8081/storage/index/index http://xxx.xxx.xxx.xxx:8082/wx/index/index http://xxx.xxx.xxx.xxx:8083/admin/index/index http://xxx.xxx.xxx.xxx:8080/#/login
-
自动上传脚本
为了简化步骤1和步骤2,完成了deploy/util/upload.sh脚本,用户需要设置相应的云主机IP和密钥文件路径。 该脚本会自动把当前项目不同模块下的最终部署文件复制到deploy文件夹中,然后上传到云主机。 注意:
上传脚本没有自动做Spring Boot项目打包和Vue项目打包工作
如下图所示,上传脚本自动上传deploy文件夹到云主机: 需要指出的是,这里的upload.sh脚本是private文件夹中的文件,因为private文件夹是 在.gitignore中设置忽略,因此upload.sh脚本里面可以包含一些隐私信息, 如云主机IP和当前系统私钥文件地址,而其他内容则和deploy/util/upload.sh完全一致。
如果用户需要先编译项目再上传,也可以运行util/lazy.sh。 注意,运行命令必须在项目主目录中,类似如下命令:
cd litemall ./deploy/util/lazy.sh
目前没有测试过,但是简单的分布式应该是可行的。
由于本项目是面向微小型企业的小商城系统,因此预期的分布式部署方案是
- 专门的云数据库部署数据
- 一台云主机部署管理后台的后台服务
- 一台云主机部署管理后台静态文件服务
- 一台云主机部署小商场的后台服务
- 专门的云存储方案
因此,如果需要实现互联网式分布式云部署,目前的项目架构和方案会存在很多问题。 至少每个功能模块应该是独立服务系统。此外,需要引入单点登录系统、集群、缓存 和消息队列等多种技术。