Code Monkey home page Code Monkey logo

youzhengjie9 / cloud-mall Goto Github PK

View Code? Open in Web Editor NEW
22.0 2.0 5.0 229.55 MB

cloud-mall是一个基于分布式、微服务架构开发的商城系统,项目主要有几大模块,分别是:后台系统模块、异步模块、人工客服模块、网关模块、日志模块、应用监控模块、订单模块、商品模块、搜索模块、秒杀模块、系统模块、前台模块,几乎实现了中小型公司商城项目的大部分功能,未来待项目优化之后再部署到云上

License: Apache License 2.0

Java 4.03% Batchfile 0.04% Shell 0.07% Roff 0.01% JavaScript 78.12% CSS 12.29% HTML 4.53% Less 0.45% SCSS 0.45%
redis mybatis elasticsearch rabbitmq spring-cloud spring-boot nacos seata sentinel springcloudalibaba guava

cloud-mall's Introduction

cloud-mall

cloud-mall

cloud-mall是一个基于分布式、微服务架构开发的商城系统,项目主要有几大模块,分别是:后台系统模块、异步模块、 人工客服模块、网关模块、日志模块、应用监控模块、订单模块、商品模块、搜索模块、秒杀模块、系统模块、前台模块, 几乎实现了中小型公司商城项目的大部分功能, 作者前期注重功能的实现,后期作者将全心投入到性能优化以及安全方面上的优化, 希望未来的某一天能够把cloud-mall打造成一个能够抗住高的并发量的商城系统。

cloud-mall的架构图

cloud-mall-jiagou.png

开发环境

类别 名称
编译器 IntelliJ IDEA 2019.3
系统1 Windows 11 dev版
系统2 CentOS 7
CPU Intel i5-9300H
内存 24GB
  • 注:特别是内存需要>=16GB才能保证流畅运行,如果不足16GB运行将有点困难

版本对应

名称 版本
Spring Boot 2.3.2.RELEASE
Spring Cloud Hoxton.SR8
Spring Cloud Alibaba 2.2.3.RELEASE
Nacos 1.4.1
Sentinel 1.8.0
Seata 1.3.0
ZipKin 2.12.9
elasticSearch 7.6.1
Kibana 7.6.1
MySQL 5.7
  • 剩下的版本可以随意,上面写出来的版本要严格对应,不然怕会出现兼容性问题!!!

技术栈

后端

名称 官网
Spring Boot https://spring.io/projects/spring-boot
Spring Cloud https://spring.io/projects/spring-cloud
Spring Cloud Alibaba https://spring.io/projects/spring-cloud-alibaba
Nacos https://nacos.io/zh-cn/
Seata http://seata.io/zh-cn/
Sentinel https://github.com/alibaba/Sentinel
ZipKin https://zipkin.io/
Redis http://www.redis.cn/
RabbitMQ https://www.rabbitmq.com/
elasticSearch https://www.elastic.co/cn/elasticsearch/
Kibana https://www.elastic.co/cn/kibana/
MyBatis http://www.mybatis.org/mybatis-3/zh/index.html
Spring Security https://spring.io/projects/spring-security/
PageHelper http://git.oschina.net/free/Mybatis_PageHelper
Maven http://maven.apache.org/
MySQL https://www.mysql.com/
Swagger2 https://swagger.io/
Druid https://github.com/alibaba/druid
fastjson https://github.com/alibaba/fastjson/
sjf4j http://www.slf4j.org/
Nginx http://nginx.org/en/download.html
FastDFS https://github.com/happyfish100/fastdfs

前端

名称 描述 官网
jQuery 函数库 http://jquery.com/
Bootstrap 前端框架 https://v3.bootcss.com/
echarts 可视化图表库 https://echarts.apache.org/zh/index.html
Thymeleaf 模板引擎 https://www.thymeleaf.org/
TinyMCE 富文本编辑器 http://tinymce.ax-z.cn/
layui 模块化前端UI框架 https://www.layui.com/
Angular 应用设计框架与开发平台 https://angular.cn/

秒杀接口压测

8000个线程并发压测秒杀接口,没有发生高并发下的超卖问题,数据和缓存都保持了一致性 miaoshajiekou.png

怎么安装cloud-mall

  • 配置数据库

  • 打开cloud-mall-doc模块,里面有个“sql”文件夹,导入到自己的Navicat即可

  • 配置Nacos、seata、sentinel

  • cloud-mall-doc模块中Nacos1.4.1、seata1.3.0、sentinel1.8.0导入到自己电脑即可,最好不要使用自己的

  • 因为这些软件都是作者开发系统时用的,没什么使用上的问题,比如sentinel是修改过源码重新打的jar包

  • 配置zipkin

  • 这个就随便吧,没啥需要注意的

  • 配置Nginx反向代理服务器

