ssm实战——秒杀系统之创建项目管理依赖设计数据库

author author     2022-09-01     793

关键词:

注:本项目使用Myeclipse开发。

一:项目创建

1:使用Myeclipse创建一个web project,命名为MySeckill,并转换为Maven项目。

2:创建项目文件目录如下:

技术分享

上面四个包分别管理:源代码、源代码资源(配置文件)、测试代码、测试代码资源(配置文件)

3:在pom.xml添加SSM框架所需依赖包:

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <groupId>MySeckill</groupId>
  <artifactId>MySeckill</artifactId>
  <version>0.0.1-SNAPSHOT</version>

    <dependencies>
    <!-- 单元测试依赖:使用4.11版本,该版本提供基于注解的测试配置 -->
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.11</version>
            <scope>test</scope>
        </dependency>

    <!-- 1:日志依赖:slf4j:日志的规范、接口 + logback:日志接口的实现 + 二者整合依赖包-->
   <dependency>
       <groupId>org.slf4j</groupId>
          <artifactId>slf4j-api</artifactId>
       <version>1.7.7</version>
   </dependency>
    <dependency>
        <groupId>ch.qos.logback</groupId>
        <artifactId>logback-core</artifactId>
        <version>1.1.1</version>
    </dependency>
    <!-- 实现slf4j接口并整合 -->
    <dependency>
        <groupId>ch.qos.logback</groupId>
        <artifactId>logback-classic</artifactId>
        <version>1.1.1</version>
    </dependency>
    
    <!-- 2:数据库依赖:mysql驱动 + c3p0连接池 -->
    <dependency>
       <groupId>mysql</groupId>
       <artifactId>mysql-connector-java</artifactId>
       <version>5.1.37</version>
       <scope>runtime</scope>
   </dependency>
    <dependency>
        <groupId>c3p0</groupId>
        <artifactId>c3p0</artifactId>
        <version>0.9.1.2</version>
    </dependency>
        
    <!-- 3:Mybatis相关依赖:mybatis自身依赖 + mybatis整合spring依赖 -->
    <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.3.0</version>
        </dependency>
    <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis-spring</artifactId>
            <version>1.2.3</version>
    </dependency>    
    
    <!-- 4: Servlet web相关依赖-->
    <!-- 标签依赖 + jstl标签库 -->
    <dependency>
            <groupId>taglibs</groupId>
            <artifactId>standard</artifactId>
            <version>1.1.2</version>
        </dependency>
    <dependency>
            <groupId>jstl</groupId>
            <artifactId>jstl</artifactId>
            <version>1.2</version>
    </dependency>
    <!-- json处理工具:jackson依赖 -->    
    <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-databind</artifactId>
            <version>2.5.4</version>
    </dependency>    
    <!-- servlet本身依赖 -->
    <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>javax.servlet-api</artifactId>
            <version>3.1.0</version>
    </dependency>
    
    <!-- 5:spring相关依赖 -->
    <!-- 1)spring核心依赖:core、beans、context -->
    <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-core</artifactId>
            <version>4.1.7.RELEASE</version>
    </dependency>
    <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-beans</artifactId>
            <version>4.1.7.RELEASE</version>
    </dependency>
    <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>4.1.7.RELEASE</version>
    </dependency>
    
    <!-- 2)spring dao层依赖:jdbc依赖 + 事务管理依赖 -->
    <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-jdbc</artifactId>
            <version>4.1.7.RELEASE</version>
    </dependency>
    <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-tx</artifactId>
            <version>4.1.7.RELEASE</version>
    </dependency>
    
    <!-- 3)spring web层依赖:web依赖 + mvc依赖 -->
    <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-web</artifactId>
            <version>4.1.7.RELEASE</version>
    </dependency>
    <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-webmvc</artifactId>
            <version>4.1.7.RELEASE</version>
    </dependency>
    
    <!--4)spring测试依赖  -->
    <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-test</artifactId>
            <version>4.1.7.RELEASE</version>
    </dependency>
    </dependencies>
    <build /> 
</project>

 

二:项目分析

1:秒杀操作

秒杀操作其实就是对数据库库存的减操作,并记录这个动作以及结果。这个“减”+“记录”是原子的,所以需要事务来管理。

