- DPVS_dpvs: DPVS架构图 介绍 DPVS是基于DPDK的高性能第4层负载均衡器
weixin_39878247
DPVS
DPVSIntroductionDPVSisahighperformanceLayer-4loadbalancerbasedonDPDK.It'sderivedfromLinuxLVSandit'smodificationalibaba/LVS.thenameDPVScomesfrom"DPDK-LVS".Differenttechniquesareappliedforhighperformanc
- DPVS_dpvs学习笔记: 2 启动流程
熊勒个猫
DPVS
整个工程量其实不大,截止到现在dpvs代码量只有不到2w行,相当轻量级了,和当年redis开源时体量相当。整体架构先看架构图,对外交互层controlplane比较像lvs,不会陌生。LoadBalancer模块根据lvs翻译而来,支持大家常用的几种转发模式。和lvs差别最大的地方就是,dpvs自己实现了轻量级的tcp协义栈,并且在用户层模拟了网卡,就是最下面的NetDevices层。为什么要自己
- DPVS 多活部署架构部署
码农心语
高性能架构dpvs多活集群部署高性能
一、目标利用DPVS部署一个基于OSPF/ECMP的提供HTTP服务的多活高可用的测试环境。本次部署仅用于验证功能,不提供性能验证。配置两台DPVS组成集群、两台REALSERVER提供实际HTTP服务。注:在虚拟环境里面,通过在一台虚拟服务器上面安装FRRouting来模拟支持OSPF的路由器。二、组网架构和keepalived模式这五种方案。以下的配置全部基于双臂模式,并且RS机器上面已经安装了DPVS相应的toa模块。我们先从单个网卡的IPv4简单配置开始,接着再做bonding配置,然后再进行IPv6简单配置
- c语言arp路由链表,dpvs学习笔记: 9 arp和路由
weixin_39631899
c语言arp路由链表
相对于传统网卡,net_dev在内核层,而dpvs在用户层抽像了一个网卡。所以相应的,arp和路由也要有,又因为是dpdk程序,每个核尽可能不和其它核交互,所以就需要在核之间广播,这是大前提。arp和路由的作用网络方面菜鸟,更专业的建义看其它分享~~数据包流入网卡时,协义栈先看mac地址是否是本机,是的话向上层传递,不是丢弃或转发。三层ip拿到数据包后,判断ip是否是本机,做同样操作。数据包写到协
- DPVS-FullNAT模式部署篇
tinychen
本文主要介绍在CentOS7.9系统上部署DPVS的FullNAT模式和在RealServer上安装toa模块获取客户端的真实IP。此前的文章已经介绍过DPVS简介与部署以及DPDK在DPVS中的应用及原理分析,有需要的同学可以先补一下相关的内容。由于之前的文章中的部署步骤只介绍到了DPVS的部署,并没有涉及相关的各种负载均衡模式的配置,以及时间过去大半年之后,DPVS的版本和对应的DPDK版本都
- dpdk入门实践6——L2fwd二层通信和l3fwd三层通信
lingshengxiyou
DPDKlinuxc++linux网络网络编程开发语言虚拟机
DPDK从网卡直接取数据到用户空间,需要有数据转发的规则才能通信。也就是说需要用户实现相关通信网络协议实现相关数据包的转发(有些协议栈不转发ICMP报文那就Ping不通),例如腾讯的fstack,爱奇艺的DPVS等。这里仅以简单的2层和3层通信实例。l2fwdSample运行./build/l2fwd-l0-3-n4---q8-p0x03或者./build/l2fwd-cf---p0x03--no
- dpdk/spdk/网络协议栈/存储/网关开发/网络安全/虚拟化/ 0vS/TRex/dpvs技术专家成长体系教程
攻城狮百里
DPDK网络协议网络
课程围绕安全,网络,存储,云原生4个维度去讲解核心技术点。6个专栏组成:dpdk网络专栏、存储技术专栏、安全与网关开发专栏、虚拟化与云原生专栏、测试工具专栏、性能测试专栏一、dpdk网络dpdk基础知识多队列网卡,vmxnet/e1000igb_uio与vfio模块kni模块hugepage的理解零拷贝dpdk与netmap区别dpdk的工作环境网络协议栈dpdk-arp.netsh静态arp表设
- DPVS-FullNAT模式keepalived篇
tinychen
本文主要介绍基于CentOS7.9系统部署DPVS的FullNAT模式在使用keepalived进行主备模式配置高可用集群在线上生产环境落地实践时遇到的一些问题和处理的思路。文中所有IP地址、主机名、MAC地址信息均已进行脱敏或魔改处理,客户端IP使用模拟器生成,但不影响阅读体验。1、keepalived架构1.1单机架构图为了方便理解我们可以把上面的架构图分为DPVS网络栈、Linux网络栈、R
- Android ARP
greatwgb
网络协议
linux内核学习笔记------ARP:地址解析协议ARP报文抓包解析学习ARP协议具体解释之GratuitousARP(免费ARP)arping命令解析Linux邻居协议学习笔记之七arp数据包处理流程高性能负载均衡DPVS邻居子系统的实现wifi概率性自动断线(IpReachabilityMonitor)虚拟IP原理ipv4上叫做ARP,ipv6改名NeighborDiscovery:net
- 武汉之行--2020/9/3-2020/09/06
较劲儿
2020/9/3-2020/9/6四天的武汉训练营结营之行马上就结束了,利用三周的时间完成的DPVS项目也顺利汇报答疑,这次项目虽然还有很多不足,但是也算给自己有了个交代,毕竟从头到尾的所有任务都积极参与其中,请教了很多牛人,学习到很多知识,深深的感受到自己的浅薄,也更加深刻的体会到一个好的团队的重要性。小米的技术氛围与文化氛围都是我喜欢的样子,会好好努力疯狂吸取知识,希望多年后回想起来,也能觉得
- dpvs学习笔记: 1 初探
董泽润
提起负载均衡设备,程序员基本都打过交道。硬件的比如F5、netscaler,以前在赶集网就用netscaler,后来过保也没续...软件的有lvs、haproxy,当然了七层的nginx也算。关于转发模式也知道一些dr、nat、tunnel等等,轮循的算法有rr、wrr、wlc等等。但是内部原理除了网络同学,大部分同学只是简单的使用,借着这次调研dpdk机会,读读源码,一勺烩了。背景现代互联网流量
- dpvs学习笔记: 9 arp和路由
董泽润
相对于传统网卡,net_dev在内核层,而dpvs在用户层抽像了一个网卡。所以相应的,arp和路由也要有,又因为是dpdk程序,每个核尽可能不和其它核交互,所以就需要在核之间广播,这是大前提。arp和路由的作用网络方面菜鸟,更专业的建义看其它分享~~数据包流入网卡时,协义栈先看mac地址是否是本机,是的话向上层传递,不是丢弃或转发。三层ip拿到数据包后,判断ip是否是本机,做同样操作。数据包写到协
- dpdk/spdk/网络协议栈/存储/网关开发/网络安全/虚拟化/ 0vS/TRex/dpvs技术成长体系
攻城狮百里
DPDK网络协议DPDKOvS网络
作为近年来运用越来越广泛,被互联网企业越来越认可的技术,网络虚拟化技术:dpdk/spdk/网络协议栈/存储/网关开发/网络安全/虚拟化/0vS/TRex/dpvs技术等该如何学习呢?这里就把相关技术点进行整理总结,看完以后,不会让你失望的。DPDK网络DPDK基础知识多队列网卡,vmxnet/e1000igb_uio与vfio模块kni模块hugepage的理解零拷贝dpdk与netmap区别d
- DPVS-FullNAT模式管理篇
tinychen777
负载均衡网络linux运维lvs负载均衡
本文主要介绍基于CentOS7.9系统部署DPVS的FullNAT模式的各种部署方式和配置管理,包括IPv4-IPv4、bonding、IPv6-IPv6、IPv6-IPv4(NAT64)和keepalived模式这五种方案。以下的配置全部基于双臂模式,并且RS机器上面已经安装了DPVS相应的toa模块。我们先从单个网卡的IPv4简单配置开始,接着再做bonding配置,然后再进行IPv6简单配置
- 在虚拟机编译运行dpvs
分享放大价值
安装依赖库aptinstalllibnuma-devapt-getinstalllibpopt-dev编译dpvs#编译dpdk./scripts/dpdk-build.sh#编译dpvsexportPKG_CONFIG_PATH=/root/dpvs/dpdk/dpdklib/lib/x86_64-linux-gnu/pkgconfigmake#编译后,dpvs在src下,dpip在tools/
- DPVS源码分析之启动过程
铉清
本文用于分析dpvs的启动流程,会对主要逻辑进行解析,忽略了一些边缘代码,比如配置文件解析,函数指针的注册等等。在阅读主逻辑的时候,如果有疑问的地方,再去看一些配置相关,初始化相关的代码。这样不仅高效而且不会那么枯燥。被忽略的代码将在本文中用...代替。从main函数开始在src/mian.c文件中,main函数还是比较清晰的。首先是初始->然后启动端口->然后启动工作线程->主线程进入循环。in
- dpvs学习笔记: 6 定时器实现及连接老化超时
董泽润
定时器实现方式很多种,定时器个数也不同。比如go老版本只有一个全局定时器,所以有些高性能项目抛弃了,自己实现用户级别的定时器,并且开启n个。但是在新版本没必要了,默认64个。dpvs由于流表可能巨大,并且处在不同状态的tcp连接超时时间还不一样,如果实现的低效,会非常影响性能。所以dpvs在利用dpdk定时器的基础上,自实现了一个,算法是常见的时间轮。数据结构structtimer_schedul
- dpvs学习笔记: 2 启动流程
董泽润
整个工程量其实不大,截止到现在dpvs代码量只有不到2w行,相当轻量级了,和当年redis开源时体量相当。整体架构先看架构图,对外交互层controlplane比较像lvs,不会陌生。LoadBalancer模块根据lvs翻译而来,支持大家常用的几种转发模式。和lvs差别最大的地方就是,dpvs自己实现了轻量级的tcp协义栈,并且在用户层模拟了网卡,就是最下面的NetDevices层。为什么要自己
- dpvs学习笔记: 3 转发模式 dr 完整流程
董泽润
以前做DBA时,常用DR模式。LB只处理进入的请求,将流量分发给后端,返回数据由RealServer直接返回到Client,所以模式叫DirectRouting.原理大家都清楚,修改二层头mac地址,所以他的局限也很明显,只能在同一个二层,不能跨网段。由于直接返回给Client,一般不会面对公网用户。那么具体实现细节呢?dr转发入口上一篇提到,dpvs每个slave核心处于轮循状态,执行三个LOO
- dpvs学习笔记: 4 nat 完整流程
董泽润
Nat用途很广,家里的宽带就是这种模式,将局域网的私有地址转换成公网地址。没有dr二层的限制,但是nat也有缺点,需要配置路由或是指定为realserver的网关,同时也会有性能扩展问题。nat模式对于进入的流量,实际上做的是dnat,将目标ip由lbip换成真正的rsip,此时后端rs是能拿到clientip的。返回的流量做snat,将源地址换成lbip.三层处理ipv4_rcv数据接收和上文都
- dpvs netif ip mac地址管理
圣骐
dpvsdpvs
dpvs代码中ip,mac,netif的数据结构存储如下:该结构有下列优点:根据netifname快速找到ip地址根据netifid快速找到ip地址根据ip快速找到所属netif接口根据ip快速找到所属netif及相关信息如mac…
- dpvs中ARP协议
ss_chris
dpvs源码阅读笔记
arp_initneigh_tableper-lcore,hash桶初始化注册ARP协议的pkt_type,用于处理接收的arp数据包注册loop任务neigh_process_ring,arp数据包会通过ring广播到所有的lcore,取出其中的arp数据包处理staticintarp_init(void){inti,j;interr;//初始化neigh_table哈希表,每个lcore维护自
- dpvs中fdir与sa_pool介绍
ss_chris
dpvs源码阅读笔记
问题引入dpvs是dpdk程序,特点就是每个核尽可能不与其他核交互,这就要求共享数据都有一份拷贝,或是数据私有。fnat模式中流表(session)保存连接信息,每个核独有。但这里有个问题,full-nat模式下,返程数据outboundpacket也必须分配到与inboundpacket收取的同一个lcore,否则在流表中找不到conndpvs解决方案引入fdir机制lcore上lip都是同步一
- dpvs persistent调度
ss_chris
ipvsadmin配置命令,开启persistent选项之后,ipvs将来自同一个客户端的请求全部调度到一个固定的RS服务器上。对于SSL和FTP这类,其多个报文之间是相互关联的协议,需要开启此类功能。但是对于NAT转发模式,由于NAT将对端口号进行修改,FTP服务需要使用ip_vs_ftp模块才能正常工作命令行选项netmask默认为255.255.255.255,仅对同一个客户端进行持续调度。
- dpvs conn超时处理
ss_chris
dpvs源码阅读笔记
连接定时器处理函数设置超时处理函数为dp_vs_conn_expire设置priv为当前connstaticvoiddp_vs_conn_attach_timer(structdp_vs_conn*conn,boollock){intrc;//如果conn->timer正在运行中,则直接返回if(dp_vs_conn_is_in_timer(conn)){return;}//如果为长连接,则将定时
- dpvs安装
weixin_40318438
linux
dpvs是爱奇艺基于dpdk做的lvs的二次开发,性能更由于lvs下载dpvsgitclonehttps://github.com/iqiyi/dpvs.git进入到dpvs目录安装dpdk,dpvs官方建议最好把dpdk放在dpvs目录中下载链接https://fast.dpdk.org/rel/dpdk-17.11.2.tar.xztardpdk-17.11.2.tar.xz在ubuntu下安
- DPVS DR模式处理流程
智智方
DR模式的原理通过上篇笔记已经了解的比较透彻了,只不过是用的LVS来模拟进行抓包分析的,但是DR模式的原理是一样的,所以先跟着DPVS的源码了解一下DPVS实现DR模式的流程(这次分析主要跟着DR模式的处理流程走,会跳过其他的处理流程)。先跳过DPVS的启动流程,从main函数的netif_lcore_start()函数开始分析,从这个函数开始DPVS的收发过程就开始启动,这个函数内容如下intn
- dpvs 连接会话老化处理逻辑
懒少
前提知识储备,dpdk定时器:http://blog.csdn.net/linzhaolover/article/details/9410529rte_get_timer_hz()获得CPU主频(1s多少个cycle)cursors的本意是游标,我用滴答取代吧。dpvs代码分析:1、核线程配置相关文件:dpvs配置文件dpvs.confdpvs设计沿用了dpdk对每个cpu核线程的操作,每个cpu
- dpvs源代码分析——master和slave之间通信
codergeek
小胖我在阅读dpvs源代码的过程中,发现很多模块调用msg_type_mc_register函数或msg_type_register函数来注册dpvs_msg_type结构体,结构体定义如下:/*unicastonlyneedsUNICAST_MSG_CB,*whilemulticastneedbothUNICAST_MSG_CBandMULTICAST_MSG_CB.*Asformulitcas
- mondb入手
木zi_鸣
mongodb
windows 启动mongodb 编写bat文件,
mongod --dbpath D:\software\MongoDBDATA
mongod --help 查询各种配置
配置在mongob
打开批处理,即可启动,27017原生端口,shell操作监控端口 扩展28017,web端操作端口
启动配置文件配置,
数据更灵活 
- 大型高并发高负载网站的系统架构
bijian1013
高并发负载均衡
扩展Web应用程序
一.概念
简单的来说,如果一个系统可扩展,那么你可以通过扩展来提供系统的性能。这代表着系统能够容纳更高的负载、更大的数据集,并且系统是可维护的。扩展和语言、某项具体的技术都是无关的。扩展可以分为两种:
1.
- DISPLAY变量和xhost(原创)
czmmiao
display
DISPLAY
在Linux/Unix类操作系统上, DISPLAY用来设置将图形显示到何处. 直接登陆图形界面或者登陆命令行界面后使用startx启动图形, DISPLAY环境变量将自动设置为:0:0, 此时可以打开终端, 输出图形程序的名称(比如xclock)来启动程序, 图形将显示在本地窗口上, 在终端上输入printenv查看当前环境变量, 输出结果中有如下内容:DISPLAY=:0.0
- 获取B/S客户端IP
周凡杨
java编程jspWeb浏览器
最近想写个B/S架构的聊天系统,因为以前做过C/S架构的QQ聊天系统,所以对于Socket通信编程只是一个巩固。对于C/S架构的聊天系统,由于存在客户端Java应用,所以直接在代码中获取客户端的IP,应用的方法为:
String ip = InetAddress.getLocalHost().getHostAddress();
然而对于WEB
- 浅谈类和对象
朱辉辉33
编程
类是对一类事物的总称,对象是描述一个物体的特征,类是对象的抽象。简单来说,类是抽象的,不占用内存,对象是具体的,
占用存储空间。
类是由属性和方法构成的,基本格式是public class 类名{
//定义属性
private/public 数据类型 属性名;
//定义方法
publ
- android activity与viewpager+fragment的生命周期问题
肆无忌惮_
viewpager
有一个Activity里面是ViewPager,ViewPager里面放了两个Fragment。
第一次进入这个Activity。开启了服务,并在onResume方法中绑定服务后,对Service进行了一定的初始化,其中调用了Fragment中的一个属性。
super.onResume();
bindService(intent, conn, BIND_AUTO_CREATE);
- base64Encode对图片进行编码
843977358
base64图片encoder
/**
* 对图片进行base64encoder编码
*
* @author mrZhang
* @param path
* @return
*/
public static String encodeImage(String path) {
BASE64Encoder encoder = null;
byte[] b = null;
I
- Request Header简介
aigo
servlet
当一个客户端(通常是浏览器)向Web服务器发送一个请求是,它要发送一个请求的命令行,一般是GET或POST命令,当发送POST命令时,它还必须向服务器发送一个叫“Content-Length”的请求头(Request Header) 用以指明请求数据的长度,除了Content-Length之外,它还可以向服务器发送其它一些Headers,如:
- HttpClient4.3 创建SSL协议的HttpClient对象
alleni123
httpclient爬虫ssl
public class HttpClientUtils
{
public static CloseableHttpClient createSSLClientDefault(CookieStore cookies){
SSLContext sslContext=null;
try
{
sslContext=new SSLContextBuilder().l
- java取反 -右移-左移-无符号右移的探讨
百合不是茶
位运算符 位移
取反:
在二进制中第一位,1表示符数,0表示正数
byte a = -1;
原码:10000001
反码:11111110
补码:11111111
//异或: 00000000
byte b = -2;
原码:10000010
反码:11111101
补码:11111110
//异或: 00000001
- java多线程join的作用与用法
bijian1013
java多线程
对于JAVA的join,JDK 是这样说的:join public final void join (long millis )throws InterruptedException Waits at most millis milliseconds for this thread to die. A timeout of 0 means t
- Java发送http请求(get 与post方法请求)
bijian1013
javaspring
PostRequest.java
package com.bijian.study;
import java.io.BufferedReader;
import java.io.DataOutputStream;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.HttpURL
- 【Struts2二】struts.xml中package下的action配置项默认值
bit1129
struts.xml
在第一部份,定义了struts.xml文件,如下所示:
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
"http://struts.apache.org/dtds/struts
- 【Kafka十三】Kafka Simple Consumer
bit1129
simple
代码中关于Host和Port是割裂开的,这会导致单机环境下的伪分布式Kafka集群环境下,这个例子没法运行。
实际情况是需要将host和port绑定到一起,
package kafka.examples.lowlevel;
import kafka.api.FetchRequest;
import kafka.api.FetchRequestBuilder;
impo
- nodejs学习api
ronin47
nodejs api
NodeJS基础 什么是NodeJS
JS是脚本语言,脚本语言都需要一个解析器才能运行。对于写在HTML页面里的JS,浏览器充当了解析器的角色。而对于需要独立运行的JS,NodeJS就是一个解析器。
每一种解析器都是一个运行环境,不但允许JS定义各种数据结构,进行各种计算,还允许JS使用运行环境提供的内置对象和方法做一些事情。例如运行在浏览器中的JS的用途是操作DOM,浏览器就提供了docum
- java-64.寻找第N个丑数
bylijinnan
java
public class UglyNumber {
/**
* 64.查找第N个丑数
具体思路可参考 [url] http://zhedahht.blog.163.com/blog/static/2541117420094245366965/[/url]
*
题目:我们把只包含因子
2、3和5的数称作丑数(Ugly Number)。例如6、8都是丑数,但14
- 二维数组(矩阵)对角线输出
bylijinnan
二维数组
/**
二维数组 对角线输出 两个方向
例如对于数组:
{ 1, 2, 3, 4 },
{ 5, 6, 7, 8 },
{ 9, 10, 11, 12 },
{ 13, 14, 15, 16 },
slash方向输出:
1
5 2
9 6 3
13 10 7 4
14 11 8
15 12
16
backslash输出:
4
3
- [JWFD开源工作流设计]工作流跳跃模式开发关键点(今日更新)
comsci
工作流
既然是做开源软件的,我们的宗旨就是给大家分享设计和代码,那么现在我就用很简单扼要的语言来透露这个跳跃模式的设计原理
大家如果用过JWFD的ARC-自动运行控制器,或者看过代码,应该知道在ARC算法模块中有一个函数叫做SAN(),这个函数就是ARC的核心控制器,要实现跳跃模式,在SAN函数中一定要对LN链表数据结构进行操作,首先写一段代码,把
- redis常见使用
cuityang
redis常见使用
redis 通常被认为是一个数据结构服务器,主要是因为其有着丰富的数据结构 strings、map、 list、sets、 sorted sets
引入jar包 jedis-2.1.0.jar (本文下方提供下载)
package redistest;
import redis.clients.jedis.Jedis;
public class Listtest
- 配置多个redis
dalan_123
redis
配置多个redis客户端
<?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi=&quo
- attrib命令
dcj3sjt126com
attr
attrib指令用于修改文件的属性.文件的常见属性有:只读.存档.隐藏和系统.
只读属性是指文件只可以做读的操作.不能对文件进行写的操作.就是文件的写保护.
存档属性是用来标记文件改动的.即在上一次备份后文件有所改动.一些备份软件在备份的时候会只去备份带有存档属性的文件.
- Yii使用公共函数
dcj3sjt126com
yii
在网站项目中,没必要把公用的函数写成一个工具类,有时候面向过程其实更方便。 在入口文件index.php里添加 require_once('protected/function.php'); 即可对其引用,成为公用的函数集合。 function.php如下:
<?php /** * This is the shortcut to D
- linux 系统资源的查看(free、uname、uptime、netstat)
eksliang
netstatlinux unamelinux uptimelinux free
linux 系统资源的查看
转载请出自出处:http://eksliang.iteye.com/blog/2167081
http://eksliang.iteye.com 一、free查看内存的使用情况
语法如下:
free [-b][-k][-m][-g] [-t]
参数含义
-b:直接输入free时,显示的单位是kb我们可以使用b(bytes),m
- JAVA的位操作符
greemranqq
位运算JAVA位移<<>>>
最近几种进制,加上各种位操作符,发现都比较模糊,不能完全掌握,这里就再熟悉熟悉。
1.按位操作符 :
按位操作符是用来操作基本数据类型中的单个bit,即二进制位,会对两个参数执行布尔代数运算,获得结果。
与(&)运算:
1&1 = 1, 1&0 = 0, 0&0 &
- Web前段学习网站
ihuning
Web
Web前段学习网站
菜鸟学习:http://www.w3cschool.cc/
JQuery中文网:http://www.jquerycn.cn/
内存溢出:http://outofmemory.cn/#csdn.blog
http://www.icoolxue.com/
http://www.jikexue
- 强强联合:FluxBB 作者加盟 Flarum
justjavac
r
原文:FluxBB Joins Forces With Flarum作者:Toby Zerner译文:强强联合:FluxBB 作者加盟 Flarum译者:justjavac
FluxBB 是一个快速、轻量级论坛软件,它的开发者是一名德国的 PHP 天才 Franz Liedke。FluxBB 的下一个版本(2.0)将被完全重写,并已经开发了一段时间。FluxBB 看起来非常有前途的,
- java统计在线人数(session存储信息的)
macroli
javaWeb
这篇日志是我写的第三次了 前两次都发布失败!郁闷极了!
由于在web开发中常常用到这一部分所以在此记录一下,呵呵,就到备忘录了!
我对于登录信息时使用session存储的,所以我这里是通过实现HttpSessionAttributeListener这个接口完成的。
1、实现接口类,在web.xml文件中配置监听类,从而可以使该类完成其工作。
public class Ses
- bootstrp carousel初体验 快速构建图片播放
qiaolevip
每天进步一点点学习永无止境bootstrap纵观千象
img{
border: 1px solid white;
box-shadow: 2px 2px 12px #333;
_width: expression(this.width > 600 ? "600px" : this.width + "px");
_height: expression(this.width &
- SparkSQL读取HBase数据,通过自定义外部数据源
superlxw1234
sparksparksqlsparksql读取hbasesparksql外部数据源
关键字:SparkSQL读取HBase、SparkSQL自定义外部数据源
前面文章介绍了SparSQL通过Hive操作HBase表。
SparkSQL从1.2开始支持自定义外部数据源(External DataSource),这样就可以通过API接口来实现自己的外部数据源。这里基于Spark1.4.0,简单介绍SparkSQL自定义外部数据源,访
- Spring Boot 1.3.0.M1发布
wiselyman
spring boot
Spring Boot 1.3.0.M1于6.12日发布,现在可以从Spring milestone repository下载。这个版本是基于Spring Framework 4.2.0.RC1,并在Spring Boot 1.2之上提供了大量的新特性improvements and new features。主要包含以下:
1.提供一个新的sprin