- 物联网实战:多语言(Java、Go、Rust、C++、C#、Rust)设备接入与数据处理
KENYCHEN奉孝
RustC++gospringjavavue.jsrustc++
SpringBoot物联网设备接入与数据处理实例物联网(IoT)设备接入与数据处理是SpringBoot的常见应用场景之一。以下是一个完整的实例,涵盖设备接入、数据传输、数据处理和存储等关键环节。设备接入物联网设备通常通过MQTT、HTTP或WebSocket等协议接入系统。MQTT是物联网领域最常用的轻量级协议。//MQTT配置类@ConfigurationpublicclassMqttConf
- 几个MODBUS模拟工具
神一样的老师
工业互联网嵌入式硬件
在网上找了几个MODBUS模拟测试工具,还没有来得及测试,先记录在这里。PeakHMISlaveSimulators,Neuron推荐的免费软件。使用方法可以参考:工业物联网数据桥接教程:Modbus桥接到MQTT-知乎(zhihu.com)。ModbusSlaveSimulation,开源软件,已经停止更新了。ModbusSlave和ModbusPoll,收费软件,用户很多。使用方法参考:【VS
- Kafka消息轨迹追踪:分布式系统调试利器
大数据洞察
kafkalinq分布式ai
Kafka消息轨迹追踪:分布式系统调试利器关键词Kafka、消息轨迹追踪、分布式系统、调试、消息处理、事件溯源摘要本文聚焦于Kafka消息轨迹追踪这一分布式系统调试的关键技术。首先介绍Kafka消息轨迹追踪的概念基础,包括其在分布式系统中的背景、发展历史以及问题空间。接着阐述其理论框架,从第一性原理进行推导,并分析理论局限性和竞争范式。在架构设计方面,对系统进行分解,构建组件交互模型并可视化展示。
- RabbitMQ实现路由模式发送接收消息
1.基础类publicclassRabbitMQHelper{publicstaticIConnectionGetConnect(){//连接工厂varfac=newConnectionFactory(){HostName=“127.0.0.1”,//IPPort=5672,//端口UserName=“xxx”,Password=“xxx”,VirtualHost=“/”};returnfac.C
- Docker:快速搭建 RabbitMQ 集群的技术指南
拾荒的小海螺
DevOpsdockerrabbitmq容器
1、简述RabbitMQ是目前最流行的开源消息中间件之一,广泛应用于解耦、异步通信、削峰填谷等场景。本篇博客将带你通过Docker快速搭建RabbitMQ集群,并展示SpringBoot集成的实践案例,助你高效入门RabbitMQ分布式消息系统。样例代码:https://gitee.com/lhdxhl/springboot-example.git2、搭建2.1准备工作首先安装Docker和Doc
- RabbitMQ消息发送与接收
VksgShapes
rabbitmqruby分布式
RabbitMQ是一个功能强大的开源消息代理,用于在应用程序之间传递消息。它实现了AMQP(高级消息队列协议),提供了可靠的消息传递机制,支持多种消息模式和灵活的消息路由。在本篇文章中,我们将详细介绍如何在应用程序中使用RabbitMQ进行消息的发送和接收。我们将使用Python作为示例编程语言,并使用Pika作为RabbitMQ的Python客户端。安装依赖库首先,我们需要安装Pika库。可以使
- RabbitMQ简单消息发送
RabbitMQ简单消息发送简单代码实现RabbitMQ消息发送需要的依赖org.springframework.bootspring-boot-starter-amqpx.x.x消息发送示例importcom.rabbitmq.client.Channel;importlombok.extern.slf4j.Slf4j;importorg.springframework.amqp.rabbit.
- Kafka日常运维命令总结
我科绝伦(Huanhuan Zhou)
kafka运维分布式
一、集群管理前台启动Brokerbin/kafka-server-start.sh/server.properties关闭方式:Ctrl+C后台启动Brokerbin/kafka-server-start.sh-daemon/server.properties关闭Brokerbin/kafka-server-stop.sh二、Topic管理操作命令创建Topicbin/kafka-topics.s
- MQTT协议
bantinghy
MQTTc++linux服务器ubuntu
MQTT协议历史背景ArlenNipper(当时在ArcomControlSystems)和IBM的AndyStanford-Clark在1999年初制定了MQTT(MessageQueuingTelemetryTransport,消息队列遥测传输)的第一个版本。那随着物联网的应用,也把其中很重要的通信协议MQTT推到非常关键的位置。没有MQTT,也就没有物联网的快速发展。参考文献Hello工控-
- DDD 分层架构实战指南:从项目结构到落地挑战
一、项目结构详解(以电商订单系统为例)src/main/java├──com.example│├──common#通用工具类、基础异常、常量│├──order#订单限界上下文(模块示例)││├──interfaces#用户接口层│││├──controller#HTTP/RESTAPI│││├──rpc#Dubbo/gRPC接口│││└──consumer#消息队列消费者(如Kafka监听)││├
- JT808教程:设置/查询终端参数
REDISANT提供互联网与物联网开发测试套件#互联网与中间件:RedisAssistantZooKeeperAssistantKafkaAssistantRocketMQAssistantRabbitMQAssistantPulsarAssistantHBaseAssistantNoSqlAssistantEtcdAssistantGarnetAssistant工业与物联网:MQTTAssist
- Ollama增加上下文大小
添财小哥
大语言模型相关人工智能
1、编辑Modelfilefromqwen2.5:32b-instruct-q4_K_Mparametertemperature0.1PARAMETERtop_p0.8PARAMETERrepeat_penalty1.1PARAMETERtop_k20PARAMETERnum_ctx131072这里可能会报错:Error:commandmustbeoneof"from","license","te
- Spring Cloud Bus 和 Spring Cloud Stream
中国lanwp
springboot
SpringCloudBus和SpringCloudStream都是SpringCloud生态中的消息通信组件,但它们的定位和使用场景有显著区别:1.SpringCloudBus核心定位:分布式系统的消息广播(配置刷新、事件传播)。典型场景:通过消息中间件(如RabbitMQ、Kafka)广播配置变更事件,实现所有微服务配置的集中刷新(如结合/actuator/refresh或/actuator/
- springboot整合rabbitmq集群配置详解
ThePual
javaspringbootrabbitmq队列
springboot整合rabbitmq集群创建方式这里省略整合开始1引入starterorg.springframework.bootspring-boot-starter-parent2.2.6.RELEASEorg.springframework.bootspring-boot-starter-amqp2配置文件rabbitmq:addresses:127.0.0.1:6605,127.0.
- rabbitmq动态创建交换机、队列、动态绑定,销毁
//缓存已创建的绑定,避免重复声明privatefinalMapcreatedBindings=newConcurrentHashMapargs=newHashMap{@AutowiredRabbitMQServicerabbitMQService;@OverridepublicvoidonApplicationEvent(ListenerContainerConsumerFailedEvente
- rabbitmq springboot 有哪些配置参数
CATTLECODE
rabbitmq
在SpringBoot中集成RabbitMQ时,可以通过配置文件(如application.properties或application.yml)设置多种参数,以满足不同的业务需求。以下是常见的配置参数及其说明:1.基础连接配置spring.rabbitmq.hostRabbitMQ服务器的地址(默认:localhost)。spring.rabbitmq.portRabbitMQ服务器
- Python大数据分析&人工智能教程 - Django-Celery异步处理(深入解析与实战案例)
AI_DL_CODE
python数据分析DjangoCelery异步处理Celery
文章目录1.概念介绍1.1Django框架概述1.2Celery异步任务队列1.3AMQP协议与消息路由2.环境搭建2.1安装Django和Celery2.2配置Redis作为消息代理3.Celery架构与工作原理3.1Celery组件介绍3.2任务生命周期3.3任务调度与执行3.3.1定时任务3.3.2异步任务调用3.3.3任务结果查询4.Django与Celery集成4.1创建Celery实例
- Exception: This server is not the leader for that topic-partition.
uplinker
javajavakafka
异常:2016081718:58:48ERRORcom.xxx.lac.service.impl.ComparePriceServiceImpl-307kafka-producer-network-thread|lac_compare_price_service_producer_3-sendCompleteexecptionThisserverisnottheleaderforthattopic
- 环境搭建:从零开始——Windows 环境下 Kafka 集群的 Docker 安装与配置全指南
DR. BULL ELECTRONICS
#环境搭建windowskafkadocker
环境搭建:从零开始——Windows环境下Kafka集群的Docker安装与配置全指南本博客详细介绍了如何在Windows环境下使用Docker安装和配置Kafka集群。通过提供具体的操作步骤和命令示例,从零开始帮助用户配置Docker、启动Kafka集群、并在SpringBoot应用程序中使用Kafka进行消息传递。该指南包括Docker安装、Kafka集群搭建、启动Kafka服务、创建主题、配
- 充电桩 APP 开发:技术架构与核心功能
一品威客网
架构
随着新能源汽车的普及,充电桩APP成为连接用户与充电设施的关键枢纽。这类APP的开发需兼顾用户体验与运营效率,以下从技术实现与功能设计两方面展开分析。技术架构设计实时数据交互:采用MQTT协议实现充电桩状态(空闲/充电中/故障)的实时推送,确保用户获取最新信息。定位与地图服务:集成高德/Baidu地图SDK,通过POI搜索与路径规划算法,优化充电桩位置展示与导航体验。支付系统:对接微信/支付宝支付
- 记录springboot集成多个mqtt,实现重连后重新订阅
shell_girl
springbootjavaspring
springboot整合多个mqtt前提:实际应用中,项目需要订阅其他服务器的消息,并且把本机消息发布,所以需要连接多个mqtt,实现不同的需求参考:https://blog.csdn.net/qq_40083897/article/details/117333716整合大致结构如下:1.引入依赖org.springframework.integrationspring-integration-s
- 《JMS事务性会话彻底解析:消息监听中的 commit、rollback 和幂等设计》
G探险者
java中间件分布式
大家好,我是G探险者!场景引入在实际项目中,我们常常面临以下挑战:监听MQ消息失败了,希望自动重试?消费MQ消息后,要写数据库,但中间报错了?消息处理必须要么成功要么失败,否则可能导致脏数据?消息是幂等的吗?可以重复投递处理吗?这些都需要事务性会话+容器回滚机制+幂等控制组合拳来解决。✅一、什么是JMS的事务性会话?事务性会话(transacted=true)是一种将消息的接收与处理放入事务中控制
- 《如何在 Spring 中实现 MQ 消息的自动重连:监听与发送双通道策略》
G探险者
javarpc开发语言
大家好,我是G探险者!背景场景在高可用分布式系统中,我们经常面临:MQ集群重启→消息监听中断MQ网络短暂抖动→发送端连接失败一端恢复正常,另一端仍处于挂死状态如果你只配置了“连接工厂层”的重连,却忽略了监听容器或发送客户端的容错设计,重连机制可能失效,业务陷入长时间不可用。✅核心理念:监听和发送是两个不同的连接“通道”通道用途组件监听通道从MQ拉取消息SpringJMS的MessageListen
- 【Java面试】如何解决MQ死信队列?
用心分享技术
Java面试题java面试
如何解决MQ死信队列?一、预防死信产生(从源头减少死信)消费者端健壮性优化捕获所有可能的异常,区分可恢复异常(如网络超时)和不可恢复异常(如数据格式错误)。对可恢复异常实现自动重试机制,通过延迟重投(如首次失败后延迟5秒重试)降低进入死信的概率。业务逻辑实现幂等性,避免重复消费导致的数据不一致问题。合理配置队列参数设置消息TTL(生存时间),避免消息无限期堆积。限制队列最大长度(如RabbitMQ
- Kafka 消息队列
ikun·
kafka分布式
一、消息队列1.什么是消息队列消息(Message)是指在应用间传送的数据。消息可以非常简单,比如只包含文本字符串,也可以更复杂,可能包含嵌入对象。消息队列(MessageQueue)是一种应用间的通信方式,消息发送后可以立即返回,由消息系统来确保消息的可靠传递。消息发布者只管把消息发布到MQ中而不用管谁来取,消息使用者只管从MQ中取消息而不管是谁发布的。这样发布者和使用者都不用知道对方的存在。2
- 点赞功能真的有必要上 Redis 吗?(Mongo、MySQL、Redis、MQ 实测性能对比)
陈亦康
Redis深入学习经验分享面试总结redis数据库缓存
免费查看本文章可前往我的网站:PiQiu目录一、你会怎么设计一个点赞功能?1.1、点赞实现思路1.2、点赞功能设计1.2.1、MySQL单表1.2.2、单表+MySQL关联表1.2.3、MySQL关联表+mq1.2.4、redis+mq1.2.5、mongodb关联文档二、性能测试2.1、前置说明2.2、10万数据准备三、基于Mongo的几种点赞功能设计思路3.1、前置说明:点赞功能设计到的业务3
- 大数据ETL工具比较:Sqoop vs Flume vs Kafka
AI天才研究院
AI人工智能与大数据大数据etlsqoopai
大数据ETL工具比较:SqoopvsFlumevsKafka关键词:大数据ETL、Sqoop、Flume、Kafka、数据迁移、日志采集、消息队列摘要:在大数据生态中,ETL(抽取-转换-加载)是数据价值挖掘的关键环节。不同业务场景对数据传输的实时性、可靠性、数据类型有差异化需求,催生了Sqoop、Flume、Kafka等特色鲜明的ETL工具。本文从核心架构、工作原理、性能指标、实战案例四个维度,
- SpringBoot RabbitMQ 配置参数
闲走天涯
mqjava-rabbitmqspringbootrabbitmq
SpringBootRabbitMQ配置参数参数值表示spring.rabbitmq.addresses以逗号分隔的客户端应连接的地址列表。spring.rabbitmq.cache.channel.checkout-timeout如果已达到缓存大小,则等待获取通道的毫秒数。spring.rabbitmq.cache.channel.size要保留在缓存中的通道数。spring.rabbitmq.
- rabbitmq配置参数解析在springboot中
天然玩家
架构设计#Spring配置解析RabbitMQSpringBootJava
1缘起我是一个菜鸟。如何才能在群体中飞得更高?期望是,大家不会用的,我会;大家都会用的,我精。当然了,大家不会用的我也不会。大家会用的,我也可能不会用。勤补拙。我在使用RabbitMQ组件的过程中,一些配置参数,如RabbitMQ连接、发布者、监听者,这些参数均是抄过来的,并不知道真生的含义,现打算弄清楚每个参数的含义,为后续的线上遇到问题,调参做准备。成为调参架构师2入口如何找到RabbitMQ
- RabbitMQ中,basicAck、basicNack和basicReject是三种核心的消息确认机制
CATTLECODE
rabbitmq分布式
channel.basicNack(message.getMessageProperties().getDeliveryTag(),false,true); channel.basicReject(message.getMessageProperties().getDeliveryTag(),false);channel.basicAck(message.getMessageProperties(
- ASM系列四 利用Method 组件动态注入方法逻辑
lijingyao8206
字节码技术jvmAOP动态代理ASM
这篇继续结合例子来深入了解下Method组件动态变更方法字节码的实现。通过前面一篇,知道ClassVisitor 的visitMethod()方法可以返回一个MethodVisitor的实例。那么我们也基本可以知道,同ClassVisitor改变类成员一样,MethodVIsistor如果需要改变方法成员,注入逻辑,也可以
- java编程思想 --内部类
百合不是茶
java内部类匿名内部类
内部类;了解外部类 并能与之通信 内部类写出来的代码更加整洁与优雅
1,内部类的创建 内部类是创建在类中的
package com.wj.InsideClass;
/*
* 内部类的创建
*/
public class CreateInsideClass {
public CreateInsideClass(
- web.xml报错
crabdave
web.xml
web.xml报错
The content of element type "web-app" must match "(icon?,display-
name?,description?,distributable?,context-param*,filter*,filter-mapping*,listener*,servlet*,s
- 泛型类的自定义
麦田的设计者
javaandroid泛型
为什么要定义泛型类,当类中要操作的引用数据类型不确定的时候。
采用泛型类,完成扩展。
例如有一个学生类
Student{
Student(){
System.out.println("I'm a student.....");
}
}
有一个老师类
- CSS清除浮动的4中方法
IT独行者
JavaScriptUIcss
清除浮动这个问题,做前端的应该再熟悉不过了,咱是个新人,所以还是记个笔记,做个积累,努力学习向大神靠近。CSS清除浮动的方法网上一搜,大概有N多种,用过几种,说下个人感受。
1、结尾处加空div标签 clear:both 1 2 3 4
.div
1
{
background
:
#000080
;
border
:
1px
s
- Cygwin使用windows的jdk 配置方法
_wy_
jdkwindowscygwin
1.[vim /etc/profile]
JAVA_HOME="/cgydrive/d/Java/jdk1.6.0_43" (windows下jdk路径为D:\Java\jdk1.6.0_43)
PATH="$JAVA_HOME/bin:${PATH}"
CLAS
- linux下安装maven
无量
mavenlinux安装
Linux下安装maven(转) 1.首先到Maven官网
下载安装文件,目前最新版本为3.0.3,下载文件为
apache-maven-3.0.3-bin.tar.gz,下载可以使用wget命令;
2.进入下载文件夹,找到下载的文件,运行如下命令解压
tar -xvf apache-maven-2.2.1-bin.tar.gz
解压后的文件夹
- tomcat的https 配置,syslog-ng配置
aichenglong
tomcathttp跳转到httpssyslong-ng配置syslog配置
1) tomcat配置https,以及http自动跳转到https的配置
1)TOMCAT_HOME目录下生成密钥(keytool是jdk中的命令)
keytool -genkey -alias tomcat -keyalg RSA -keypass changeit -storepass changeit
- 关于领号活动总结
alafqq
活动
关于某彩票活动的总结
具体需求,每个用户进活动页面,领取一个号码,1000中的一个;
活动要求
1,随机性,一定要有随机性;
2,最少中奖概率,如果注数为3200注,则最多中4注
3,效率问题,(不能每个人来都产生一个随机数,这样效率不高);
4,支持断电(仍然从下一个开始),重启服务;(存数据库有点大材小用,因此不能存放在数据库)
解决方案
1,事先产生随机数1000个,并打
- java数据结构 冒泡排序的遍历与排序
百合不是茶
java
java的冒泡排序是一种简单的排序规则
冒泡排序的原理:
比较两个相邻的数,首先将最大的排在第一个,第二次比较第二个 ,此后一样;
针对所有的元素重复以上的步骤,除了最后一个
例题;将int array[]
- JS检查输入框输入的是否是数字的一种校验方法
bijian1013
js
如下是JS检查输入框输入的是否是数字的一种校验方法:
<form method=post target="_blank">
数字:<input type="text" name=num onkeypress="checkNum(this.form)"><br>
</form>
- Test注解的两个属性:expected和timeout
bijian1013
javaJUnitexpectedtimeout
JUnit4:Test文档中的解释:
The Test annotation supports two optional parameters.
The first, expected, declares that a test method should throw an exception.
If it doesn't throw an exception or if it
- [Gson二]继承关系的POJO的反序列化
bit1129
POJO
父类
package inheritance.test2;
import java.util.Map;
public class Model {
private String field1;
private String field2;
private Map<String, String> infoMap
- 【Spark八十四】Spark零碎知识点记录
bit1129
spark
1. ShuffleMapTask的shuffle数据在什么地方记录到MapOutputTracker中的
ShuffleMapTask的runTask方法负责写数据到shuffle map文件中。当任务执行完成成功,DAGScheduler会收到通知,在DAGScheduler的handleTaskCompletion方法中完成记录到MapOutputTracker中
- WAS各种脚本作用大全
ronin47
WAS 脚本
http://www.ibm.com/developerworks/cn/websphere/library/samples/SampleScripts.html
无意中,在WAS官网上发现的各种脚本作用,感觉很有作用,先与各位分享一下
获取下载
这些示例 jacl 和 Jython 脚本可用于在 WebSphere Application Server 的不同版本中自
- java-12.求 1+2+3+..n不能使用乘除法、 for 、 while 、 if 、 else 、 switch 、 case 等关键字以及条件判断语句
bylijinnan
switch
借鉴网上的思路,用java实现:
public class NoIfWhile {
/**
* @param args
*
* find x=1+2+3+....n
*/
public static void main(String[] args) {
int n=10;
int re=find(n);
System.o
- Netty源码学习-ObjectEncoder和ObjectDecoder
bylijinnan
javanetty
Netty中传递对象的思路很直观:
Netty中数据的传递是基于ChannelBuffer(也就是byte[]);
那把对象序列化为字节流,就可以在Netty中传递对象了
相应的从ChannelBuffer恢复对象,就是反序列化的过程
Netty已经封装好ObjectEncoder和ObjectDecoder
先看ObjectEncoder
ObjectEncoder是往外发送
- spring 定时任务中cronExpression表达式含义
chicony
cronExpression
一个cron表达式有6个必选的元素和一个可选的元素,各个元素之间是以空格分隔的,从左至右,这些元素的含义如下表所示:
代表含义 是否必须 允许的取值范围 &nb
- Nutz配置Jndi
ctrain
JNDI
1、使用JNDI获取指定资源:
var ioc = {
dao : {
type :"org.nutz.dao.impl.NutDao",
args : [ {jndi :"jdbc/dataSource"} ]
}
}
以上方法,仅需要在容器中配置好数据源,注入到NutDao即可.
- 解决 /bin/sh^M: bad interpreter: No such file or directory
daizj
shell
在Linux中执行.sh脚本,异常/bin/sh^M: bad interpreter: No such file or directory。
分析:这是不同系统编码格式引起的:在windows系统中编辑的.sh文件可能有不可见字符,所以在Linux系统下执行会报以上异常信息。
解决:
1)在windows下转换:
利用一些编辑器如UltraEdit或EditPlus等工具
- [转]for 循环为何可恨?
dcj3sjt126com
程序员读书
Java的闭包(Closure)特征最近成为了一个热门话题。 一些精英正在起草一份议案,要在Java将来的版本中加入闭包特征。 然而,提议中的闭包语法以及语言上的这种扩充受到了众多Java程序员的猛烈抨击。
不久前,出版过数十本编程书籍的大作家Elliotte Rusty Harold发表了对Java中闭包的价值的质疑。 尤其是他问道“for 循环为何可恨?”[http://ju
- Android实用小技巧
dcj3sjt126com
android
1、去掉所有Activity界面的标题栏
修改AndroidManifest.xml 在application 标签中添加android:theme="@android:style/Theme.NoTitleBar"
2、去掉所有Activity界面的TitleBar 和StatusBar
修改AndroidManifes
- Oracle 复习笔记之序列
eksliang
Oracle 序列sequenceOracle sequence
转载请出自出处:http://eksliang.iteye.com/blog/2098859
1.序列的作用
序列是用于生成唯一、连续序号的对象
一般用序列来充当数据库表的主键值
2.创建序列语法如下:
create sequence s_emp
start with 1 --开始值
increment by 1 --増长值
maxval
- 有“品”的程序员
gongmeitao
工作
完美程序员的10种品质
完美程序员的每种品质都有一个范围,这个范围取决于具体的问题和背景。没有能解决所有问题的
完美程序员(至少在我们这个星球上),并且对于特定问题,完美程序员应该具有以下品质:
1. 才智非凡- 能够理解问题、能够用清晰可读的代码翻译并表达想法、善于分析并且逻辑思维能力强
(范围:用简单方式解决复杂问题)
- 使用KeleyiSQLHelper类进行分页查询
hvt
sql.netC#asp.nethovertree
本文适用于sql server单主键表或者视图进行分页查询,支持多字段排序。KeleyiSQLHelper类的最新代码请到http://hovertree.codeplex.com/SourceControl/latest下载整个解决方案源代码查看。或者直接在线查看类的代码:http://hovertree.codeplex.com/SourceControl/latest#HoverTree.D
- SVG 教程 (三)圆形,椭圆,直线
天梯梦
svg
SVG <circle> SVG 圆形 - <circle>
<circle> 标签可用来创建一个圆:
下面是SVG代码:
<svg xmlns="http://www.w3.org/2000/svg" version="1.1">
<circle cx="100" c
- 链表栈
luyulong
java数据结构
public class Node {
private Object object;
private Node next;
public Node() {
this.next = null;
this.object = null;
}
public Object getObject() {
return object;
}
public
- 基础数据结构和算法十:2-3 search tree
sunwinner
Algorithm2-3 search tree
Binary search tree works well for a wide variety of applications, but they have poor worst-case performance. Now we introduce a type of binary search tree where costs are guaranteed to be loga
- spring配置定时任务
stunizhengjia
springtimer
最近因工作的需要,用到了spring的定时任务的功能,觉得spring还是很智能化的,只需要配置一下配置文件就可以了,在此记录一下,以便以后用到:
//------------------------定时任务调用的方法------------------------------
/**
* 存储过程定时器
*/
publi
- ITeye 8月技术图书有奖试读获奖名单公布
ITeye管理员
活动
ITeye携手博文视点举办的8月技术图书有奖试读活动已圆满结束,非常感谢广大用户对本次活动的关注与参与。
8月试读活动回顾:
http://webmaster.iteye.com/blog/2102830
本次技术图书试读活动的优秀奖获奖名单及相应作品如下(优秀文章有很多,但名额有限,没获奖并不代表不优秀):
《跨终端Web》
gleams:http