Categories
java mysql

mycat 实例

mycat配置解释

再mycat2/conf/有配置文件

server.xml 定义数据库连接 用户

schema.xml 定义 虚拟表和实体表

rule.xml 定义分库逻辑(入库)

route.xml定义查询时实体表路由配置(查询)

简单按字段值分库
<!-- 按照学校名分表 -->
	<tableRule name="shardingBySchoolName">
		<rule>
			<columns>school_name</columns>
			<algorithm>shardingBySchoolName</algorithm>
		</rule>
	</tableRule>
<!-- 按照学校名分表 -->
	<function name="shardingBySchoolName" class="org.opencloudb.route.function.PartitionByFileMap">
		<property name="mapFile">shardingBySchoolName.txt</property>
		<property name="type">1</property>
		<property name="defaultNode">0</property>
	</function>

shardingBySchoolName.txt

爱享=0
中悦=1
DEFAULT_NODE=1
Categories
java

elasticsearch

Categories
java

docker tomcat

静态资源目录在 /usr/local/tomcat/webapps

配置文件在 /usr/local/tomcat/conf/server.xml

Categories
java

apache httpd

Apache(音译为阿帕奇)是世界使用排名第一的Web服务器软件。它可以运行在几乎所有广泛使用的计算机平台上,由于其跨平台和安全性被广泛使用,是最流行的Web服务器端软件之一。它快速、可靠并且可通过简单的API扩充,将Perl/Python解释器编译到服务器中

服务器根目录在/usr/local/apache2/htdocs

Categories
java

jetty

Jetty 是一个开源的servlet容器,它为基于Java的web容器,例如JSP和servlet提供运行环境。Jetty是使用Java语言编写的,它的API以一组JAR包的形式发布。开发人员可以将Jetty容器实例化成一个对象,可以迅速为一些独立运行(stand-alone)的Java应用提供网络和web连接。

默认的静态资源文件夹 在/var/lib/jetty/webapps/下

添加默认根context:在/var/lib/jetty/webapps/下添加ROOT文件夹

然后在ROOT文件夹添加index.html

即可提供默认主页访问

当然也可把war包放到webapps下自动解压访问

Categories
java

spring-boot 配置文件

启动sprongboot jar 包时 有几个地方会读取配置

一是启动参数

二是启动目录下的application.yaml

三是jar包内部的application.yaml

所以其实一个jar包可以把基本功能设置

通过把配置文件 置于启动目录下 可完成运行前修改配置功能

java -jar common-server.jar –spring.config.local=application.properties

也可以通过 –spring.config.local 指定配置文件

Categories
java

Jenkins

jenkins 是一个服务端服务持续集成的框架,用于管理项目部署脚本。

最简单的安装方法下载 jenkins war包到本地 通过 java -jar 部署 因其内部自带netty http 服务 用网站进入jenkins 进行项目管理

 java -jar jenkins.war --httpPort=8280 

在端口8280启动jenkins服务

Categories
java

xxl-job

国内的可集群 任务调度

程序内部分为两部分

admin 管理控制台

executor 调度执行器

通过管理控制台 向系统提交任务 和绑定到对应的执行器

执行器在安排的时间内执行任务

Categories
java

Elastic job

分布式调度应用

elasticjob-lite-core 分布式调度应用核心代码

基于ZooKeeper 作为调度中心

Categories
java

身份证判断逻辑


// 定义判别用户身份证号的正则表达式(15位或者18位,最后一位可以为字母)
String regularExpression = "(^[1-9]\\d{5}(18|19|20)\\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\\d{3}[0-9Xx]$)|" +
"(^[1-9]\\d{5}\\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\\d{3}$)";
//假设18位身份证号码:41000119910101123X 410001 19910101 123X
//^开头
//[1-9] 第一位1-9中的一个 4
//\\d{5} 五位数字 10001(前六位省市县地区)
//(18|19|20) 19(现阶段可能取值范围18xx-20xx年)
//\\d{2} 91(年份)
//((0[1-9])|(10|11|12)) 01(月份)
//(([0-2][1-9])|10|20|30|31)01(日期)
//\\d{3} 三位数字 123(第十七位奇数代表男,偶数代表女)
//[0-9Xx] 0123456789Xx其中的一个 X(第十八位为校验值)
//$结尾

//假设15位身份证号码:410001910101123 410001 910101 123
//^开头
//[1-9] 第一位1-9中的一个 4
//\\d{5} 五位数字 10001(前六位省市县地区)
//\\d{2} 91(年份)
//((0[1-9])|(10|11|12)) 01(月份)
//(([0-2][1-9])|10|20|30|31)01(日期)
//\\d{3} 三位数字 123(第十五位奇数代表男,偶数代表女),15位身份证不含X
//$结尾


boolean matches = IDNumber.matches(regularExpression);

//判断第18位校验值
if (matches) {

if (IDNumber.length() == 18) {
try {
char[] charArray = IDNumber.toCharArray();
//前十七位加权因子
int[] idCardWi = {7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2};
//这是除以11后,可能产生的11位余数对应的验证码
String[] idCardY = {"1", "0", "X", "9", "8", "7", "6", "5", "4", "3", "2"};
int sum = 0;
for (int i = 0; i < idCardWi.length; i++) {
int current = Integer.parseInt(String.valueOf(charArray[i]));
int count = current * idCardWi[i];
sum += count;
}
char idCardLast = charArray[17];
int idCardMod = sum % 11;
if (idCardY[idCardMod].toUpperCase().equals(String.valueOf(idCardLast).toUpperCase())) {
return true;
} else {
return false;
}

} catch (Exception e) {
logger.error("身份证校验异常,{}", e.getMessage());
return false;
}
}

}

return matches;