Java开发技术积累(redis、mysql、http、shiro、threadlocal)

前言

工作越久发现自己越麻瓜。感觉只有每天积累一点,才不会觉得空虚。

redis-benchmark用法

redis-benchmark是用于给redis进行压测的。 1.100个并发连接,10000个请求

redis-benchmark -h 127.0.0.1 -p 6379 -c 100 -n 10000

2.存取大小为100字节的数据包

redis-benchmark -h 127.0.0.1 -p 6379 -q -d 100

3.只测试某些操作的性能

redis-benchmark -t set,get,lpush -q -n 10000

4.只测试某些数据存取的性能

redis-benchmark -n 10000 -q script load "redis.call('set','cmazxiaoma','123')"


jmeter命令行使用

1.在windows上录好jmx 2.在linux上进行命令行操作

sh jmeter.sh -n -t xxx.jmx -l result.jtl

3.把result.jtl导入到windows上的jmeter


合理更新缓存

一般我们正确使用Redis的策略是先更新数据库,再删除缓存。在这种情况下,我们可以考虑出脏数据的场景:有一个读操作,但是没有命中缓存,然后就到数据库取数据。此时正好来了一个写操作,让缓存失效,然后之前的那个读操作再把老数据放到缓存中,所以产生了脏数据。

但是这种场景出现的概率很低,因为这个条件需要发现在读操作时缓存需要失效,而且并发着有一个写操作。而实际上数据库的写操作会比读操作慢的多,而且要锁表,而读操作必须要在写操作之前进行数据库操作,而且还要晚于写操作更新缓存。


Linux命令

1.查看linux服务器CPU核数

cat /proc/cpuinfo|grep processor

2.给脚本赋权限,chmod是change the permissions mode of file。u代表所有者,x代表执行权限,+表示增加权限。

chmod n+x *.sh

3.查看系统当前可用内存

cat /proc/meminfo

Java编码

1.Java一律采用Unicode编码方式,每个字符无论中文还是英文字符都占有2个字节。 2.Java虚拟机中通常使用UTF-16的方式来保存一个字符。

MySQL

1.我们查看会话等待时间,全局等待时间。特别提醒:时间的大小不能随便设置,时间过长导致过多的connection sleep,占用较多系统资源。从业务出发,结合查询的耗时和业务吞吐量。

show global variables like 'wait_timeout' show session variables like '%wait%'

2.建唯一索引

alter table order_info add unique key u_idx_user_goods(user_id,goods_id)

Http状态码

当我们前后端分离 + 页面静态化(htm + ajax)去做商品详情页时,请求会返回304。304状态码:如果客户端发送了一个带条件的GET请求且该请求已被允许,而文档的内容并没有改变,则服务器应返回这个304状态。对于商品详情页而言,对数据的及时性没有那么的高,应该考虑将界面缓存到用户的浏览器中。在application-dev.properties中j进行如下配置。

spring.resources.chain.cache=true spring.resources.chain.enabled=true

Ajax

当我们发送Ajax的请求时,要判断readystate=4和status=200才能进行下一步。那么readystate又分为哪几步呢。

0 - 未初始化,还没有创建对象。 1 - 已打开,对象已经创建并且已初始化,但还未调用send方法。 2 - 已发送,已经调用send方法,但对象等待状态码和响应头返回。 3 - 正在接收,已经接收到部分数据,但还不能调用该对象的属性和方法,因为状态码和响应头不完整。 4 - 已加载完,所有数据接收完毕。


Shiro

Shiro的Subject对象是由SecurityManager、HttpRequest等信息创建,然后把Subject绑定到当前线程(servlet线程)。SecurityUtils的getSubject方法是从当前线程中获得到Subject对象的。


ThreadLocal

ThreadLocal本身不存储值,每一个Thread维护着一个ThreadLocalMap,ThreadLocalMap中的key就是ThreadLocal实例本身,value是其需要存储的Object对象。

ThreadLocalMap使用ThreadLocal的弱引用作为其key,如果一个ThreadLocal没有外部强引用去引用它,那么系统GC的时候,这个ThreadLocal会被回收。GC后,ThreadLocal会出key为null的Entry,我们无法访问这些key为null的Entry中的value。如果当前线程迟迟不结束的话,这样key为null的Entry的value就会形成一条引用链:Thread Ref -> Thread -> ThreadLocalMap -> Entry -> value,最终造成内存泄漏。


尾言

脑子不好使,就多背多积累吧。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏机器学习算法与Python学习

Python之运行实现原理

来源:@mozillazg 链接:https://mozillazg.com/2016/04/apm-python-agent-principle.html 本...

376140
来自专栏python学习指南

Python爬虫(十三)_案例:使用XPath的爬虫

本篇是使用XPath的案例,更多内容请参考:Python学习指南 案例:使用XPath的爬虫 现在我们用XPath来做一个简单的爬虫,我们尝试爬取某个贴吧...

24480
来自专栏智能算法

Python学习(九)---- python中的线程

原文地址: https://blog.csdn.net/fgf00/article/details/52773459 编辑:智能算法,欢迎关注! 上期我们一起学...

18220
来自专栏古时的风筝

mybatis Generator生成代码及使用方式

为什么要有mybatis mybatis 是一个 Java 的 ORM 框架,ORM 的出现就是为了简化开发。最初的开发方式是业务逻辑和数据库查询逻辑是分开的,...

26190
来自专栏信安之路

XPath注入:攻击与防御技术

相信大家都非常熟悉 “注入” 这种攻击方式。 “注入” 这种攻击方式被列为了 OWASP 十大攻击的榜首。然而,本文所要讲述的不是被人熟知的SQL 注入攻击。而...

18400
来自专栏SeanCheney的专栏

《Learning Scrapy》(中文版)第5章 快速构建爬虫一个具有登录功能的爬虫使用JSON APIs和AJAX页面的爬虫在响应间传递参数一个加速30倍的项目爬虫可以抓取Excel文件的爬虫总结

第3章中,我们学习了如何从网页提取信息并存储到Items中。大多数情况都可以用这一章的知识处理。本章,我们要进一步学习抓取流程UR2IM中两个R,Request...

37480
来自专栏黑泽君的专栏

windows系统下VS2013或者VS2017的C4996错误解决方法

由于微软在VS2013中不建议再使用c的传统库函数scanf,strcpy,sprintf等,所以直接使用这些库函数会提示C4996错误,在源文件中添加以下指令...

11220
来自专栏python学习指南

Python爬虫Scrapy(二)_入门案例

本章将从案例开始介绍python scrapy框架,更多内容请参考:python学习指南 入门案例 学习目标 创建一个Scrapy项目 定义提取的结构...

22160
来自专栏前端小叙

Vue-router路由判断页面未登录跳转到登录页面

router.beforeEach((to, from, next) => { if (to.matched.some(record => record.m...

65370
来自专栏北京马哥教育

用Python爬下十几万本小说,再也不会闹书荒!

自从看了师傅爬了顶点全站之后,我也手痒痒的,也想爬一个比较牛逼的小说网看看,于是选了宜搜这个网站,好了,马上开干,这次用的是mogodb数据库,感觉mysql太...

18040

扫码关注云+社区

领取腾讯云代金券