Springboot中文乱码问题(还有一个未解决)
视频地址:http://www.imooc.com/learn/587
这个视频感觉废话有点多,看的有点困。
一、创建项目
1、创建maven项目
data:image/s3,"s3://crabby-images/3db0b/3db0b9abf7376293720f0eb850e1a7463cb94677" alt=""
2、默认创建的项目,用的servlet的版本是2.3,太老,换成3.1
data:image/s3,"s3://crabby-images/ee86c/ee86c3312eddb762cbeda8456a4626ea80fb5ac5" alt=""
3、junit默认是3.8,改为4.11,因为4.x才支持注解
data:image/s3,"s3://crabby-images/431a7/431a76bf53a19624272f36a7ad0a50b1f40b9a3d" alt=""
二、添加依赖
1、日志依赖
data:image/s3,"s3://crabby-images/da5e3/da5e3dd9b20dd6c6da1d0aea3140e2bad8847826" alt=""
data:image/s3,"s3://crabby-images/7ab0b/7ab0b9156c18cc3b91325b4168ea506f37e517b1" alt=""
2、db依赖
data:image/s3,"s3://crabby-images/f173e/f173ebf9d9d9d9475dc6e12109c38aca6d86c742" alt=""
3、dao依赖
data:image/s3,"s3://crabby-images/0371e/0371edc955c4246831ef52c9debc4eda3770dc5e" alt=""
4、servlet web依赖
data:image/s3,"s3://crabby-images/43e9c/43e9c7727e29c766f5f9002a7bdff863e45fe4fa" alt=""
5、Spring依赖
data:image/s3,"s3://crabby-images/51c27/51c27db4dbe7e136fde6e96eec8b227ef13100a6" alt=""
data:image/s3,"s3://crabby-images/11f08/11f08acd226ae00f0c00e13b3a8e1f79cad78455" alt=""
data:image/s3,"s3://crabby-images/b68a3/b68a37ded135c286cca1755720d52eb635aed912" alt=""
data:image/s3,"s3://crabby-images/decbc/decbc99bc2377bd16a203378d3152bb8334f62c8" alt=""
三、秒杀业务
data:image/s3,"s3://crabby-images/71454/71454bf148f51877ecf1d936fe521f92657e345f" alt=""
data:image/s3,"s3://crabby-images/7004e/7004ed79642e5694def6e1ecf3b985bbe0e5466b" alt=""
用户角度:
data:image/s3,"s3://crabby-images/03fd5/03fd55684777ec36e1c7e80692636c7fe1183a2c" alt=""
data:image/s3,"s3://crabby-images/09a02/09a02038f8edf80c490c833e8d77acd898f62c88" alt=""
为什么需要事务:
data:image/s3,"s3://crabby-images/f6fdb/f6fdbbf4c023798c1b0468c25c1553fb8a3e4eab" alt=""
data:image/s3,"s3://crabby-images/d08a2/d08a2c1a06e7321eb0781dd2ff0fec89bf84fc3f" alt=""
数据落地:
NoSQL(如Redis、HBase、ES等)的优势是高性能、高可用、分布式,对事务的支持还是不如MySQL。
data:image/s3,"s3://crabby-images/eab36/eab36d623ce1523ffc80e643878c816cce4377ca" alt=""
四、秒杀系统的难点
data:image/s3,"s3://crabby-images/4ee56/4ee560a4e286dc21293b5705607ae07498e6ceb8" alt=""
事务
data:image/s3,"s3://crabby-images/ff535/ff5350214551c9d7228590d7c4dbf742c9c48c3b" alt=""
行级锁
data:image/s3,"s3://crabby-images/eddee/eddee434aa4f6c408d7dbf45d534abc37a741265" alt=""
data:image/s3,"s3://crabby-images/e8126/e81264a2529c4956d0298eb77fa93b067c5df1a8" alt=""
五、实现哪些秒杀功能
data:image/s3,"s3://crabby-images/fad77/fad7750acab57eaddfff4aaea6d3bb81376f3630" alt=""
本课程实现的功能
data:image/s3,"s3://crabby-images/9c9d9/9c9d9186e6e5bc801cdfd3b60a874c8aeb892f2f" alt=""
代码开发阶段
data:image/s3,"s3://crabby-images/fe901/fe9019e461b232c96f94d1dd40baabd93906ea6d" alt=""
六、数据库设计
data:image/s3,"s3://crabby-images/d3c0b/d3c0b109ee4c7f229b7df08008d889b56fe780cd" alt=""
data:image/s3,"s3://crabby-images/b4f12/b4f12799429c840b3bad694bdaa3988dc5116832" alt=""
七、dao
data:image/s3,"s3://crabby-images/6083e/6083e8fe14d39caa41ad26840c8026fb8fa76270" alt=""
data:image/s3,"s3://crabby-images/9a398/9a398d2c113fa4220734f86eaeaba3e756db7ab2" alt=""
Mybatis的特点
data:image/s3,"s3://crabby-images/42aff/42aff5cfec6dcfca8477c021b2cf1a07569c1ed9" alt=""
mybatis-config.xml
data:image/s3,"s3://crabby-images/8707e/8707e41d303dad7936d65daa039cefefe60bbd7a" alt=""
SeckillDao.xml
data:image/s3,"s3://crabby-images/3552d/3552d909ddf792bd6e191b56de3683aca58b5e1f" alt=""
data:image/s3,"s3://crabby-images/e0f5b/e0f5bd03808deb77c2da84d28ce98ccfb6f577e7" alt=""
SuccessKilledDao.xml
- 第一个sql中的ignore,表示如果插入了重复主键,sql不抛出异常,而是返回0,方便业务处理。
-
第二个sql中的别名,是为了把对象设置为SuccessKilled.seckill属性
image.png
高并发的点:
data:image/s3,"s3://crabby-images/ff6b2/ff6b2846f5f8cf8e24e90085cf602240ca9104e8" alt=""
优化总结
data:image/s3,"s3://crabby-images/610e4/610e4bd2874cc2894bbd75e98845acfd0ae0cfb3" alt=""
最后一点有两种方式:
1、修改mysql源码,在后面增加一个注释,如果达到某个条件(比如发现库存为0),就直接回滚,这样就可以减少java和mysql的交互次数
data:image/s3,"s3://crabby-images/1d5e9/1d5e924c2d22eed09b051033ac911c2afad8961f" alt=""
2、采用存储过程,效果跟上面类似。
redis
更好的序列化对象
protostuff来做序列化,可以提供比java自带序列化更快、更强。体积大概是原来的0.2甚至0.1,时间也是数量级的提升。
data:image/s3,"s3://crabby-images/9dad3/9dad35ec7073467e13fa8a323ccba8391d027cfb" alt=""
data:image/s3,"s3://crabby-images/34fbe/34fbe58e44839f4f0ef13f130967d3f8cc319a12" alt=""
data:image/s3,"s3://crabby-images/8ee6a/8ee6ab02c4edf3cacfdc8255206af6c9745f9fe1" alt=""
锁优化
data:image/s3,"s3://crabby-images/23efe/23efeb38d4a6a68fd99597ebf99adf4dfebb0023" alt=""
把insert提前,缩短update和commit/rollback之间的时间
data:image/s3,"s3://crabby-images/492d0/492d004d6350d5acb3f5cef65dbb0ed5ef54642e" alt=""
data:image/s3,"s3://crabby-images/55108/55108360f19df0d52c56442d7d9000edf66d9c03" alt=""
部署架构
![Uploading image_335182.png . . .]
data:image/s3,"s3://crabby-images/38221/382211a9b0647f61db1c1270d5f50810f72a68dd" alt=""
data:image/s3,"s3://crabby-images/1e334/1e334043e2ed35ec5d2a11fda7b2f8c330d25755" alt=""
1、编码统一:
所有编码都采用utf-8,包括文件编码、数据库链接编码
2、修改application.properties文件,增加如下配置:
spring.http.encoding.force=true
spring.http.encoding.charset=UTF-8
spring.http.encoding.enabled=true
server.tomcat.uri-encoding=UTF-8
3、PathVariable含有中文(未解决)
以上方式可以解决http://xxx.com/test?name=中文这种
但是对于http://xxx.com/test/中文这种还是乱码,网上找了几种解决方式,测试了一下都没奏效,找问题ing。
1)设置mapping的produces
@RequestMapping(value = "/query/{keyword}", method = RequestMethod.GET, produces = "text/html;charset=UTF-8")
public String query(@PathVariable String keyword) {
}
2)自己做编码转换
@RequestMapping(value="/search/{key}", method = {RequestMethod.GET})
public String searchFaceListIndex(@PathVariable(value="key") String key,Map<String, Object> result) throws UnsupportedEncodingException {
key = new String(key.getBytes("ISO-8859-1"), "utf8");
return "searchFaceList";
}
目前尚未解决,欢迎评论指导。