数据分片 概念: 按特定方式拆分,分散存放到多个数据库服务器上,达到负载效果 垂直分割:单个表切换成多个表,按业务类别分散到不同数据库. 水平分割:将表里的多条记录切分到不同数据库.
搭建数据分片服务器 MyCAT
基于JAVA的分布式 适合大量写入数据的存储需求 分片 高可用集群 读写分离 都可以使用MYCAT 支持MYSQL Oracle Sqlserver Mongodb
分片规则: 枚举法 固定分片 范围约定 求模法 日期列分区法 通配取模 ASCII码求模通配 编程指定 字符串拆分hash 一致性hash Mycat软件介绍: 工作过程图一 工作过程图二
一、配置mycat环境
拓扑结构、
IP规划
二、开始搭建mycat分片服务器(56操作)
步骤一:公共配置 1)关闭防火墙和selinux,配置yum源(系统源),这里不再操作 2)把53,54,55还原成独立数据库服务器,56主机下载mycat 软件包 需要的软件包:Mycat-server-1.6 这个软包需要三台数据库服务器
56]# tar -zxvf Mycat-server-1.6-linux.tar.gz
56]# mv mycat/ /usr/local
56 ]# cd /usr/local/mycat/
56 mycat]# ls
bin catlet conf lib logs version.txt
配置文件 修改配置文件图一 3)在53(主机)54(主机)和55(主机)上面创建db3、db2、db1库和授权一个用户。
53]# mysql -u root [email protected]
mysql> create database db3;
Query OK, 1 row affected (0.00 sec)
mysql> grant all on * . * to roota@"%" identified by "[email protected] ";
52]# mysql -u root [email protected]
mysql> create database db2;
Query OK, 1 row affected (0.00 sec)
mysql> grant all on * . * to roota@"%" identified by "[email protected] ";
51]# mysql -u root [email protected]
mysql> create database db1;
Query OK, 1 row affected (0.00 sec)
mysql> grant all on * . * to roota@"%" identified by "[email protected] ";
4)修改数据库的配置文件(53、54、55) 注意:1代表不区分表名的大小写,0为区分大小写 主机c1上面:
53]# vim /etc/my.cnf
[mysqld]
lower_case_table_names=1 //表名忽视大小写
53]# systemctl restart mysqld
54]# vim /etc/my.cnf
[mysqld]
lower_case_table_names=1 //表名忽视大小写
54]# systemctl restart mysqld
55]# vim /etc/my.cnf
[mysqld]
lower_case_table_names=1 //表名忽视大小写
55]# systemctl restart mysqld
5)在56主机上面安装JDK和mycat
56]# rpm -qa | grep -i jdk //安装自带的即可 java-1.8.0-openjdk-1.8.0.131-11.b12.el7.x86_64 java-1.8.0-openjdk-headless-1.8.0.131-11.b12.el7.x86_64 copy-jdk-configs-2.2-3.el7.noarch 56]# yum -y install java-1.8.0-openjdk 56]# cd mysql/ 56mysql]# tar -xf Mycat-server-1.4-beta-20150604171601-linux.tar.gz //免安装,解压即可使用 56mysql]# mv mycat/ /usr/local/ 56mysql]# ls /usr/local/mycat/ bin catlet conf lib logs version.txt 56mysql]# cd /usr/local/mycat/ 56mycat]# ./bin/mycat --help Usage: ./bin/mycat { console | start | stop | restart | status | dump } 修改配置文件图二 (图片上的修改仅供查看,不做修改) 修改配置文件图三 (图片上的修改仅供查看,不做修改) 修改配置文件图四 (图片上的修改仅供查看,不做修改)
修改配置文件图五 (图片上的修改仅供查看,不做修改) 6)56主机上修改配置文件。
56]# cd /usr/local/mycat/conf
56conf]# vim schema.xml
7 //dataNode="dn1,dn2,dn3"代表数据库,有几个数据库就写几个dn....。
8
9 //dataNode="dn1,dn2,dn3"代表数据库,有几个数据库就写几个dn....。
10 //dataNode="dn1,dn2,dn3"代表数据库,有几个数据库就写几个dn....。
12 //dataNode="dn1,dn2,dn3"代表数据库,有几个数据库就写几个dn....。
14 //dataNode="dn1,dn2,dn3"代表数据库,有几个数据库就写几个
16 //dataNode="dn1,dn2,dn3"代表数据库,有几个数据库就写几个
..........
.........
27 //在53创建的数据库
28 //在54创建的数据库
29 //在55创建的数据库
//代表一个数据库服务器
31
33 select user()
34 //数据库服务器的IP、端口、用户、密码
36
37
38
39 // name="localhost54"代表主机54,只是一个标识。
41 select user()
42
44
45
46
47 // name="localhost55"代表主机53,只是一个标识。
49 select user()
50 //数据库的IP、用户、密码
52
53
7)添加PATH路径(可不用)
56 conf]# export PATH=/usr/local/mycat/bin:$PATH
56 conf]# echo "PATH=/usr/local/mycat/bin:$PATH" >> /etc/profile
56 conf]# source /etc/profile
56 conf]# echo $PATH
/usr/local/mycat/bin:/usr/local/mycat/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin
56 conf]# which mycat
/usr/local/mycat/bin/mycat
8)启动服务并查看端口
56 conf]# /usr/local/mycat/bin/mycat start
Starting Mycat-server...
56 conf]# netstat -antup | grep :8066
tcp6 0 0 :::8066 :::* LISTEN 6421/java
[root@mycat conf]# ps -C java
PID TTY TIME CMD
6421 ? 00:00:04 java
9)客户端验证:
客户端50连接分片服务器访问数据
50]# mysql -h192.168.4.56 -P8066 -u root -p123456;
mysql> show databases;
mysql> use testdb;
mysql> create table employee(
> ID int primary key auto_increment,
> sharding_id int,
> name char(30),
> age int);
mysql> desc employee;
mysql> insert into employee(sharding_id,name,age) values(10000,"bob",19); //插入的数据库存储在53
mysql> insert into employee(sharding_id,name,age) values(10010,"fanny",19); //插入的数据库存储在54
select * from employee;
10)修改56主机分片规则配置文件,让数据库可以分片存储到服务55里 56]# /usr/local/mycat/bin/mysqlcat stop 56]# vim /usr/local/mycat/conf/partition-hash-int.txt 10000=0 10010=1 10020=2
partition-hash-int.txt //设置分片规则的配置文件,规则为枚举算法。 枚举类型算法: 10000=0 //代表数据存储在数据服务器53 10010=1 //代表数据存储在数据服务器54 10020=2 //代表数据存储在数据服务器55
56]# /usr/local/mycat/bin/mysqlcat start
56]# ss -unptl | grep 8066
50]# mysql -h192.168.4.56 -P8066 -u root -p123456
mysql> create table company(ID int primary key auto_increment,name char(30));
Query OK, 0 rows affected (0.77 sec)
mysql> desc company;
+-------+----------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-------+----------+------+-----+---------+----------------+
| ID | int(11) | NO | PRI | NULL | auto_increment |
| name | char(30) | YES | | NULL | |
+-------+----------+------+-----+---------+----------------+
55 ~]# mysql -u root [email protected]
mysql> use db1;
Database changed
mysql> show tables;
+---------------+
| Tables_in_db1 |
+---------------+
| company |
| employee |
+---------------+
2 rows in set (0.00 sec)
53 ~]# mysql -u root [email protected]
mysql> use db2;
Database changed
mysql> show tables;
+---------------+
| Tables_in_db2 |
+---------------+
| company |
| employee |
+---------------+
2 rows in set (0.00 sec)55 ~]# mysql -u root [email protected]
mysql> use db3;
Database changed
mysql> show tables;
+---------------+
| Tables_in_db3 |
+---------------+
| company |
| employee |
+---------------+
2 rows in set (0.00 sec)
11)创建表指定余数存储到数据库服务器
56]# mysql -h192.168.4.56 -u root -p123456
mysql> create table hotnews(id int,name char(30));
Query OK, 0 rows affected (0.98 sec)
mysql> insert into hotnews(id,name) values(10,"qq"),(8,"oo"),(12,"uu");
Query OK, 3 rows affected (0.37 sec)
55]# mysql -u root [email protected]
mysql> show tables;
+---------------+
| Tables_in_db1 |
+---------------+
| company |
| employee |
| employee02 |
| hotnews |
+---------------+
4 rows in set (0.00 sec)
mysql> select * from hotnews;
+------+------+
| id | name |
+------+------+
| 8 | oo |
+------+------+
1 row in set (0.00 sec)
54]# mysql -u root [email protected]
mysql> show tables;
+---------------+
| Tables_in_db2 |
+---------------+
| company |
| employee |
+---------------+
2 rows in set (0.00 sec)
mysql> select * from hotnews; ±-----±-----+ | id | name | ±-----±-----+ | 10 | qq | ±-----±-----+ 1 row in set (0.00 sec) 53]# mysql -u root [email protected] mysql> show tables; ±--------------+ | Tables_in_db3 | ±--------------+ | company | | employee | ±--------------+ 2 rows in set (0.00 sec)
mysql> select * from hotnews; ±-----±-----+ | id | name | ±-----±-----+ | 12 | uu | ±-----±-----+ 1 row in set (0.00 sec)
你可能感兴趣的:(MySQL数据库知识集,搭建mycat分片服务器)
SSM 构建个性化商铺系统:功能亮点聚焦商业成功
2402_85758349
后端 java
第二章开发技术与环境配置以Java语言为开发工具,利用了当前先进的SSM框架技术,以MyEclipse10为系统开发工具,MySQL为后台数据库,开发的一个个性化商铺系统。2.1微信开发者工具在传统web浏览器中,在加载htm15页面时先加载视图层的html和css,后加载逻辑层的javascript,然后返回数据并在浏览器中展示页面。而微信开发者工具的系统层是基于NativeSystem的,视图
汽车蓝牙钥匙定位仿真小程序
程序员石磊
基于深度学习的室内定位 室内定位 蓝牙钥匙 蓝牙钥匙定位
此需求来自于粉丝的真实需求,假期没事,牛刀小试。一、项目背景如今,智能车钥匙和移动端定位技术已经相当普及。为了探索蓝牙Beacon在短距离定位场景下的可行性,我们搭建了一个简易原型:利用UniApp在移动端采集蓝牙信标的RSSI(信号强度),通过三边定位算法估算钥匙在车内或车周围的坐标,并使用FastAPI+Redis实现数据存储与可视化接口,最后在Leaflet地图中模拟车辆俯视效果,实时展示定
lxc与docker的区别
xihuaodc
docker linux
Docker不是lxc的一个替代方案。“lxc”是指linux内核(尤指命名空间以及Cgroup)的一个特性,它允许其他一些沙盒进程运行在一块相对独立的空间,并且能够方便的控制他们的资源调度。而基于底层的内核特性的基础上,Docker在上层构建了一个更高层次的具备多个强大功能的工具集:可移植的跨机器部署。Docker定义了一个将应用打包的规范,而它的所有依赖都被封装到了一个简单对象里,它可以被传输
DeepSeek R1本地化部署与联网功能实战指南:从零搭建智能对话系统
Coderabo
python DeepSeek R1
前言在人工智能技术快速发展的今天,如何将先进的对话模型DeepSeekR1部署到本地环境并赋予其联网能力,成为许多开发者和企业关注的重点。本文将深入讲解完整的本地化部署流程,并通过实例代码演示如何为模型添加实时网络访问功能。一、环境准备与基础架构1.1硬件需求推荐配置:NVIDIAGPU(RTX3090或更高)+32GB内存+50GB存储空间最低配置:CPU(支持AVX2指令集)+16GB内存+3
团体程序设计天梯赛-练习集——L1-028 判断素数
SY师弟
GPLT天梯赛 算法 c语言 数据结构 c++ GPLT c#
前言一道10分的题目,相对来说比较简单,思考的时候要仔细且活跃,有时候在写代码的时候一些代码的出现很多余,并且会影响最后的结果L1-028判断素数本题的目标很简单,就是判断一个给定的正整数是否素数。输入格式:输入在第一行给出一个正整数N(≤10),随后N行,每行给出一个小于231次方的需要判断的正整数。输出格式:对每个需要判断的正整数,如果它是素数,则在一行中输出Yes,否则输出No。输入样例:2
Prometheus+grafana+alertmanager告警平台搭建
zhangshaohuas
prometheus
目录一:基本组件理解二:告警平台架构图三:prometheus部署3.1:创建用户3.2:下载安装包3.3:解压3.4:设置prometheus.yml3.5:将prometheus设置为系统服务3.6:启动prometheus服务四:node_exporter部署4.1:下载安装包:4.2:解压4.3:将node_exporter设置为系统服务4.4:启动node_exporter服务五:gra
【转摘】域名服务器配置学习笔记
weixin_30725467
数据库 嵌入式 运维
括看相关的rfc文件,一看和dns相关的rfc文件,妈呀,居然有86个之多。能看多少是多少吧。先把DNS的原理研究透彻了。在看rfc文件我想会事半功倍的:)1.ICANN是干什么的?和他的一些相关资讯?ICANN全称是叫:InternetCorporationforAssignedNamesandNumbers(互联网名称与数字地址分配机构),是一个非盈利性的国际组织,负责互联网协议(IP)地址的
Spring Boot构建mvc项目
贾斯汀玛尔斯
Java spring boot mvc 后端
好的,以下是一个简单的JavaMVC(Model-View-Controller)项目示例,使用SpringBoot框架和MySQL数据库。这个项目包括基本的CRUD操作。项目结构src/└──main/├──java/│└──com/│└──example/│└──demo/│├──DemoApplication.java│├──controller/││└──UserController.ja
QTcpSocket 如何统计在线时长
我喜欢就喜欢
C++ 技术文档 QT 数据库 服务器 网络
基本原理QTcpSocket是Qt库中用于TCP通信的类。要统计在线时长,关键思路是记录连接建立的时间和当前时间,通过计算两者的差值来得到在线时长。实现步骤记录连接建立时间:在连接成功的信号槽函数中记录开始时间。例如,当QTcpSocket成功连接到服务器时,会发出connected()信号。可以在对应的槽函数中使用QDateTime类来记录连接时间。示例代码如下:收起cpp#include#in
实战 | Docker+Jmeter+InfluxDB+Grafana 搭建性能监控平台
测试小迷糊
压力测试
1.为什么要搭建性能监控平台?本身带有聚合报告如下图所示:这个报告有几个很明显的缺点::中获取数据并以特定的模板进行展示2、性能监控平台部署实践本文的重点并不是介绍Docker,所以不了解的小伙伴需要自己去学习一下基本的安装和操作,可参考之前发送的。1)首先去下载InfluxDB的镜像,下载很简单,直接pull就好,默认为下载最新的镜像:$dockerpullinfluxdb镜像,在访问8083端
CDH_6.3.2的搭建
我的K8409
Flink linux 大数据 分布式
一站式搭建大数据的应用1、前提条件和准备工作hostnamectlset-hostnamecdh01hostnamectlset-hostnamecdh02hostnamectlset-hostnamecdh032、修改IP和Host映射关系(所有节点)在window中也配置一下vim/etc/hosts192.168.92.201cdh01192.168.92.202cdh02192.168.9
nginx安全配置
凉生ㄨ゛゛记忆﹎ゝ
nginx 安全 chrome
一、基础安全配置隐藏版本号信息默认情况下,Nginx会在响应头中显示版本号,这可能会给攻击者提供服务器信息。攻击者可以根据版本号查找对应版本的已知漏洞进行定向攻击。http{#关闭在响应头中显示Nginx版本号#默认响应头:Server:nginx/1.18.0#关闭后响应头:Server:nginxserver_tokensoff;}配置安全Headers添加安全相关的HTTP响应头,可以有效防
Nginx 日志分析与监控
计算机毕设定制辅导-无忧学长
# Nginx nginx 运维
引言在当今互联网时代,Web服务的稳定运行和高效性能是至关重要的。Nginx作为一款高性能的HTTP和反向代理服务器,以其出色的稳定性、高效性和丰富的功能,被广泛应用于各类Web项目中,成为了Web服务架构中不可或缺的一部分。无论是大型互联网公司的高并发网站,还是小型企业的业务系统,Nginx都能发挥其强大的作用,承担着处理大量并发请求、实现负载均衡、保障服务稳定等重要任务。而Nginx日志,就像
mysqlclient MacOS 使用报错 NameError: name ‘_mysql’ is not defined
流浮生
日常填坑 python django mysql
背景最近使用django作为一个服务的后台,在使用mysqlclient链接mysql数据库时发生一个奇怪的报错NameError:name‘_mysql’isnotdefined下面是具体报错信息INFO]2021-04-0702:27:57,613WatchingforfilechangeswithStatReloaderExceptioninthreaddjango-main-thread:
Nginx与Web安全:遵循OWASP最佳实践
墨夶
Nginx学习资料1 nginx web安全 hibernate
在当今数字化时代,网络安全已成为企业不可忽视的重要环节。Web应用程序面临着各种威胁,包括SQL注入、跨站脚本攻击(XSS)、跨站请求伪造(CSRF)等。Nginx作为高性能的HTTP和反向代理服务器,提供了丰富的功能来增强Web应用的安全性。结合OpenWebApplicationSecurityProject(OWASP)的最佳实践,可以有效提升Web应用的安全防护水平。本文将详细介绍如何使用
如何搭建产品架构
Fadeland
架构 产品运营 媒体 大数据 学习
产品架构究竟是什么?就像人的骨架都是一节一节组成,同样,在产品中也有许多构成元素,然而我们现在需要分析的产品架构就是去分析各种功能元素之间的关系,这些元素混合在一起才能构成一个完整的产品模型。而用户将会直接去接触搭建好的产品模型,这里模型的难易程度将直接性的影响用户的认可度。产品架构,最考验PM的判断力和设计能力。产品架构中有什么?其实产品架构可以参考用户体验五要素,将产品争对所面向的用户拆分为五
innodb_file_per_table
weixin_34203426
数据库
MySQLInnoDB引擎默认会将所有的数据库InnoDB引擎的表数据存储在一个共享空间中:ibdata1,当增删数据库的时候,ibdata1文件不会自动收缩,单个数据库的备份也将成为问题。通常只能将数据使用mysqldump导出,然后再导入解决这个问题。在MySQL的配置文件[mysqld]部分,增加innodb_file_per_table参数,可以修改InnoDB为独立表空间模式,每个数据库
MySQL Innodb Engine --独立表空间参数(innodb_file_per_table)
第八个猴子
运维 数据库
MySQL中参数innodb_file_per_table决定将表存放于ibdata*的共享表空间还是独立的.ibd文件的独立表空间。==================================共享表空间方式:所有数据和索引都存放在共享表空间中,默认存放在MySQL的data目录下。优点:可以为共享表空间配置多个数据文件,多个数据文件可以存放到不同磁盘上,将单表数据分布到多个磁盘上。缺点:
MySQL 参数- Innodb_File_Per_Table(独立表空间)
csdn_life18
数据库#mysql mysql oracle 数据库
Innodb存储引擎可将所有数据存放于ibdata*的共享表空间,也可将每张表存放于独立的.ibd文件的独立表空间。共享表空间以及独立表空间都是针对数据的存储方式而言的。共享表空间某一个数据库的所有的表数据,索引文件全部放在一个文件中,默认这个共享表空间的文件路径在data目录下。默认的文件名为:ibdata1初始化为10M。优点:可以将表空间分成多个文件存放到各个磁盘上(表空间文件大小不受表大小
使用Ollama本地化部署DeepSeek
大模型llm人工智能
1、Ollama简介Ollama是一个开源的本地化大模型部署工具,旨在简化大型语言模型(LLM)的安装、运行和管理。它支持多种模型架构,并提供与OpenAI兼容的API接口,适合开发者和企业快速搭建私有化AI服务。Ollama的主要特点包括:轻量化部署:支持在本地设备上运行模型,无需依赖云端服务。多模型支持:兼容多种开源模型,如LLaMA、DeepSeek等。高效管理:提供命令行工具,方便用户下载
如何区分MongoDB和关系型数据库?思维导图 代码示例(java 架构)
用心去追梦
数据库 mongodb java
MongoDB和关系型数据库(RDBMS,如MySQL、PostgreSQL)是两种不同类型的数据库管理系统,它们在数据模型、查询语言、扩展性和性能等方面存在显著差异。理解这些差异有助于选择适合特定应用场景的数据库类型。以下是关于如何区分MongoDB和关系型数据库的详细指南:区分MongoDB和关系型数据库数据模型MongoDB:文档模型:使用BSON格式存储数据,每个记录都是一个自描述的文档,
rust如何操作sqlserver
扎量丙不要犟
sqlserver 数据库 rust tiberius
rust中操作mysql和pgsql的技术非常多,也很成熟。但是操作mssql的办法,确实不多。作为一个sqlserver多年的使用者,我总不能用rust之后,就放弃mssql吧。我尝试了一下,我们国人开发的rbatis,rbatis是支持mssql的。但是很遗憾,我使用的是兼容win7的rust1.77.2这个版本,rbatis在这个环境并没有跑起来。我找到了tiberius,这个库是可以用的。
vscode用ssh连接服务器后,明明内存还很富足,为什么却很卡顿
炸毛小怪
把bug打倒 vscode ssh 服务器 c语言 算法 硬件架构
vscode用ssh连接服务器后,明明内存还很富足,为什么却很卡顿前言一、判断是否是服务器上其他用户同时在执行实验1、执行free命令查看内存占用情况2、额外的发现3、解决二、附加:buffer/cache和swap的先后顺序三、个人总结reference前言 这两天由于需要跑实验,数据集比较大,因此我在vscode上通过ssh连接上我们实验室的服务器(两张A100的配置)开启我的实验之路。可是
如何在本地电脑上安装和使用 DeepSeek R-1
知识大胖
NVIDIA GPU和大语言模型开发教程 电脑
简介似乎每个人都在谈论DeepSeekR-1是中国人工智能公司DeepSeek开发的全新开源人工智能语言模型。一些用户声称,其推理能力与OpenAI的o1相当,甚至更好。目前,DeepSeek是免费使用的,这对用户来说是个好消息,但也带来了一些疑问。随着用户量的激增,他们如何管理服务器成本?硬件运行成本不可能便宜吧?这里最合乎逻辑的一点是——数据。数据是人工智能模型的命脉。他们可能以某种方式收集用
使用WebSocket、MySQL、Go语言的Gin框架和GORM库来实现一个用户实时统计大屏概览
云梦优选
Go websocket mysql golang
为了使用WebSocket、MySQL、Go的Gin框架和GORM实现用户实时统计大屏概览,以下是分步指南:1.项目结构与依赖1.1初始化项目mkdirrealtime-dashboard&&cdrealtime-dashboardgomodinitrealtime-dashboard1.2安装依赖goget-ugithub.com/gin-gonic/gingoget-ugorm.io/gorm
Ubuntu全面卸载mysql
张3蜂
ubuntu mysql adb
如果你已经看到whereismysql输出了与MySQL相关的路径,说明MySQL仍然存在于系统中。要卸载MySQL,可以按照以下步骤操作,确保完全删除所有相关的文件和配置:1.停止MySQL服务首先,停止MySQL服务:sudosystemctlstopmysql2.卸载MySQL包卸载MySQL的所有相关包。你可以使用purge命令来卸载MySQL并删除配置文件:sudoapt-getpurg
前端网页开发学习(HTML+CSS+JS)有这一篇就够!
软件技术NINI
html/css笔记 前端 学习 html
前端网页开发是一个不断发展的领域,涉及到构建和设计网站以及Web应用程序的用户界面。以下是一份全面的学习指南,涵盖HTML、CSS和JavaScript的基础知识,帮助你入门前端开发。HTML(超文本标记语言)1.基础结构文档类型和标签:定义了文档类型和根元素。htmlDocument标签:包含元数据,如字符集、标题和链接到CSS文件。标签:包含网页的可见内容。2.常用标签文本内容:<h
PyTorch中的unsqueeze函数(自用)
黯岚岚岚岚岚
pytorch pytorch python 经验分享
前言最近在学习swin_transformer的模型搭建,其中用到了广播机制,在理解广播机制的过程中发现自己对torch.unsqueeze()函数比较困惑,所以做了个小实验帮助自己理解。问题阐述我们都知道,torch.unsqueeze()函数的作用是拓展张量维度,那么在不同位置拓展之后,原数据是怎样排列的呢?下面进入实验部分。实验>>>importtorch>>>>>>a=torch.Tens
keepalived 各模式设置
伏虎山真人
运维 运维 linux 服务器 keep 负载均衡
在MySQL和相关的高可用性解决方案中,“trackscript”通常与Keepalived等高可用软件一起使用,用于监控特定服务的状态。以下是对“trackscript”的详细解释:一、定义与功能定义:“trackscript”是Keepalived等高可用软件中用于定义跟踪监控脚本的配置项。功能:通过指定一个脚本文件,Keepalived可以定期执行该脚本来检查某个服务的状态(如MySQL服务
集合论导引:广义无界闭子集与荟萃子集
AI天才研究院
大数据AI人工智能 ChatGPT java python javascript kotlin golang 架构 人工智能 大厂程序员 硅基计算 碳基计算 认知计算 生物计算 深度学习 神经网络 大数据 AIGC AGI LLM 系统架构设计 软件哲学 Agent 程序员实现财富自由
《集合论导引:广义无界闭子集与荟萃子集》关键词集合论,广义无界闭子集,荟萃子集,拓扑学,度量空间,函数空间摘要本文旨在为读者提供一部关于集合论中广义无界闭子集与荟萃子集的导引。文章首先回顾了集合论的基础知识,包括集合的定义、运算、子集、超集以及可数集与不可数集等。在此基础上,文章深入探讨了集合的基数与连续统假设,并介绍了集合的公理系统。接着,文章转向广义无界闭子集和荟萃子集的基本概念、性质及应用,
开发者关心的那些事
圣子足道
ios 游戏 编程 apple 支付
我要在app里添加IAP,必须要注册自己的产品标识符(product identifiers)。产品标识符是什么?
产品标识符(Product Identifiers)是一串字符串,它用来识别你在应用内贩卖的每件商品。App Store用产品标识符来检索产品信息,标识符只能包含大小写字母(A-Z)、数字(0-9)、下划线(-)、以及圆点(.)。你可以任意排列这些元素,但我们建议你创建标识符时使用
负载均衡器技术Nginx和F5的优缺点对比
bijian1013
nginx F5
对于数据流量过大的网络中,往往单一设备无法承担,需要多台设备进行数据分流,而负载均衡器就是用来将数据分流到多台设备的一个转发器。
目前有许多不同的负载均衡技术用以满足不同的应用需求,如软/硬件负载均衡、本地/全局负载均衡、更高
LeetCode[Math] - #9 Palindrome Number
Cwind
java Algorithm 题解 LeetCode Math
原题链接:#9 Palindrome Number
要求:
判断一个整数是否是回文数,不要使用额外的存储空间
难度:简单
分析:
题目限制不允许使用额外的存储空间应指不允许使用O(n)的内存空间,O(1)的内存用于存储中间结果是可以接受的。于是考虑将该整型数反转,然后与原数字进行比较。
注:没有看到有关负数是否可以是回文数的明确结论,例如
画图板的基本实现
15700786134
画图板
要实现画图板的基本功能,除了在qq登陆界面中用到的组件和方法外,还需要添加鼠标监听器,和接口实现。
首先,需要显示一个JFrame界面:
public class DrameFrame extends JFrame { //显示
linux的ps命令
被触发
linux
Linux中的ps命令是Process Status的缩写。ps命令用来列出系统中当前运行的那些进程。ps命令列出的是当前那些进程的快照,就是执行ps命令的那个时刻的那些进程,如果想要动态的显示进程信息,就可以使用top命令。
要对进程进行监测和控制,首先必须要了解当前进程的情况,也就是需要查看当前进程,而 ps 命令就是最基本同时也是非常强大的进程查看命令。使用该命令可以确定有哪些进程正在运行
Android 音乐播放器 下一曲 连续跳几首歌
肆无忌惮_
android
最近在写安卓音乐播放器的时候遇到个问题。在MediaPlayer播放结束时会回调
player.setOnCompletionListener(new OnCompletionListener() {
@Override
public void onCompletion(MediaPlayer mp) {
mp.reset();
Log.i("H
java导出txt文件的例子
知了ing
java servlet
代码很简单就一个servlet,如下:
package com.eastcom.servlet;
import java.io.BufferedOutputStream;
import java.io.IOException;
import java.net.URLEncoder;
import java.sql.Connection;
import java.sql.Resu
Scala stack试玩, 提高第三方依赖下载速度
矮蛋蛋
scala sbt
原文地址:
http://segmentfault.com/a/1190000002894524
sbt下载速度实在是惨不忍睹, 需要做些配置优化
下载typesafe离线包, 保存为ivy本地库
wget http://downloads.typesafe.com/typesafe-activator/1.3.4/typesafe-activator-1.3.4.zip
解压r
phantomjs安装(linux,附带环境变量设置) ,以及casperjs安装。
alleni123
linux spider
1. 首先从官网
http://phantomjs.org/下载phantomjs压缩包,解压缩到/root/phantomjs文件夹。
2. 安装依赖
sudo yum install fontconfig freetype libfreetype.so.6 libfontconfig.so.1 libstdc++.so.6
3. 配置环境变量
vi /etc/profil
JAVA IO FileInputStream和FileOutputStream,字节流的打包输出
百合不是茶
java核心思想 JAVA IO操作 字节流
在程序设计语言中,数据的保存是基本,如果某程序语言不能保存数据那么该语言是不可能存在的,JAVA是当今最流行的面向对象设计语言之一,在保存数据中也有自己独特的一面,字节流和字符流
1,字节流是由字节构成的,字符流是由字符构成的 字节流和字符流都是继承的InputStream和OutPutStream ,java中两种最基本的就是字节流和字符流
类 FileInputStream
Spring基础实例(依赖注入和控制反转)
bijian1013
spring
前提条件:在http://www.springsource.org/download网站上下载Spring框架,并将spring.jar、log4j-1.2.15.jar、commons-logging.jar加载至工程1.武器接口
package com.bijian.spring.base3;
public interface Weapon {
void kil
HR看重的十大技能
bijian1013
提升 能力 HR 成长
一个人掌握何种技能取决于他的兴趣、能力和聪明程度,也取决于他所能支配的资源以及制定的事业目标,拥有过硬技能的人有更多的工作机会。但是,由于经济发展前景不确定,掌握对你的事业有所帮助的技能显得尤为重要。以下是最受雇主欢迎的十种技能。 一、解决问题的能力 每天,我们都要在生活和工作中解决一些综合性的问题。那些能够发现问题、解决问题并迅速作出有效决
【Thrift一】Thrift编译安装
bit1129
thrift
什么是Thrift
The Apache Thrift software framework, for scalable cross-language services development, combines a software stack with a code generation engine to build services that work efficiently and s
【Avro三】Hadoop MapReduce读写Avro文件
bit1129
mapreduce
Avro是Doug Cutting(此人绝对是神一般的存在)牵头开发的。 开发之初就是围绕着完善Hadoop生态系统的数据处理而开展的(使用Avro作为Hadoop MapReduce需要处理数据序列化和反序列化的场景),因此Hadoop MapReduce集成Avro也就是自然而然的事情。
这个例子是一个简单的Hadoop MapReduce读取Avro格式的源文件进行计数统计,然后将计算结果
nginx定制500,502,503,504页面
ronin47
nginx 错误显示
server {
listen 80;
error_page 500/500.html;
error_page 502/502.html;
error_page 503/503.html;
error_page 504/504.html;
location /test {return502;}}
配置很简单,和配
java-1.二叉查找树转为双向链表
bylijinnan
二叉查找树
import java.util.ArrayList;
import java.util.List;
public class BSTreeToLinkedList {
/*
把二元查找树转变成排序的双向链表
题目:
输入一棵二元查找树,将该二元查找树转换成一个排序的双向链表。
要求不能创建任何新的结点,只调整指针的指向。
10
/ \
6 14
/ \
Netty源码学习-HTTP-tunnel
bylijinnan
java netty
Netty关于HTTP tunnel的说明:
http://docs.jboss.org/netty/3.2/api/org/jboss/netty/channel/socket/http/package-summary.html#package_description
这个说明有点太简略了
一个完整的例子在这里:
https://github.com/bylijinnan
JSONUtil.serialize(map)和JSON.toJSONString(map)的区别
coder_xpf
jquery json map val()
JSONUtil.serialize(map)和JSON.toJSONString(map)的区别
数据库查询出来的map有一个字段为空
通过System.out.println()输出 JSONUtil.serialize(map): {"one":"1","two":"nul
Hibernate缓存总结
cuishikuan
开源 ssh javaweb hibernate缓存 三大框架
一、为什么要用Hibernate缓存?
Hibernate是一个持久层框架,经常访问物理数据库。
为了降低应用程序对物理数据源访问的频次,从而提高应用程序的运行性能。
缓存内的数据是对物理数据源中的数据的复制,应用程序在运行时从缓存读写数据,在特定的时刻或事件会同步缓存和物理数据源的数据。
二、Hibernate缓存原理是怎样的?
Hibernate缓存包括两大类:Hib
CentOs6
dalan_123
centos
首先su - 切换到root下面1、首先要先安装GCC GCC-C++ Openssl等以来模块:yum -y install make gcc gcc-c++ kernel-devel m4 ncurses-devel openssl-devel2、再安装ncurses模块yum -y install ncurses-develyum install ncurses-devel3、下载Erang
10款用 jquery 实现滚动条至页面底端自动加载数据效果
dcj3sjt126com
JavaScript
无限滚动自动翻页可以说是web2.0时代的一项堪称伟大的技术,它让我们在浏览页面的时候只需要把滚动条拉到网页底部就能自动显示下一页的结果,改变了一直以来只能通过点击下一页来翻页这种常规做法。
无限滚动自动翻页技术的鼻祖是微博的先驱:推特(twitter),后来必应图片搜索、谷歌图片搜索、google reader、箱包批发网等纷纷抄袭了这一项技术,于是靠滚动浏览器滚动条
ImageButton去边框&Button或者ImageButton的背景透明
dcj3sjt126com
imagebutton
在ImageButton中载入图片后,很多人会觉得有图片周围的白边会影响到美观,其实解决这个问题有两种方法
一种方法是将ImageButton的背景改为所需要的图片。如:android:background="@drawable/XXX"
第二种方法就是将ImageButton背景改为透明,这个方法更常用
在XML里;
<ImageBut
JSP之c:foreach
eksliang
jsp forearch
原文出自:http://www.cnblogs.com/draem0507/archive/2012/09/24/2699745.html
<c:forEach>标签用于通用数据循环,它有以下属性 属 性 描 述 是否必须 缺省值 items 进行循环的项目 否 无 begin 开始条件 否 0 end 结束条件 否 集合中的最后一个项目 step 步长 否 1
Android实现主动连接蓝牙耳机
gqdy365
android
在Android程序中可以实现自动扫描蓝牙、配对蓝牙、建立数据通道。蓝牙分不同类型,这篇文字只讨论如何与蓝牙耳机连接。
大致可以分三步:
一、扫描蓝牙设备:
1、注册并监听广播:
BluetoothAdapter.ACTION_DISCOVERY_STARTED
BluetoothDevice.ACTION_FOUND
BluetoothAdapter.ACTION_DIS
android学习轨迹之四:org.json.JSONException: No value for
hyz301
json
org.json.JSONException: No value for items
在JSON解析中会遇到一种错误,很常见的错误
06-21 12:19:08.714 2098-2127/com.jikexueyuan.secret I/System.out﹕ Result:{"status":1,"page":1,&
干货分享:从零开始学编程 系列汇总
justjavac
编程
程序员总爱重新发明轮子,于是做了要给轮子汇总。
从零开始写个编译器吧系列 (知乎专栏)
从零开始写一个简单的操作系统 (伯乐在线)
从零开始写JavaScript框架 (图灵社区)
从零开始写jQuery框架 (蓝色理想 )
从零开始nodejs系列文章 (粉丝日志)
从零开始编写网络游戏 
jquery-autocomplete 使用手册
macroli
jquery Ajax 脚本
jquery-autocomplete学习
一、用前必备
官方网站:http://bassistance.de/jquery-plugins/jquery-plugin-autocomplete/
当前版本:1.1
需要JQuery版本:1.2.6
二、使用
<script src="./jquery-1.3.2.js" type="text/ja
PLSQL-Developer或者Navicat等工具连接远程oracle数据库的详细配置以及数据库编码的修改
超声波
oracle plsql
在服务器上将Oracle安装好之后接下来要做的就是通过本地机器来远程连接服务器端的oracle数据库,常用的客户端连接工具就是PLSQL-Developer或者Navicat这些工具了。刚开始也是各种报错,什么TNS:no listener;TNS:lost connection;TNS:target hosts...花了一天的时间终于让PLSQL-Developer和Navicat等这些客户
数据仓库数据模型之:极限存储--历史拉链表
superlxw1234
极限存储 数据仓库 数据模型 拉链历史表
在数据仓库的数据模型设计过程中,经常会遇到这样的需求:
1. 数据量比较大; 2. 表中的部分字段会被update,如用户的地址,产品的描述信息,订单的状态等等; 3. 需要查看某一个时间点或者时间段的历史快照信息,比如,查看某一个订单在历史某一个时间点的状态, 比如,查看某一个用户在过去某一段时间内,更新过几次等等; 4. 变化的比例和频率不是很大,比如,总共有10
10点睛Spring MVC4.1-全局异常处理
wiselyman
spring mvc
10.1 全局异常处理
使用@ControllerAdvice注解来实现全局异常处理;
使用@ControllerAdvice的属性缩小处理范围
10.2 演示
演示控制器
package com.wisely.web;
import org.springframework.stereotype.Controller;
import org.spring