java 集成测试_javadbf.jar

java 集成测试_javadbf.jar0、pom.xml依赖<!–LMDB–> <dependency> <groupId>org.lmdbjava</groupId> <artifactId>lmdbjava</artifactId> <version>0.7.0</version> </dependency>1、application.properties配置:#maven多环境打包的支持l

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

0、pom.xml依赖

<!-- LMDB -->
		<dependency>
			<groupId>org.lmdbjava</groupId>
			<artifactId>lmdbjava</artifactId>
			<version>0.7.0</version>
		</dependency>

1、application.properties配置:

lmdb.path=E:\\lmdb
#单位为MB
lmdb.max.size=256
lmdb.database.count=10

2、LmdbServier 工具类


import lombok.extern.slf4j.Slf4j;
import org.lmdbjava.*;
import org.springframework.stereotype.Service;
import javax.annotation.PostConstruct;
import java.io.File;
import java.nio.ByteBuffer;
import java.nio.charset.StandardCharsets;
import java.util.HashMap;
import java.util.Map;
import static java.lang.Integer.BYTES;
import static java.nio.ByteBuffer.allocateDirect;
import static org.lmdbjava.ByteBufferProxy.PROXY_OPTIMAL;
import static org.lmdbjava.DbiFlags.MDB_CREATE;
import static org.lmdbjava.Env.create;

/** * Lmdb操作工具类 * * @author jack<br> * @version 1.0<br> * @CreateDate 2020年5月11日 <br> */
@Slf4j
@Service
public class LmdbService { 
   

    /** * lmdb path */
    @Value("${lmdb.path}")
    private String lmdbPath;

    /** * env */
    private Env<ByteBuffer> env;

     /** * lmdb max size */
    @Value("${lmdb.max.size}")
    private int lmdbMaxSize;

    /** * lmdb库的数量 */
    @Value("${lmdb.database.count}")
    private int lmdbDatabaseCount;

    /** * Description: 初始化操作 <br> * @author jack<br> * @version 1.0<br> * @CreateDate 2020年5月11日 <br> */
    @PostConstruct
    private void init(){ 
   
        try { 
   
            final File path = new File(lmdbPath);
            env = create(PROXY_OPTIMAL)
                    .setMapSize(lmdbMaxSize * 1024 * 1024)
                    .setMaxDbs(lmdbDatabaseCount)
                    .setMaxReaders(lmdbDatabaseCount*2)
                    .open(path);
            log.info("初始化Lmdb成功......");
        } catch (Exception e) { 
   
            throw new LmdbException("IO failure", e);
        }
    }

    /** * Description: 向库中插入数据 <br> * @param dbName dbname * @param key value 数据 * @author jack<br> * @version 1.0<br> * @CreateDate 2020年5月11日 <br> */
    public void putValueToDb(String dbName, String key,String value) { 
   
        final Dbi<ByteBuffer> db = env.openDbi(dbName, MDB_CREATE);
        try (Txn<ByteBuffer> txn = env.txnWrite()) { 
   
            final Cursor<ByteBuffer> c = db.openCursor(txn);
            c.put(bb(key), bb(value));
            c.close();
            txn.commit();
        }

    }

    /** * Description: 根据指定的key获取数据 <br> * @param dbName dbname * @param key key * @author jack<br> * @version 1.0<br> * @CreateDate 2020年5月11日 <br> */
    public String getValueByKey(String dbName, String key) { 
   

        final Dbi<ByteBuffer> db = env.openDbi(dbName, MDB_CREATE);
        final Cursor<ByteBuffer> c;
        String value ="";
        try (Txn<ByteBuffer> txn = env.txnRead()) { 
   
            c = db.openCursor(txn);
            c.get(bb(key),GetOp.MDB_SET_KEY);
            ByteBuffer byteBuffer = c.val();
            c.close();
            value =  StandardCharsets.UTF_8.decode(byteBuffer).toString();
        }
        return value;
    }