2:动作信息

用户执行秒杀操作,所需信息主要有:谁?什么时候?结果如何?

3:高并发瓶颈

整个秒杀过程归根结底就是对库存的“减”操作的执行。一个减操作,对应库存表一行商品记录的修改;多个用户秒杀这个商品,则对应多个对这行的操作。这些同时发起的对同一行的操作该如何安排顺序?

数据库本身采用行级锁来管理这些并发的操作:对同一行,某一时刻只能有一个事务操作它。

那么一旦事务多了起来,比如上万条秒杀操作该如何调度?这就是高并发的瓶颈所在。

 

三:功能实现

1:秒杀网址暴露

到了秒杀时间才开放秒杀网址

2:执行秒杀

3:秒杀后是信息查询

 

四:数据库设计

CREATE DATABASE seckill;

USE seckill;

CREATE TABLE seckill(
`seckill_id` BIGINT NOT NULL AUTO_INCREMENT COMMENT 商品库存id,
`name` VARCHAR(120) NOT NULL COMMENT 商品名称,
`number` INT NOT NULL COMMENT 库存数量,
`create_time` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT 创建时间,
`start_time` TIMESTAMP NOT NULL COMMENT 秒杀开启时间,
`end_time` TIMESTAMP NOT NULL COMMENT 秒杀结束时间,
PRIMARY KEY(seckill_id),
KEY idx_start_time(start_time),
KEY idx_end_time(end_time),
KEY idx_create_time(create_time)
)ENGINE=INNODB AUTO_INCREMENT=1000 DEFAULT CHARSET=utf8 COMMENT=秒杀库存表;

`success_killed`

CREATE TABLE success_killed(
`seckill_id` BIGINT NOT NULL COMMENT 秒杀商品id,
`user_phone` BIGINT NOT NULL COMMENT 用户手机号,
`state` TINYINT NOT NULL DEFAULT -1 COMMENT 状态标识:-1:无效 0:成功 1:已付款,2:已发货
`create_time` TIMESTAMP NOT NULL COMMENT 创建时间,
PRIMARY KEY(seckill_id,user_phone),/*联合主键*/
KEY ids_create_time(create_time)

)ENGINE=INNODB DEFAULT CHARSET = utf8 COMMENT=秒杀成功明细表;

 

ssm实战——秒杀系统之高并发优化

一:高并发点高并发出现在秒杀详情页,主要可能出现高并发问题的地方有:秒杀地址暴露、执行秒杀操作。 二:静态资源(页面)访问优化——CDNCDN,内容分发网络。我们把静态的资源(html/css/js)放在CDN上,以加快用户... 查看详情

秒杀系统企业级实战应用之真实工业界案例

...统-基础回顾SpringMVC讲解00:21:19  第07课、秒杀系统-数据库设计100:26:42  第08课、秒杀系统-数据库设计200:21:28  第09课、秒杀系统-项目搭建00:29:39  第10课、秒杀系统-Spring+SpringMVC+Mybatis实现商家模块100:23:... 查看详情

重磅回归-ssm整合进阶项目实战之个人博客系统

...输出:我自己实现的spring4+springmvc+mybatis3整合的进阶项目实战-个人博客系统已然完成了,系统采用mvc三层模式进行整体的开发,涉及到技术一下子很难全部列出,其中不得不提的有:整合shiro实现登录安全认证,整合lucene实现全... 查看详情

项目实战仓库信息管理系统(layui+ssm+springboot)(代码片段)

