AOP使用详情+nginx部署以及反向代理

aop的使用场景

在我们service层中有多个方法,我们想要统计这些方法运行时的每次耗时,但是我们在多个方法中加入耗时统计未免有点太冗余了,所以我们可以使用aop来进行统一的使用,使用aop需要导入aop的依赖

aop概念
1.连接点

joinpoint可以被aop控制的方法叫 连接点,比如我们统计方法的执行耗时,统计的这些方法就都是连接点

2.通知 advice 

指那些在aop中 重复的逻辑代码,也就是共性功能

比如  耗时统计这个方法需要  得到  方法开始前的时间和结束后时间,我们用后者减去前者得到执行耗时,但是这个统计耗时的方法需要在所有的service方法中统计,这种共性的 功能也叫通知

3.切入点

在通知当中,我们所定义的共性功能到底要应用在哪些方法上?此时就涉及到了切入点pointcut 概念。切入点指的是匹配连接点的条件。通知仅会在切入点方法运行时才会被应用。

4.切面  aspect

当通知和切入点结合在一起,就形成了一个切面。通过切面就能够描述当前aop程序需要针对于哪 个原始方法,在什么时候执行什么样的操作

5.目标对象  Target,通知所应用的对象

目标对象指的就是通知所应用的对象,我们就称之为目标对象

aop运行流程

首先 我们会为目标对象生成一个代理对象,代理对象注入 controller层的 service方法,然后运行切面类的中的方法,运行一次之后,调用目标对象的原始方法,然后继续运行切面类的方法,直到结束

aop通知类型

当我们的通知类型中的切入点表达式 相同重复的多的话 可以用@pointcut注解来进行 切入点表达式的抽取,需要的时候引入该方法就行

通知类型执行顺序

当我们的对一个目标方法加入了不同的切面类时候,通知默认按照切面类的类名字母排序执行

也可以使用@order注解进行顺序的调控

aop切入点表达式

描述切入点方法的一种表达式 

主要来决定项目中哪些方法需要加入通知

然后在切面类的通知类型中加入自己注解的全路径名

连接点

 

 

nginx 反向代理以及部署

我们在下载nodejs之后和npm安装之后,可以在vue图形化界面vue ui当中创建一个vue项目,写完项目代码之后,我们用打包好文件内容之后,把打包好的文件放入到nginx中的html文件夹中即可完成部署

点击第二个build即可进行文件打包,打包好之后,

在自己下载的nginx全英文目录中找到html文件,把打包好的文件放入html文件中即可完成部署

完成部署之后,点击exe启动nginx,这时候只需要我们在自己电脑中访问 自己在conf文件中设置的端口号就可以 查看自己的前端项目了

 

可以看到我的文件中设置的是 80端口号,只需要在网志中输入 localhost:80 就可以访问,但是这样比较不安全,会暴露我们的后端服务,我们就可以用反向代理 来使我们的后端更安全,访问速度更快,可以进行负载均衡总结来说  就是 前端发送的动态请求 nginx会帮我转发到后端tomcat服务器等,

就是一个拼接的过程,在请求的网址 api前面 会拼接 反向代理设置的网址

  • 12
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
可以使用 RedisTemplate 实现分布式锁,具体实现步骤如下: 1. 定义一个自定义注解,用于标识需要加锁的方法。 2. 在方法执行前获取锁,执行后释放锁。 3. 使用 RedisTemplate 操作 Redis,实现分布式锁。 下面是示例代码: ```java @Target(ElementType.METHOD) @Retention(RetentionPolicy.RUNTIME) public @interface DistributedLock { String key(); long expire() default 30000; } @Component @Aspect public class DistributedLockAspect { @Autowired private RedisTemplate<String, String> redisTemplate; @Around("@annotation(distributedLock)") public Object doAround(ProceedingJoinPoint joinPoint, DistributedLock distributedLock) throws Throwable { String key = distributedLock.key(); long expire = distributedLock.expire(); // 获取锁 boolean locked = false; String lockKey = "lock:" + key; String lockValue = UUID.randomUUID().toString(); try { locked = redisTemplate.opsForValue().setIfAbsent(lockKey, lockValue, expire, TimeUnit.MILLISECONDS); if (!locked) { throw new RuntimeException("获取锁失败"); } // 执行方法 return joinPoint.proceed(); } finally { // 释放锁 if (locked) { String value = redisTemplate.opsForValue().get(lockKey); if (lockValue.equals(value)) { redisTemplate.delete(lockKey); } } } } } ``` 在需要加锁的方法上加上 @DistributedLock 注解,指定锁的 key 和过期时间即可。 例如: ```java @Service public class UserService { @Autowired private UserDao userDao; @DistributedLock(key = "user:update:${#userId}") public void updateUser(long userId, String name) { userDao.updateUser(userId, name); } } ``` 这样就可以实现分布式锁了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

三氧化真

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值