    /** * Description: 获取库下所有的数据 <br> * @param dbName dbname * @author jack<br> * @version 1.0<br> * @CreateDate 2020年5月11日 <br> */
    public Map<String, String> getAllValueByDbName(String dbName) { 
   
        final Dbi<ByteBuffer> db = env.openDbi(dbName, MDB_CREATE);
        Map<String, String> map = new HashMap<>();
        try (Txn<ByteBuffer> txn = env.txnRead()) { 
   
            Cursor<ByteBuffer> cursor = db.openCursor(txn);
            while (cursor.next()) { 
   
                ByteBuffer key = cursor.key();
                ByteBuffer val = cursor.val();
                byte[] k = new byte[key.capacity()];
                byte[] v = new byte[val.capacity()];
                key.get(k);
                val.get(v);
                map.put(new String(k,StandardCharsets.UTF_8), new String(v,StandardCharsets.UTF_8));
            }
            cursor.close();
        }
        return map;
    }

    /** * Description: 根据dbname获取该库下的数量 <br> * @param dbName dbname * @author jack<br> * @version 1.0<br> * @CreateDate 2020年5月11日 <br> */
    public long getDbCount(String dbName) { 
   
        return getAllValueByDbName(dbName).size();
    }

    /** * 格式化 ByteBuffer * @param value * @author jack<br> * @version 1.0<br> * @CreateDate 2020年5月11日 <br> */
    static ByteBuffer bb(final int value) { 
   
        final ByteBuffer bb = allocateDirect(BYTES);
        bb.putInt(value).flip();
        return bb;
    }

    /** * 格式化 ByteBuffer * @param value * @author jack<br> * @version 1.0<br> * @CreateDate 2020年5月11日 <br> */
    static ByteBuffer bb(final String value) { 
   
        byte[] val = value.getBytes(StandardCharsets.UTF_8);
        final ByteBuffer bb = allocateDirect(val.length);
        bb.put(val).flip();
        return bb;
    }

}

3、lmdb数据库名称枚举:LmdbNameEnum

主要用于:定义lmdb中的dbName

public enum LmdbNameEnum { 
   
	//点位状态
	PointStatus("pointStatus");

	private String dbName;

	LmdbNameEnum(String dbName) { 
   
		this.dbName = dbName;
	}

	public String getDbName() { 
   
		return dbName;
	}

	@Override
	public String toString() { 
   
		return "LmdbNameEnum{" + "dbName=" + dbName + '}';
	}
}

4、Demo测试:LmdbController

package com.jack.maintain.controller;

import com.jack.framework.json.resp.BaseResp;
import com.jack.maintain.cache.LmdbService;
import com.jack.maintain.enums.LmdbNameEnum;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.*;

import java.util.Map;

@Controller
@RequestMapping(value = "/lmdb")
public class LmdbController{ 
   

    @Autowired
    private LmdbService lmdbOperation;


    @RequestMapping(value = "setPoint/{point}",method = RequestMethod.GET)
    @ResponseBody
    public BaseResp setPoint(@PathVariable("point") String point){ 
   
        lmdbOperation.putValueToDb(LmdbNameEnum.PointStatus.getDbName(),point,point);
        return BaseResp.success("设值成功");
    }

    @RequestMapping(value = "getPoint/{point}",method = RequestMethod.GET)
    @ResponseBody
    public BaseResp getPoint(@PathVariable("point") String point){ 
   
        String val = lmdbOperation.getValueByKey(LmdbNameEnum.PointStatus.getDbName(),point);
        return BaseResp.success("成功",val);
    }

    @RequestMapping(value = "getPointCount",method = RequestMethod.GET)
    @ResponseBody
    public BaseResp getPointCount(){ 
   
        long count = lmdbOperation.getDbCount(LmdbNameEnum.PointStatus.getDbName());
        return BaseResp.success("成功",count);
    }

    @RequestMapping(value = "getPointList",method = RequestMethod.GET)
    @ResponseBody
    public BaseResp getDbVal(){ 
   
        Map<String,String> resultMap = lmdbOperation.getAllValueByDbName(LmdbNameEnum.PointStatus.getDbName());
        return BaseResp.success("成功",resultMap);
    }

}

测试结果:

插入值:
在这里插入图片描述
获取值:
在这里插入图片描述
在这里插入图片描述
配置文件中定义的lmdb数据路径:
在这里插入图片描述

