- Kafka Controller 元数据解析与故障恢复实战指南
磐基Stack专业服务团队
Kafkakafkalinq分布式
#作者:张桐瑞文章目录1生产案例:Controller选举在故障恢复中的关键作用1.1问题背景1.2核心操作原理:2Controller元数据全景:从ZooKeeper到内存的数据镜像2.1元数据核心载体:ControllerContext类2.2核心元数据深度解析1生产案例:Controller选举在故障恢复中的关键作用1.1问题背景某Kafka集群部分核心主题分区一直处于“不可用”状态,通过k
- Zookeeper异常ConnectionLossException: KeeperErrorCode = ConnectionLoss for / 问题解决大全
takmehand
Javajavazookeeper
zookeeper报ConnectionLossException:KeeperErrorCode=ConnectionLossfor异常我的开发环境是Windows开发zookeeper客户端程序,zookeeper集群安装在本地虚拟机上centos7经过自己踩坑和查找博客,发现报此异常有三种原因一是:zookeeper服务没有启动,这是最low的错误二是:centos防火墙未关闭,导致连接不上
- 【Note】《Kafka: The Definitive Guide》 第二章 Installing Kafka:Kafka 安装与运行
《Kafka:TheDefinitiveGuide》第二章InstallingKafka:Kafka安装与运行本章核心目标是教读者如何在本地搭建Kafka,包括依赖安装、启动服务、测试运行等操作。一、Kafka的依赖与基本结构1.Kafka的核心组成Kafka并不是一个单独运行的进程,它依赖以下两个核心组件:组件作用ZooKeeperKafka用于存储元数据(如broker注册信息、control
- 利用已有的 PostgreSQL 和 ZooKeeper 服务,启动dolphinscheduler-standalone-server3.1.9 镜像
云游
大数据平台zookeeperdockerpostgresql工作流任务调度
ApacheDolphinScheduler是一个分布式易扩展的可视化DAG工作流任务调度开源系统。适用于企业级场景,提供了一个可视化操作任务、工作流和全生命周期数据处理过程的解决方案。ApacheDolphinScheduler旨在解决复杂的大数据任务依赖关系,并为应用程序提供数据和各种OPS编排中的关系。解决数据研发ETL依赖错综复杂,无法监控任务健康状态的问题。DolphinSchedule
- RPC--zookeeper服务提供类
ZKServiceProviderImpl实现类:下面三个属性,第一个serviceMap,key是服务名称,value是Object也就是服务对象,用于快速查找服务实例第二个registeredService,是已经注册的服务名称,防止重复注册服务第三个serviceRegistry是一个服务注册组件,负责将服务元数据写入Zookeeper接口方法:添加服务、获取服务、发布服务1、addServ
- 解决Windows下C++编译ZooKeeper时的`__imp_zookeeper_init`错误
本文还有配套的精品资源,点击获取简介:在Windows环境中使用C++编译ZooKeeper客户端库时,可能会遇到__imp_zookeeper_init错误,这通常是由于动态链接库(DLL)导入问题导致的。文章解释了如何处理这个错误,包括获取ZooKeeper开发库、配置编译器、链接ZooKeeper库、拷贝DLL文件以及正确使用API。此外,也提到了如何从源代码编译ZooKeeper,以确保所
- ZooKeeper应用场景和实现方案详解:从分布式协调到微服务架构的全场景实践
一切皆有迹可循
微服务注册中心分布式技术分布式架构zookeeper后端云原生微服务java
前言在分布式系统中,协调与一致性是构建可靠服务的核心挑战。ApacheZooKeeper作为高性能分布式协调服务,提供了一套通用的分布式原语,被广泛应用于服务注册发现、分布式锁、配置管理等关键场景。本文将深入解析ZooKeeper的典型应用场景,结合具体代码示例展示实现方案,帮助开发者快速掌握其核心用法。一、服务注册与发现:构建弹性微服务架构1.1场景需求微服务架构中,服务实例动态上下线,需要一个
- SpringBoot教程(二十二) | SpringBoot实现分布式定时任务之elastic-job
Slow菜鸟
#SpringBoot学习篇springboot分布式后端
SpringBoot教程(二十二)|SpringBoot实现分布式定时任务之elastic-job简介适用场景前置条件:需要ZooKeeper配合1、引入相关依赖2、application.yml中配置注册中心和作业调度巨坑(配置修改无效)3、job实例4、ElasticJob-UI监控平台(相当于管理端页面)参考文章:【1】SpringBoot整合分布式任务调度Elastic-Job【2】Ela
- 分布式作业: Elastic-Job
赤橙红的黄
Spring分布式
1.背景介绍Spring框架自带的定时任务scheduled如果部署多台机器时,同一个任务会执行多次,比如给用户计算收益定时任务,每天定时给用户计算收益,如果部署了多台,同一个用户将重复计算多次收益(业务错误),但如果只部署一台机器,无法保证高可用性,如果定时任务机器宕机,无法故障转移;Elastic-Job基于Zookeeper、Quartz开发的Java分布式定时任务解决方案。2.优点高可用性
- 分布式定时任务:Elastic-Job-Lite
Elastic-Job-Lite是一款由Apache开源的轻量级分布式任务调度框架,属于ShardingSphere生态体系的一部分。它专注于分布式任务调度,支持弹性伸缩、分片处理、高可用等特性,且不依赖中心化架构。一、基础(一)核心特性分布式协调通过ZooKeeper实现作业的分布式调度和协调,确保任务在集群环境中不重复、不遗漏地执行。分片机制支持将任务拆分为多个分片(Sharding)并行执行
- 【Java面试】RocketMQ的设计原理
用心分享技术
Java面试题java面试rocketmq
一、核心架构设计原因NameServer轻量级无状态问题:传统注册中心(如ZooKeeper)强一致性(CP)设计复杂,且在高并发场景下性能瓶颈明显。解决:NameServer采用无状态+最终一致性(AP),节点间不通信,仅通过Broker心跳(30s/次)更新路由,降低复杂度并提升吞吐量。容忍分钟级不一致(如Broker宕机需120s剔除),适合消息路由这种非强一致场景。Broker主从架构与文
- 基于 SASL/SCRAM 让 Kafka 实现动态授权认证
zlt2000
Javajavaspringbootkafka
一、说明在大数据处理和分析中ApacheKafka已经成为了一个核心组件。然而在生产环境中部署Kafka时,安全性是一个必须要考虑的重要因素。SASL(简单认证与安全层)和SCRAM(基于密码的认证机制的盐化挑战响应认证机制)提供了一种方法来增强Kafka集群的安全性。本文将从零开始部署ZooKeeper和Kafka并通过配置SASL/SCRAM和ACL(访问控制列表)来增强Kafka的安全性。二
- 大数据集群架构hadoop集群、Hbase集群、zookeeper、kafka、spark、flink、doris、dataeas(二)
争取不加班!
hadoophbasezookeeper大数据运维
zookeeper单节点部署wget-chttps://dlcdn.apache.org/zookeeper/zookeeper-3.8.4/apache-zookeeper-3.8.4-bin.tar.gz下载地址tarxfapache-zookeeper-3.8.4-bin.tar.gz-C/data/&&mv/data/apache-zookeeper-3.8.4-bin//data/zoo
- Nacos与Eureka、ZooKeeper的区别?
leijmdas
java
Nacos、Eureka和ZooKeeper是分布式系统中常用的服务注册与发现组件,但它们在功能定位、一致性模型、性能特性及适用场景上存在显著差异。以下从核心维度进行对比分析:一、功能定位对比特性NacosEurekaZooKeeper核心功能服务注册发现+动态配置管理仅服务注册发现分布式协调(含服务发现)健康检查多模式(心跳+服务端主动探测)仅客户端心跳临时节点会话机制管理界面功能丰富,支持配置
- JT808教程:设置/查询终端参数
REDISANT提供互联网与物联网开发测试套件#互联网与中间件:RedisAssistantZooKeeperAssistantKafkaAssistantRocketMQAssistantRabbitMQAssistantPulsarAssistantHBaseAssistantNoSqlAssistantEtcdAssistantGarnetAssistant工业与物联网:MQTTAssist
- 深入了解大数据领域Zookeeper的ACL权限管理
AGI大模型与大数据研究院
大数据zookeeperwpfai
深入了解大数据领域Zookeeper的ACL权限管理关键词:Zookeeper、ACL权限管理、大数据安全、分布式系统、访问控制、权限模型、数据保护摘要:本文深入探讨了Zookeeper中的ACL(AccessControlList)权限管理系统。作为分布式协调服务的核心组件,Zookeeper的ACL机制对于保障大数据环境中的数据安全至关重要。文章将从基础概念出发,详细解析ZookeeperAC
- Dubbo与Zookeeper核心解析
Java开发廖志伟
Java场景面试宝典DubboServiceDiscoveryDistributedSystems
我是廖志伟,一名Java开发工程师、《Java项目实战——深入理解大型互联网企业通用技术》(基础篇)、(进阶篇)、(架构篇)清华大学出版社签约作家、Java领域优质创作者、CSDN博客专家、阿里云专家博主、51CTO专家博主、产品软文专业写手、技术文章评审老师、技术类问卷调查设计师、幕后大佬社区创始人、开源项目贡献者。拥有多年一线研发和团队管理经验,研究过主流框架的底层源码(Spring、Spri
- .net基于数据库实现分布式锁
.NET基于数据库实现分布式锁全解析前言在分布式系统中,分布式锁是保证数据一致性和避免并发问题的重要手段。在.NET环境下,除了使用Redis、Zookeeper等专业工具实现分布式锁,我们还可以基于数据库来实现。本文将深入探讨如何在.NET中利用数据库实现分布式锁,并分析其优缺点和注意事项。实现思路基于数据库实现分布式锁的核心思路是利用数据库的事务和唯一性约束。我们可以创建一个专门的表来存储锁的
- Zookeeper集群
永旗狍子
Linuxjavazookeeper分布式
目录Zookeeper集群架构图Zookeeper集群中节点的角色Zookeeper数据同步Zookeeper选举搭建Zookeeper集群Java连接Zookeeper集群Zookeeper集群架构图Zookeeper集群中节点的角色Leader(Master):事务请求的唯一处理者,也可以处理读请求。Follower(Slave):可以直接处理客户端的读请求,并向客户端响应;但其不会处理事务请
- ZooKeeper深度面试指南二
搬砖的小熊猫
zookeeper面试分布式
一、Chroot特性:多租户隔离的命名空间功能原理Chroot(ChangeRoot)是ZooKeeper3.2.0引入的关键特性,允许客户端将操作限制在指定子树下。客户端连接时通过路径后缀(如127.0.0.1:2181/app1)设置命名空间,所有操作(如创建节点/config)实际映射为/app1/config,实现物理集群内的逻辑隔离。应用场景多应用共享集群:不同业务(支付/订单)共用Zo
- zookeeper Curator(5):集群架构和集群搭建
后会无期77
zookeeperCuratorzookeeper架构分布式
文章目录一、集群架构:Leader-Follower模式二、核心机制:ZAB协议三、Leader选举机制四、集群部署要点五、优势与挑战Zookeeper集群是一个由多个Zookeeper服务实例组成的分布式协调服务系统,通过奇数个节点(通常3、5、7个)的协作,提供高可用性、容错性和数据一致性,适用于分布式环境下的配置管理、命名服务、分布式锁等场景。以下从架构、核心机制、选举机制、数据模型、应用场
- ZooKeeper的使用和基于Curator的JavaAPI操作
Ruined_ofJoker
java-zookeeperzookeeper数据库
Docker下使用ZooKeeper在/usr/local/zookeeper目录下保存ZooKeeper数据与数据卷卷cd/usr/local&&mkdirzookeeper&&cdzookeepermkdirdata开始部署部署命令dockerrun-d-eTZ="Asia/Shanghai"-p2181:2181-v$PWD/data:/data--namezookeeper--restar
- zookeeper总是重启失败
千百元
工具zookeeperlinux分布式
为什么只有kill-910422后,才能把zookeeper重启成功?问题分析根据你提供的信息,Zookeeper服务在启动时失败,并且只有在使用kill-910422命令终止某个进程(PID为10422)后,才能成功重启Zookeeper。这通常表明PID为10422的进程占用了Zookeeper所需的资源(如端口、文件句柄等),导致Zookeeper无法正常启动。进程10422占用资源原因:端
- 头歌 ZooKeeper之分布式环境搭建(新)
敲代码的苦13
头歌分布式zookeeper云原生
任务描述本关任务:了解ZooKeeper,掌握ZooKeeper分布式安装。相关知识为了完成本关任务,你需要掌握:1.ZooKeeper分布式安装配置ZooKeeper介绍standlone模式运行ZooKeeper,便于评估,开发,测试和学习。但是在实际生产中,使用ZooKeeper均以仲裁模式(quorummode)运行,quorummode具有一组ZooKeeper服务器,这一组服务器同时服
- 深入理解Dubbo与Zookeeper在Java分布式架构中的应用
Aurora曙光
本文还有配套的精品资源,点击获取简介:本文详细解析了Dubbo与Zookeeper在分布式系统构建中的应用,包括如何通过这两个工具实现服务注册、发现、负载均衡和容错处理等核心功能,以及如何将它们集成以提高系统灵活性和可扩展性。文章还提供了使用Dubbo与Zookeeper的实例文档和项目代码,帮助开发者深入理解这两项技术。1.Dubbo与Zookeeper在分布式系统中的应用1.1分布式系统简介与
- Dubbo与Zookeeper技术解析
AIHacksCash
Java场景面试宝典DubboMicroservicesDistributedSystems
我是廖志伟,一名Java开发工程师、《Java项目实战——深入理解大型互联网企业通用技术》(基础篇)、(进阶篇)、(架构篇)清华大学出版社签约作家、Java领域优质创作者、CSDN博客专家、阿里云专家博主、51CTO专家博主、产品软文专业写手、技术文章评审老师、技术类问卷调查设计师、幕后大佬社区创始人、开源项目贡献者。拥有多年一线研发和团队管理经验,研究过主流框架的底层源码(Spring、Spri
- 互联网大数据求职面试:从Zookeeper到Flink的技术探讨
场景:互联网大数据求职面试在一个阳光明媚的下午,小白来到了知名互联网公司,准备接受他人生中最重要的一次面试。他的面试官是以严肃和专业著称的老黑。第一轮提问:分布式系统与协调老黑:小白,你能解释一下Zookeeper在分布式系统中的作用吗?小白:哦,这个简单,Zookeeper是一个分布式协调服务,主要用来解决分布式系统中数据一致性问题,比如选主、配置管理和命名服务。老黑:不错,那你知道Yarn是如
- 揭秘互联网大数据求职面试:从Zookeeper到数据挖掘
小葛呀
大数据面试宝典互联网大数据ZookeeperYarnRedisKafkaHDFS
场景:互联网大数据求职者面试角色介绍:面试官老黑:严肃而专业,技术深入,擅长引导候选人展示自己。程序员小白:搞笑且略显紧张,对基础问题能应付自如,但面对复杂问题时经常词穷。第一轮提问:老黑:"小白,你对Zookeeper的理解是什么?它在分布式系统中扮演什么角色?"小白:"Zookeeper...是个协调者,负责管理配置和同步数据...就像一个团队的协调员,确保每个节点都知道该做什么。"老黑:"没
- 在大数据求职面试中如何回答分布式协调与数据挖掘问题
在大数据求职面试中如何回答分布式协调与数据挖掘问题场景:小白的大数据求职面试小白是一名初出茅庐的程序员,今天他来到一家知名互联网公司的面试现场,面试官是经验丰富的老黑。以下是他们之间的对话:第一轮提问:分布式与数据采集老黑:小白,你对Zookeeper有了解吗?小白:当然,Zookeeper是一个分布式协调服务,主要用于分布式应用程序中的同步服务、命名服务和配置管理。老黑:不错,你能说说Flume
- 使用Java语言实现基于Zookeeper实现分布式锁
夜影风
微服务架构Java应用分布式java-zookeeperjava
前期,我们介绍了什么是分布式锁及分布式锁应用场景,并分享了基于Redis方案实现的分布式锁,今天我们基于Zookeeper方案来实现分布式锁的应用。一.方案概述1.1.实现原理:临时顺序节点:每个客户端请求锁时,在ZooKeeper的指定节点下创建一个临时顺序节点。锁竞争机制:客户端创建节点后,获取所有子节点列表并排序如果自己创建的节点是序号最小的节点,则获得锁否则,监听前一个节点的删除事件,进入
- jvm调优总结(从基本概念 到 深度优化)
oloz
javajvmjdk虚拟机应用服务器
JVM参数详解:http://www.cnblogs.com/redcreen/archive/2011/05/04/2037057.html
Java虚拟机中,数据类型可以分为两类:基本类型和引用类型。基本类型的变量保存原始值,即:他代表的值就是数值本身;而引用类型的变量保存引用值。“引用值”代表了某个对象的引用,而不是对象本身,对象本身存放在这个引用值所表示的地址的位置。
- 【Scala十六】Scala核心十:柯里化函数
bit1129
scala
本篇文章重点说明什么是函数柯里化,这个语法现象的背后动机是什么,有什么样的应用场景,以及与部分应用函数(Partial Applied Function)之间的联系 1. 什么是柯里化函数
A way to write functions with multiple parameter lists. For instance
def f(x: Int)(y: Int) is a
- HashMap
dalan_123
java
HashMap在java中对很多人来说都是熟的;基于hash表的map接口的非同步实现。允许使用null和null键;同时不能保证元素的顺序;也就是从来都不保证其中的元素的顺序恒久不变。
1、数据结构
在java中,最基本的数据结构无外乎:数组 和 引用(指针),所有的数据结构都可以用这两个来构造,HashMap也不例外,归根到底HashMap就是一个链表散列的数据
- Java Swing如何实时刷新JTextArea,以显示刚才加append的内容
周凡杨
java更新swingJTextArea
在代码中执行完textArea.append("message")后,如果你想让这个更新立刻显示在界面上而不是等swing的主线程返回后刷新,我们一般会在该语句后调用textArea.invalidate()和textArea.repaint()。
问题是这个方法并不能有任何效果,textArea的内容没有任何变化,这或许是swing的一个bug,有一个笨拙的办法可以实现
- servlet或struts的Action处理ajax请求
g21121
servlet
其实处理ajax的请求非常简单,直接看代码就行了:
//如果用的是struts
//HttpServletResponse response = ServletActionContext.getResponse();
// 设置输出为文字流
response.setContentType("text/plain");
// 设置字符集
res
- FineReport的公式编辑框的语法简介
老A不折腾
finereport公式总结
FINEREPORT用到公式的地方非常多,单元格(以=开头的便被解析为公式),条件显示,数据字典,报表填报属性值定义,图表标题,轴定义,页眉页脚,甚至单元格的其他属性中的鼠标悬浮提示内容都可以写公式。
简单的说下自己感觉的公式要注意的几个地方:
1.if语句语法刚接触感觉比较奇怪,if(条件式子,值1,值2),if可以嵌套,if(条件式子1,值1,if(条件式子2,值2,值3)
- linux mysql 数据库乱码的解决办法
墙头上一根草
linuxmysql数据库乱码
linux 上mysql数据库区分大小写的配置
lower_case_table_names=1 1-不区分大小写 0-区分大小写
修改/etc/my.cnf 具体的修改内容如下:
[client]
default-character-set=utf8
[mysqld]
datadir=/var/lib/mysql
socket=/va
- 我的spring学习笔记6-ApplicationContext实例化的参数兼容思想
aijuans
Spring 3
ApplicationContext能读取多个Bean定义文件,方法是:
ApplicationContext appContext = new ClassPathXmlApplicationContext(
new String[]{“bean-config1.xml”,“bean-config2.xml”,“bean-config3.xml”,“bean-config4.xml
- mysql 基准测试之sysbench
annan211
基准测试mysql基准测试MySQL测试sysbench
1 执行如下命令,安装sysbench-0.5:
tar xzvf sysbench-0.5.tar.gz
cd sysbench-0.5
chmod +x autogen.sh
./autogen.sh
./configure --with-mysql --with-mysql-includes=/usr/local/mysql
- sql的复杂查询使用案列与技巧
百合不是茶
oraclesql函数数据分页合并查询
本片博客使用的数据库表是oracle中的scott用户表;
------------------- 自然连接查询
查询 smith 的上司(两种方法)
&
- 深入学习Thread类
bijian1013
javathread多线程java多线程
一. 线程的名字
下面来看一下Thread类的name属性,它的类型是String。它其实就是线程的名字。在Thread类中,有String getName()和void setName(String)两个方法用来设置和获取这个属性的值。
同时,Thr
- JSON串转换成Map以及如何转换到对应的数据类型
bijian1013
javafastjsonnet.sf.json
在实际开发中,难免会碰到JSON串转换成Map的情况,下面来看看这方面的实例。另外,由于fastjson只支持JDK1.5及以上版本,因此在JDK1.4的项目中可以采用net.sf.json来处理。
一.fastjson实例
JsonUtil.java
package com.study;
impor
- 【RPC框架HttpInvoker一】HttpInvoker:Spring自带RPC框架
bit1129
spring
HttpInvoker是Spring原生的RPC调用框架,HttpInvoker同Burlap和Hessian一样,提供了一致的服务Exporter以及客户端的服务代理工厂Bean,这篇文章主要是复制粘贴了Hessian与Spring集成一文,【RPC框架Hessian四】Hessian与Spring集成
在
【RPC框架Hessian二】Hessian 对象序列化和反序列化一文中
- 【Mahout二】基于Mahout CBayes算法的20newsgroup的脚本分析
bit1129
Mahout
#!/bin/bash
#
# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements. See the NOTICE file distributed with
# this work for additional information re
- nginx三种获取用户真实ip的方法
ronin47
随着nginx的迅速崛起,越来越多公司将apache更换成nginx. 同时也越来越多人使用nginx作为负载均衡, 并且代理前面可能还加上了CDN加速,但是随之也遇到一个问题:nginx如何获取用户的真实IP地址,如果后端是apache,请跳转到<apache获取用户真实IP地址>,如果是后端真实服务器是nginx,那么继续往下看。
实例环境: 用户IP 120.22.11.11
- java-判断二叉树是不是平衡
bylijinnan
java
参考了
http://zhedahht.blog.163.com/blog/static/25411174201142733927831/
但是用java来实现有一个问题。
由于Java无法像C那样“传递参数的地址,函数返回时能得到参数的值”,唯有新建一个辅助类:AuxClass
import ljn.help.*;
public class BalancedBTree {
- BeanUtils.copyProperties VS PropertyUtils.copyProperties
诸葛不亮
PropertyUtilsBeanUtils
BeanUtils.copyProperties VS PropertyUtils.copyProperties
作为两个bean属性copy的工具类,他们被广泛使用,同时也很容易误用,给人造成困然;比如:昨天发现同事在使用BeanUtils.copyProperties copy有integer类型属性的bean时,没有考虑到会将null转换为0,而后面的业
- [金融与信息安全]最简单的数据结构最安全
comsci
数据结构
现在最流行的数据库的数据存储文件都具有复杂的文件头格式,用操作系统的记事本软件是无法正常浏览的,这样的情况会有什么问题呢?
从信息安全的角度来看,如果我们数据库系统仅仅把这种格式的数据文件做异地备份,如果相同版本的所有数据库管理系统都同时被攻击,那么
- vi区段删除
Cwind
linuxvi区段删除
区段删除是编辑和分析一些冗长的配置文件或日志文件时比较常用的操作。简记下vi区段删除要点备忘。
vi概述
引文中并未将末行模式单独列为一种模式。单不单列并不重要,能区分命令模式与末行模式即可。
vi区段删除步骤:
1. 在末行模式下使用:set nu显示行号
非必须,随光标移动vi右下角也会显示行号,能够正确找到并记录删除开始行
- 清除tomcat缓存的方法总结
dashuaifu
tomcat缓存
用tomcat容器,大家可能会发现这样的问题,修改jsp文件后,但用IE打开 依然是以前的Jsp的页面。
出现这种现象的原因主要是tomcat缓存的原因。
解决办法如下:
在jsp文件头加上
<meta http-equiv="Expires" content="0"> <meta http-equiv="kiben&qu
- 不要盲目的在项目中使用LESS CSS
dcj3sjt126com
Webless
如果你还不知道LESS CSS是什么东西,可以看一下这篇文章,是我一朋友写给新人看的《CSS——LESS》
不可否认,LESS CSS是个强大的工具,它弥补了css没有变量、无法运算等一些“先天缺陷”,但它似乎给我一种错觉,就是为了功能而实现功能。
比如它的引用功能
?
.rounded_corners{
- [入门]更上一层楼
dcj3sjt126com
PHPyii2
更上一层楼
通篇阅读完整个“入门”部分,你就完成了一个完整 Yii 应用的创建。在此过程中你学到了如何实现一些常用功能,例如通过 HTML 表单从用户那获取数据,从数据库中获取数据并以分页形式显示。你还学到了如何通过 Gii 去自动生成代码。使用 Gii 生成代码把 Web 开发中多数繁杂的过程转化为仅仅填写几个表单就行。
本章将介绍一些有助于更好使用 Yii 的资源:
- Apache HttpClient使用详解
eksliang
httpclienthttp协议
Http协议的重要性相信不用我多说了,HttpClient相比传统JDK自带的URLConnection,增加了易用性和灵活性(具体区别,日后我们再讨论),它不仅是客户端发送Http请求变得容易,而且也方便了开发人员测试接口(基于Http协议的),即提高了开发的效率,也方便提高代码的健壮性。因此熟练掌握HttpClient是很重要的必修内容,掌握HttpClient后,相信对于Http协议的了解会
- zxing二维码扫描功能
gundumw100
androidzxing
经常要用到二维码扫描功能
现给出示例代码
import com.google.zxing.WriterException;
import com.zxing.activity.CaptureActivity;
import com.zxing.encoding.EncodingHandler;
import android.app.Activity;
import an
- 纯HTML+CSS带说明的黄色导航菜单
ini
htmlWebhtml5csshovertree
HoverTree带说明的CSS菜单:纯HTML+CSS结构链接带说明的黄色导航
在线体验效果:http://hovertree.com/texiao/css/1.htm代码如下,保存到HTML文件可以看到效果:
<!DOCTYPE html >
<html >
<head>
<title>HoverTree
- fastjson初始化对性能的影响
kane_xie
fastjson序列化
之前在项目中序列化是用thrift,性能一般,而且需要用编译器生成新的类,在序列化和反序列化的时候感觉很繁琐,因此想转到json阵营。对比了jackson,gson等框架之后,决定用fastjson,为什么呢,因为看名字感觉很快。。。
网上的说法:
fastjson 是一个性能很好的 Java 语言实现的 JSON 解析器和生成器,来自阿里巴巴的工程师开发。
- 基于Mybatis封装的增删改查实现通用自动化sql
mengqingyu
DAO
1.基于map或javaBean的增删改查可实现不写dao接口和实现类以及xml,有效的提高开发速度。
2.支持自定义注解包括主键生成、列重复验证、列名、表名等
3.支持批量插入、批量更新、批量删除
<bean id="dynamicSqlSessionTemplate" class="com.mqy.mybatis.support.Dynamic
- js控制input输入框的方法封装(数字,中文,字母,浮点数等)
qifeifei
javascript js
在项目开发的时候,经常有一些输入框,控制输入的格式,而不是等输入好了再去检查格式,格式错了就报错,体验不好。 /** 数字,中文,字母,浮点数(+/-/.) 类型输入限制,只要在input标签上加上 jInput="number,chinese,alphabet,floating" 备注:floating属性只能单独用*/
funct
- java 计时器应用
tangqi609567707
javatimer
mport java.util.TimerTask; import java.util.Calendar; public class MyTask extends TimerTask { private static final int
- erlang输出调用栈信息
wudixiaotie
erlang
在erlang otp的开发中,如果调用第三方的应用,会有有些错误会不打印栈信息,因为有可能第三方应用会catch然后输出自己的错误信息,所以对排查bug有很大的阻碍,这样就要求我们自己打印调用的栈信息。用这个函数:erlang:process_display (self (), backtrace).需要注意这个函数只会输出到标准错误输出。
也可以用这个函数:erlang:get_s