worker_processes  2;
worker_rlimit_nofile 10240;
events {
    worker_connections  10240;
	
}

http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
	
	server_tokens off;
     client_max_body_size    100m;
    #tcp_nopush     on;
    #keepalive_timeout  0;
     keepalive_timeout  65;
	client_header_buffer_size 4k;
	open_file_cache max=10240 inactive=20s;
	open_file_cache_valid 30s;
	open_file_cache_min_uses 1;
    #gzip  on;
     gzip  on; 
     gzip_http_version 1.1; 
     gzip_vary on; 
     gzip_comp_level 6; 
     gzip_proxied any; 
     gzip_types text/plain text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript application/x-httpd-php image/jpeg image/gif image/png; 
     gzip_buffers 16 8k; 
     gzip_disable "MSIE [1-6]\.";
	fastcgi_connect_timeout 300;
	fastcgi_send_timeout 300;
	fastcgi_read_timeout 300;
	fastcgi_buffer_size 64k;
	fastcgi_buffers 4 64k;
	fastcgi_busy_buffers_size 128k;
	fastcgi_temp_file_write_size 128k;
	

	upstream cloudmall.index.cn{
		server localhost:3201 weight=1;
	}
	
	#cloud-mall的web模块
    server {
        listen       80;
        server_name  localhost;
		
        location / {
            root   html;
            index  index.html index.htm;
			proxy_pass http://cloudmall.index.cn;
        }      
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
    
    }
 	
}

安装FastDFS分布式文件系统

  • 由于后期采用阿里云+FastDFS来进行存储图片文件,所以安装cloud-mall必须安装FastDFS,作者安装教程如下:
   docker search fastdfs
   docker pull delron/fastdfs
   docker images
   docker run -dti --network=host --name tracker -v /var/fdfs/tracker:/var/fdfs -v /etc/localtime:/etc/localtime delron/fastdfs tracker
   docker run -dti  --network=host --name storage -e TRACKER_SERVER=192.168.184.132:22122 -v /var/fdfs/storage:/var/fdfs  -v /etc/localtime:/etc/localtime  delron/fastdfs storage
   docker ps #查看容器id
   sudo docker exec -it 容器id /bin/bash
  #下面这两行命令可以不写,就默认配置
   vi /etc/fdfs/storage.conf
   vi /usr/local/nginx/conf/nginx.conf
   
   firewall-cmd --zone=public  --permanent --add-port=8888/tcp
   firewall-cmd --zone=public  --permanent --add-port=22122/tcp
   firewall-cmd --zone=public  --permanent --add-port=23000/tcp
   
    #重启
   systemctl restart firewalld

    #自启动
   docker update --restart=always tracker
   docker update --restart=always storage
第三方登录
gitee
  • 接入gitee第三方授权配置,先在gitee的第三方应用上对网站进行授权,获得Client ID和Client Secret和回调地址,并放到cloud-mall-web模块的application.yml中即可
GitHub
  • GitHub第三方配置有点复杂,也弄了一两天,主要还是GitHub**地区登录很慢
  • 我们只需要把cloud-mall-commons模块中的com.boot.GitHubConstant的CLIENT_ID和CLIENT_SECRET换成自己的
  • 然后在login.html的GitHub第三方登录超链接中client_id=xxx换成自己的id,即可

人工客服表情插件配置

  • 往EmojiProperties配置类里面的emojiMap以key为emoji字符/代号,value为对应svg的格式添加配置,
  • 再修改chat.html引入icon.js地址即可横向扩展表情包的配置.

违规词配置

  • 只需要在cloud-mall-chat模块下的badWord.properties里面配置违规词即可

图片演示

01.png 02.png 03.png 04.png 05.png 06.png 07.png 08.png 09.png 10.png 11.png 12.png 13.png 14.png 15.png 16.png 人工客服-客服视角👇 kefu_view.png 人工客服-用户视角👇 user_view.png 表情包插件配置👇 emoji_config.png

cloud-mall's People

Contributors

youzhengjie9 avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar

cloud-mall's Issues

看了之后小小的感受

开发者你好,我也是从学校里毕业出来不久的,看了这个电商微服务,感觉功能实现的很多,后端技术架构也是目前流行的。要是能够把前端代码和后端分开就好了,可以使用vue

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.