资源补全:(相关的公共方法类)

BaseResp.java(接口统一返回封装类)


import java.util.List;

import com.jack.framework.json.JsonMsgUtil;
import com.fasterxml.jackson.annotation.JsonView;

import lombok.Data;
import lombok.experimental.Accessors;

/** * @Description: 基础返回类 * @date 2018年5月21日 下午9:28:00 */
@Data
@Accessors(chain = true)
public class BaseResp { 
   

	public interface DefaultJsonView { 
   
	};

	@JsonView(DefaultJsonView.class)
	private boolean rs;

	@JsonView(DefaultJsonView.class)
	private int code;

	@JsonView(DefaultJsonView.class)
	private String msg;

	@JsonView(DefaultJsonView.class)
	private Object data;

	@JsonView(DefaultJsonView.class)
	private List<?> datas;

	public BaseResp() { 
   
		this(0);
	}

	public BaseResp(int code) { 
   
		this.code = code;
	}

	public BaseResp(int code, String msg) { 
   
		this.code = code;
		this.msg = msg;
	}

	public String getMsg() { 
   
		if (msg == null) { 
   
			this.msg = JsonMsgUtil.getMsg(code);
		}
		if (this.msg == "") { 
   
			this.msg = JsonMsgUtil.getMsg(9999);
		}
		return msg;
	}

	public boolean getRs() { 
   
		rs = code == 0;
		return rs;
	}

	public boolean isRs() { 
   
		rs = code == 0;
		return rs;
	}

	public static boolean isSuccess(BaseResp resp) { 
   
		return resp.isRs();
	}

	/** * 功能描述:请求成功 * @param filePath */
	public static BaseResp success(String msg) { 
   
		BaseResp r = new BaseResp(0);
		r.setMsg(msg);
		return r;
	}
	//
	public static BaseResp success(String msg, Object data) { 
   
		BaseResp r = new BaseResp(0);
		r.setMsg(msg);
		r.setData(data);
		return r;
	}
	public static BaseResp success(String msg, List<?> datas) { 
   
		BaseResp r = new BaseResp(0);
		r.setMsg(msg);
		r.setDatas(datas);
		return r;
	}
	/** * 功能描述:参数出错 */
	public static BaseResp paramsError(String msg) { 
   
		BaseResp r = new BaseResp(100);
		r.setMsg(msg);
		return r;
	}

	/** * 功能描述:验证出错 */
	public static BaseResp validError(String msg) { 
   
		BaseResp r = new BaseResp(101);
		r.setMsg(msg);
		return r;
	}

	/** * 功能描述:逻辑判断出错 */
	public static BaseResp logicError(String msg) { 
   
		BaseResp r = new BaseResp(102);
		r.setMsg(msg);
		return r;
	}

	/** * 功能描述:未登录 */
	public static BaseResp invalidLogin(String url) { 
   
		BaseResp r = new BaseResp(9888);
		r.data = url;
		return r;
	}

	/** * 功能描述:无权限 */
	public static BaseResp invalidPerms(String msg) { 
   
		BaseResp r = new BaseResp(9889);
		r.setMsg(msg);
		return r;
	}

}

JsonMsgUtil.java(获取.properties文件属性的工具类)

package com.jack.framework.json;

import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.util.Properties;

import org.springframework.core.io.support.PathMatchingResourcePatternResolver;
import org.springframework.core.io.support.PropertiesLoaderUtils;

import lombok.extern.slf4j.Slf4j;

/** * 功能说明:资源工具类 */
@Slf4j
public final class JsonMsgUtil { 
   

	private static Properties propertie = new Properties();

	private static String DEFAULT_MESSAGE = "";

	static { 
   
		try { 
   
			propertie = PropertiesLoaderUtils.loadProperties(new PathMatchingResourcePatternResolver().getResource("classpath:conf/json-msg.properties"));
		} catch (IOException e1) { 
   
			String s = "Load resource file failed.";
			log.error(s);
		}
	}