...6.日志记录机制7.鉴权服务设计与实现8.业务功能简述三、数据库设计1.数据库模型设计概览2.数据库表设计①depository②仓库调度记录(deposito 查看详情

13.go语言高并发与微服务实战---综合实战:秒杀系统的设计与实现

13.综合实战:秒杀系统的设计与实现 秒杀系统设计原则: 1.数据要尽量少 2.请求数尽量少 3.路径要尽量短 4.依赖要尽量少 5.尽量不要有单点       查看详情

13.go语言高并发与微服务实战---综合实战:秒杀系统的设计与实现

13.综合实战:秒杀系统的设计与实现 秒杀系统设计原则: 1.数据要尽量少 2.请求数尽量少 3.路径要尽量短 4.依赖要尽量少 5.尽量不要有单点       查看详情

计算机毕业设计之java+ssm植物养护管理系统

...和退出模块等多个模块。系统采用流行的MVC框架springmvc,数据库mysql,开发工具Myeclipse,使用JAVA语言开发,页面采取JSP动态页面开发技术,SSM(Spring+SpringMVC+MyBatis)框架管理员的登录模块:管理员登录系统 查看详情

计算机毕业设计之java+ssm供应链管理信息系统

...过程进行了详细的描述。本系统基于ssm框架访问作为后台数据库管理连接,通过jdbc与数据库建立连接,以jsp为前端开发工具提供程序界面。通过明确系统目标,对系统需求和功能分析,前台设计出实现系统一般功... 查看详情

计算机毕业设计之java+ssm体育器材租借管理系统

...ring+SpringMVC+MyBatis)框架,开发语言选用Java,数据库选用Mysql,使用mybatis数据库连接技术,使用eclipse作为系统应用程序的开发工具1.用户 查看详情

计算机毕业设计之java+ssm智慧仓库进销存系统

...JAVA编程语言和JSP技术,,并使用Mysql作为系统的数据库。该系统设计了强大的功能模块,考虑了企业库存管理的各个方面。这些主要功能模块分别是系统用户管理、用户信息管理、商品类别管理、仓库管理、商品信息... 查看详情

计算机毕业设计之java+ssm理发店会员管理系统

...用javaweb,基于B/S模式,Myeclipse或者eclipseidea为开发工具,mysql数据库,感兴趣的朋友们可以下载研究一下。针对 查看详情

计算毕业设计之java+ssm中超足球队员信息管理系统

...43;MyBatis)框架的MVC三层设计模式和eclipse编辑器、MySQL数据库设计并实现的有系统用户管理模块、足坛新闻管理模块、球队信息管理、赛事信息管理、积分榜模块、和射手榜模块等多个模块需求分析管理员的登录模块:管... 查看详情

计算机毕业设计之java+ssm闲置图书分享平台系统

.../S结构和java中流行的MVC三层设计模式和eclipse编辑器、MySQL数据库设计并实现的。管理员的登录模块:管理员登录系统对本系统其他管理模块进行管理。用户的登录模块:用户登录本系统&#x 查看详情

计算机毕业设计之java+ssm翻译公司业务管理系统

...务管理系统采用目前最流行的ssm框架和eclipse编辑器、mysql数据库设计并实现的。主要包括登录模块、工作人员管理模块、客户信息管理模块、客户下单管理模块、和退出模块等多个模块.针对现存的问题和需要,通过功能需求... 查看详情

实战高并发大流量秒杀系统

目录php的视频go视频数据库层:案例:秒杀系统的设计和分层介绍:第一个版本秒杀模块的划分秒杀接入层核心功能php的视频学习地址:https://ke.qq.com/course/1586364?tuin=30289dc0go视频学习地址:https://ke.qq.com/course/314678?taid=219870972325407... 查看详情

计算机毕业设计之java+ssm公交站牌广告灯箱管理系统

...java中流行的MVC三层设计模式ssm框架和eclipse编辑器、MySQL数据库设计并实现的。主要包括系统用户管理模块、网站资讯管理模块、任务信息管理、留言管理、登录模块、和退出模块等多个模块.随着现代公交站牌广告灯箱管理的快... 查看详情

实战高并发大流量秒杀系统

目录php的视频go视频数据库层:案例:秒杀系统的设计和分层介绍:第一个版本秒杀模块的划分秒杀接入层核心功能php的视频学习地址:https://ke.qq.com/course/1586364?tuin=30289dc0go视频学习地址:https://ke.qq.com/course/314678?taid=219870972325407... 查看详情

计算机毕业设计之java+ssm活动酒桌预订系统

...式SSM(Spring+SpringMVC+MyBatis)框架和eclipse编辑器、MySQL数据库设计并实现的。主要包括系统用户管理模块、商家信息管理模块、酒店信息管理、订单信息管理、登录模块、和退出模块等多个模块。它帮助活动酒桌预订实现了信... 查看详情