【黑马程序员SpringBoot2全套视频教程,springboot零基础到项目实战(spring boot2完整版)】
之前我们又完成了健康指标的自定义


这次我们来说说这个性能指标的自定义

发请求看看里面有什么

就是这些了
这些信息和面板中

的这些信息是对应的
【自定义性能端点监控指标】
在我们的应用中,现在假定一次删除操作就会进行一次付费

修改book 的业务层实现类
package com.dingjiaxiong.service.impl;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.dingjiaxiong.Dao.BookDao;
import com.dingjiaxiong.domain.Book;
import com.dingjiaxiong.service.IBookService;
import io.micrometer.core.instrument.Counter;
import io.micrometer.core.instrument.MeterRegistry;
import org.apache.logging.log4j.util.Strings;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
/**
* ClassName: BookServiceImpl
* date: 2022/10/17 19:51
*
* @author DingJiaxiong
*/
@Service
public class BookServiceImpl extends ServiceImpl<BookDao, Book> implements IBookService {
@Autowired
private BookDao bookDao;
private Counter counter;
public BookServiceImpl(MeterRegistry meterRegistry) {
counter = meterRegistry.counter("用户付费操作次数:");
}
@Override
public boolean saveBook(Book book) {
return bookDao.insert(book) > 0;
}
@Override
public boolean modify(Book book) {
return bookDao.updateById(book) > 0;
}
@Override
public boolean delete(Integer id) {
//每次执行删除操作业务后,等同于执行了付费业务
counter.increment(); //每删除一次,向上递增一次
return bookDao.deleteById(id) > 0;
}
@Override
public IPage<Book> getPage(int currentPage, int pageSize) {
IPage page = new Page(currentPage,pageSize);
return bookDao.selectPage(page , null);
}
@Override
public IPage<Book> getPage(int currentPage, int pageSize, Book book) {
IPage page = new Page(currentPage,pageSize);
LambdaQueryWrapper<Book> queryWrapper = new LambdaQueryWrapper<Book>();
queryWrapper.like(Strings.isNotEmpty(book.getType()),Book::getType,book.getType());
queryWrapper.like(Strings.isNotEmpty(book.getName()),Book::getName,book.getName());
queryWrapper.like(Strings.isNotEmpty(book.getDescription()),Book::getDescription,book.getDescription());
return bookDao.selectPage(page , queryWrapper);
}
}

直接重启应用,查看面板

把这个加入

现在还是0,执行两次删除操作

OK, 再次查看面板

没变,我giao,为啥

行吧,笔者看了下控制器,压根儿没调咱们自己写的方法,改一下

重启一下

删除前

OK, 可以了【当然还有很多更精细的配置】
回顾一下