	public static String getMsg(String key) { 
   
		String message = propertie.getProperty(key, DEFAULT_MESSAGE);
		try { 
   
			message = new String(message.getBytes("UTF-8"), "UTF-8");
		} catch (UnsupportedEncodingException e) { 
   
			e.printStackTrace();
			return DEFAULT_MESSAGE;
		}
		return message;
	}

	public static String getMsg(int key) { 
   
		String message = propertie.getProperty("" + key, DEFAULT_MESSAGE);
		try { 
   
			message = new String(message.getBytes("UTF-8"), "UTF-8");
		} catch (UnsupportedEncodingException e) { 
   
			e.printStackTrace();
			return DEFAULT_MESSAGE;
		}
		return message;
	}

}

json-msg.properties(定义系统的统一返回码)
通常中文需要转成Unicode格式

##################
#JSON MSG
#返回码规划如下
#100 --默认参数异常
#1XXX --通用错误异常
#2XXX --业务模块异常
#3XXX --API模块异常

#8XXX --管理模块异常
#9XXX --系统异常
##################

##########################正常############################
0=成功

##########################业务模块异常############################
#2X0X--业务通用模块
2001=文件上传失败
2002=业务参数异常
2003=你无权操作

##########################API模块异常############################
3999=时间戳错误
3998=随机码错误
3997=签名错误

3000=未登录或已失效,请重新登录

##########################系统异常############################
9400=无效请求
9404=非法请求
9405=方法不被允许
9406=无法接受
9415=不支持的媒体类型
9500=执行异常

9900=运行时异常
9901=空值异常
9902=数据类型转换异常
9903=IO异常
9904=未知方法异常
9905=数组越界异常

9888=未登录或已失效,请重新登录
9889=权限不足

9997=Json格式错误
9998=数据格式错误
9999=系统异常

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/189014.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 人员能力提升方案_优秀的网站通过什么提供信息

    人员能力提升方案_优秀的网站通过什么提供信息在软件行当也混了有4个年头了,刚毕业那会,觉得百度好强大,工作过程中遇到的问题都能从中查到解决方案。随着能力的提升,对于百度的定位:“其就是用来找些低俗的内容而已”。毕业第一年刚进公司,师傅还总因为我用百度而责骂我,不过那个时候真的不懂他的意思,总觉得他很苛刻,用什么你都管。有的时候甚至觉得他很讨厌,跟了他一年只是学会了Google的入门而已,授人以鱼,不如授之以渔,时隔几年才真真的体会到,他真的…

    2022年10月4日
    2
  • Python 根据AIC准则定义向前逐步回归进行变量筛选(二)

    Python 根据AIC准则定义向前逐步回归进行变量筛选(二)Python根据AIC准则定义向前逐步回归进行变量筛选(二)AIC简介AIC即赤池值,是衡量模型拟合优良性和模型复杂性的一种标准,在建立多元线性回归模型时,变量过多,且有不显著的变量时,可以使用AIC准则结合逐步回归进行变量筛选。AICD数学表达式如下:AIC=2p+n(log(SSE/n))AIC=2p+n(log(SSE/n))AIC=2p+n(log(SSE/n))其中,ppp…

    2022年5月24日
    182
  • 空白符号在线复制_html里空格怎么表示

    空白符号在线复制_html里空格怎么表示空格网名符号复制以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!空格网名符号复制搜狗输入法,v+1在按下d就是空格:这里空格【】这里还有一个空格:[]弄了,在游戏里就是空白名空格符号复制法一:搜狗输入法将半角转换全角,快捷键(Shift+空格键),按空格(根据:半角空格为1字节,全角为2字节)法二:搜狗输…

    2022年9月15日
    4
  • Java工具开发手记

    Java工具开发手记前言这段时间沉迷于工具开发方面,个人也比较倾向于gui的工具。使用在开发过程中避免的就是gui的一些框体,这里主要用于记录一些关键点。工具开发其实在前段时间编写的14882

    2021年12月13日
    43
  • 使用playbook安装nginx和mysql

    使用playbook安装nginx和mysql

    2021年5月31日
    133
  • Clipboard.js_js复制文本代码

    Clipboard.js_js复制文本代码Clipboard.js实现文本复制或者剪切到剪切板引用js文件使用一使用二使用三

    2022年8月4日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号