- Redis 有哪些危险命令?如何防范?
花小疯
redis缓存数据库危险命令大数据
Redis有哪些危险命令?Redis的危险命令主要有以下几个:1.keys客户端可查询出所有存在的键。2.flushdb删除Redis中当前所在数据库中的所有记录,并且此命令从不会执行失败。3.flushall删除Redis中所有数据库中的所有记录,不止是当前所在数据库,并且此命令从不会执行失败。4.config客户端可修改Redis配置。怎么禁用和重命名危险命令?看下redis.conf默认配置
- docker快速部署Redis、MySQL、Nginx
ChanChan__
Linuxdockerredismysqlnginxlinux服务器微服务
文章目录docker部署redisdocker部署mysqldocker部署nginxdocker部署redis拉取镜像dockerpullredis:7.0.10拷贝一份redis.conf文件复制到/home/ubuntu/redis文件夹下,修改redis.conf配置文件vimredis.conf-----------------------------------------------
- Redis配置
collman
Redisredis数据库缓存
redis配置管理可以直接打开配置文件进行查看和修改,也可以通过config命令来进行查看和修改。配置文件位置Linux中默认在/etc/redis/redis.conf。Windows中默认在安装目录下,名为redis.windows.conf。查看redis配置使用redis-cli连接redis后,就可以使用config命令对redis配置进行查看与修改操作了。查看某个配置项的值:127.0
- Redis 的内存淘汰策略详解
半桶水专家
Redisredis数据库缓存
内存淘汰策略配置方式要配置Redis的内存淘汰策略,可以通过修改Redis配置文件redis.conf或者在运行时通过命令行直接设置。以下是配置淘汰策略的两种方法:方法1:修改redis.conf配置文件找到并打开Redis的配置文件redis.conf。这个文件通常位于Redis安装目录下。找到maxmemory和maxmemory-policy选项。默认情况下,这些选项可能被注释掉了(前面有#
- Redis使用——Redis的redis.conf配置注释详解(三)
武昌库里写JAVA
面试题汇总与解析springlog4jjava开发语言算法
Redis使用——Redis的redis.conf配置注释详解(三)背景日常我们开发时,我们会遇到各种各样的奇奇怪怪的问题(踩坑o(╯□╰)o),这个常见问题系列就是我日常遇到的一些问题的记录文章系列,这里整理汇总后分享给大家,让其还在深坑中的小伙伴有绳索能爬出来。同时在这里也欢迎大家把自己遇到的问题留言或私信给我,我看看其能否给大家解决。开发环境系统:Ubuntu工具:Docker镜像:Redi
- 远程链接腾讯云Redis-遇到的坑
__Jack
redisrediscentos7腾讯云
开门见山:1、配置腾讯安全组(不用重启机器):首先找到默认的安全组:一个实例必须有一个安全组,即这个。点进去,就会进入安全组下全部的安全策略,根据需要配置:2、更改Redis配置redis.conf:注意:1、一定找到启动Redis对应的redis.conf,不然更改没用。(按照网上给的安装方法,启动的redis.conf有时不是安装目录下的那个)2、全局搜索“bind”关键字,一定找全bind后
- Redis的KeyExpirationEventMessageListener键过期监听器
立小言先森
【Redis系列】【每日扫盲】【spring系列】redis缓存发布订阅通道过期监听器
MessageListener通过监听key过期的Rediskeyspace通知,然后通过ApplicationEventPublisher发布RedisKeyExpiredEvent事件的模式进行事件监听和广播。redis.conf地址:https://github.com/redis/redis/blob/unstable/redis.confRedis官方地址:https://redis.i
- 连接Redis报错:connect timed out
不会起名啊
redis
连接Redis报错:connecttimedout1、将redis.conf配置文件中的bind127.0.0.1注释掉,此处限制可以链接redis的ip2、如果上一个方法不行,就应该是Linux的防火墙的问题了我这里用的是CentOS7,在CentOS7中默认使用firewall做为防火墙,下面是启动&关闭防火墙的命令://启动firewallsystemctlstartfirewalld.se
- Docker启动Redis容器时报错WARNING: The TCP backlog setting of 511 cannot be enforced
板凳的爸爸
dockerredistcp/ip
正常使用命令dockerpullredis之后启动dockerrun--namem-redis-p8379:6379-v/data/redis/redis.conf:/usr/local/etc/redis/redis.conf-dredis发现容器并没有启动,于是查看了一下logs[root@localhostredis]#dockerlogsm-redis1:C25Sep202304:03:4
- Redis 内存淘汰策略
妖怪兮诺
数据库redisbootstrapjava
Redis的内存淘汰策略只有在运行内存达到了配置的最大内存阈值时才会触发,这个阈值是通过redis.conf的maxmemory参数来定义的。64位操作系统下,maxmemory默认为0,表示不限制内存大小。32位操作系统下,默认的最大内存值是3GB。你可以使用命令configgetmaxmemory来查看maxmemory的值。configgetmaxmemorymaxmemory0Redis提
- dockers拉取MySQL及Redis并挂载文件
好运——
mysqlredis数据库
目录一.MySQL拉取1、进入MySQL容器内部。2、登录MySQL。3、修改远程连接4、刷新二.Redis拉取1.redis/conf中新建文件redis.conf,内容如下:2.容器运行一.MySQL拉取dockerrun-d--restart=always--namemysql\-v/root/mysql/data:/var/lib/mysql\-v/root/mysql/conf:/etc
- redis
u011013840
redis数据库缓存
wgethttp://download.redis.io/releases/redis-5.0.5.tar.gztar-zxvfredis-5.0.5.tar.gz进入解压后的文件目录使用make命令进行编译进入src文件执行makeinstall安装redis在src目录执行./redis-server…/redis.conf即可启动redis
- Redis主从集群
钗头风
redis数据库缓存
一.架构模式二.资源分布操作系统:Centos7Redis版本:6.2.14IP端口角色192.168.157.1306379master192.168.157.1316379slave1192.168.157.1326379slave2三.流程1.创建三台虚拟机IP及端口如上且安装好Reids说明:安装好Redis的意思是无需额外配置;Redis能正常启动即可2.修改三个redis.conf配置
- Docker容器创建命令汇总
晓倾城
dockerdocker容器redis
redisdockerrun-p6379:6379--nameredis-01--netmy-tomcat-net--ip=-v/root/mk-backsystem/redis/conf/redis.conf:/etc/redis/redis.conf-v/root/mk-backsystem/redis/data:/data-dredis:busterredis-server/etc/redi
- 解决:docker创建Redis容器成功,但无法启动Redis容器、也无报错提示
ideal-cs
解决dockerredis容器无法启动Redis容器Redis容器无报错Redis容器无法启动
解决:docker创建Redis容器成功,但无法启动Redis容器、也无报错提示一·问题描述:1.docker若是直接简单使用run命令,但不挂载容器数据卷等参数,则可以启动Redis容器2.docker复杂使用run命令,使用指定redis.conf文件后台启动Redis服务、且挂载容器数据卷时,容器创建成功,但是永远无法启动Redis容器二·问题原因:1.docker容器里面,如果进程都是守护
- 如何使用idea连通服务器上的Redis(详细版本)
Zane:)
redis
这里我使用的是阿里云的服务器打开阿里云的安全组,设置端口为6379在redis.conf文件中,注释bind127.0.0.1将protected-mode设置为no,即关闭保护模式更改服务器中的防火墙,放行6379端口#放行端口firewall-cmd--zone=public--add-port=6379/tcp--permanent#重启防火墙systemctlrestartfirewall
- 外部链接redis服务器要修改配置
Kevin0is0me
sudovi/etc/redis/redis.conf参考redis网页课件然后下面两步和网页课件不同:1把bind=。。注释2把protected-modeyes改成protected-modeno
- 【生产实测可用】Redis修改集群弱口令
白-胖-子
运维常见问题自动化运维redisbootstrap前端
起因漏扫redis连接发现弱口令需要修改先连上去看看是空口令还是弱口令redis-cli-p6379-ha.b.c.dinfosentinel找到启动服务器的配置文件cp-av/app/redis-7001/redis.conf/app/redis-7001/redis.conf.bak20240207echo"requirepass口令">>/app/redis-7001/redis.conf主
- Redis.conf 配置文件解读
Yield & Allure
redisjava数据库
1、单位容量单位不区分大小写,G和GB没有区别配置文件unit单位对大小写不敏感2、组合配置可以使用include组合多个配置问题3、网络配置bind127.0.0.1#绑定的ipprotected-modeyes#保护模式port6379#端口设置4、通用GENERALdaemonizeyes#以守护进程的方式运行,默认是no,我们需要自己开启为yes!pidfile/var/run/redis
- rediss集群 三主三从集群模式
30醒悟的码农
redis
三主三从集群模式1)、新建redis集群目录:7001~7006工作目录【/app/soft/redis-cluster/目下】2)、在7001~7006目录下创建bin和conf目录,然后将/app/soft/redis/bin目录下的文件分别拷贝到7001~7006目录,然后在7001~7006目录conf文件夹创建redis.conf文件。修改配置文件:include/app/soft/re
- Redis AOF持久化
周_0717
AOF持久化本质是采用日志的形式来记录每个写操作,并追加到对应的.aof文件中。Redis重启的会根据日志文件的内容将写指令从前到后执行一次以完成数据的恢复工作,会忽略掉RDB存储载入。Redis服务默认没有开启AOF功能,打开redis.conf文件,找到APPENDONLYMODE对应内容:1)修改appendonly值为yes;2)修改appendfilename指定本地数据库文件名,默认值
- centos7.2安装redis
ouxinde
服务器运维linux经验分享后端
Redis安装和启动cdusr/localwgethttp://download.redis.io/releases/redis-5.0.5.tar.gztarxzfredis-5.0.5.tar.gzcdredis-5.0.5makeviredis.conf------daemonizeyescdsrc./redis-server../redis.conf启动Redis配置vimredis.co
- 启动redis服务
大碗扣肉真香
学习笔记javaredis数据库
一、默认redis.conf文件没修改的话1、直接进入默认路径目录cd/usr/local/redis2、开启服务redis-serverredis.conf3、关闭服务redis-clishutdown二、更改redis.conf,如果不知道自己的redis.conf文件在哪1、可以全局搜索一下find-nameredis.conf2、进入到redis.conf所在目录cd/softwares/
- resp连接redis服务器
小胖鲸~
数据库redis服务器数据库
修改redis的配置文件使得windows的图形界面客户端可以连接redis服务器resp安装好以后,可以在linux端打开redis.conf中做以下操作,使得windows的图形界面客户端可以连接redis服务器方法一:1,在redis.conf文件中添加bind在文件redis.conf中添加bind=0.0.0.02,重启redis服务systemctlrestartredis(3)重新连
- Redis系列三:thinkphp 使用 redis
Ajekseg
javajava后端
1、redis服务端配置认证密码(1)通过配置文件进行配置打开配置文件/usr/local/redis/etc/redis.conf找到#requirepassfoobared去掉行前的注释,并修改密码为所需的密码,保存文件requirepassmyRedis重启redis这个时候尝试登录redis,发现可以登上,但是执行具体命令是提示操作不允许1.redis-cli-h127.0.0.1-p63
- linux系统非关系型数据库redis的配置文件
丨析木丨
linuxlinuxnosqlredis
redis配置文件Redis的配置文件位于Redis安装目录下,文件名为redis.conf,配置项说明如下Redis默认不是以守护进程的方式运行,可以通过该配置项修改,使用yes启用守护进程daemonizeno当Redis以守护进程方式运行时,Redis默认会把pid写入/var/run/redis.pid文件,可以通过pidfile指定pidfile/var/run/redis.pid指定R
- redis在mac中的安装
煮茶听雨
采用brew安装brewinstallredisimage.png按照提示,开机启动服务,执行brewservicesstartredis如果不需要后台运行redis-server/usr/local/etc/redis.conf配置文件位置:/usr/local/etc/redis.conf打开redis客户端:redis-cli参考redis配置#修改为守护模式daemonizeyes#设置进
- 已经设置密码的情况下连接不上linux下redis服务的,解决办法
臣妾写不来啊
linuxredisjava
1.服务器防火墙请放行端口6379systemctlstartfirewalld.servicefirewall-cmd--add-port=6379/tcp--permanentfirewall-cmd--reload3.修改redis的配置文件打开redis配置文件redis.conf进行编辑,修改一些参数将bind127.0.0.1修改为bind0.0.0.0,原因是bind127.0.0.
- Windows 安装Redis
诗雅颂
rediswindows数据库
Windows下安装Redis详细的操作流程和案例:下载Redis:访问Redis官方网站(https://redis.io/)。在"Download"页面中选择适合你操作系统的稳定版本并下载。解压Redis安装包:找到下载的Redis安装包文件,将其解压到目标文件夹中。配置Redis:进入Redis解压后的文件夹,在该目录下找到redis.conf文件,并使用文本编辑器(如Notepad++、S
- Redis(三)主从架构、Redis哨兵架构、Redis集群方案对比、Redis高可用集群搭建、Redis高可用集群之水平扩展
_蓝天IT_
分布式redis架构java
转自极客时间Redis主从架构redis主从架构搭建,配置从节点步骤:1、复制一份redis.conf文件2、将相关配置修改为如下值:port6380pidfile/var/run/redis_6380.pid#把pid进程号写入pidfile配置的文件logfile"6380.log"dir/usr/local/redis-5.0.3/data/6380#指定数据存放目录#需要注释掉bind#b
- ASM系列五 利用TreeApi 解析生成Class
lijingyao8206
ASM字节码动态生成ClassNodeTreeAPI
前面CoreApi的介绍部分基本涵盖了ASMCore包下面的主要API及功能,其中还有一部分关于MetaData的解析和生成就不再赘述。这篇开始介绍ASM另一部分主要的Api。TreeApi。这一部分源码是关联的asm-tree-5.0.4的版本。
在介绍前,先要知道一点, Tree工程的接口基本可以完
- 链表树——复合数据结构应用实例
bardo
数据结构树型结构表结构设计链表菜单排序
我们清楚:数据库设计中,表结构设计的好坏,直接影响程序的复杂度。所以,本文就无限级分类(目录)树与链表的复合在表设计中的应用进行探讨。当然,什么是树,什么是链表,这里不作介绍。有兴趣可以去看相关的教材。
需求简介:
经常遇到这样的需求,我们希望能将保存在数据库中的树结构能够按确定的顺序读出来。比如,多级菜单、组织结构、商品分类。更具体的,我们希望某个二级菜单在这一级别中就是第一个。虽然它是最后
- 为啥要用位运算代替取模呢
chenchao051
位运算哈希汇编
在hash中查找key的时候,经常会发现用&取代%,先看两段代码吧,
JDK6中的HashMap中的indexFor方法:
/**
* Returns index for hash code h.
*/
static int indexFor(int h, int length) {
- 最近的情况
麦田的设计者
生活感悟计划软考想
今天是2015年4月27号
整理一下最近的思绪以及要完成的任务
1、最近在驾校科目二练车,每周四天,练三周。其实做什么都要用心,追求合理的途径解决。为
- PHP去掉字符串中最后一个字符的方法
IT独行者
PHP字符串
今天在PHP项目开发中遇到一个需求,去掉字符串中的最后一个字符 原字符串1,2,3,4,5,6, 去掉最后一个字符",",最终结果为1,2,3,4,5,6 代码如下:
$str = "1,2,3,4,5,6,";
$newstr = substr($str,0,strlen($str)-1);
echo $newstr;
- hadoop在linux上单机安装过程
_wy_
linuxhadoop
1、安装JDK
jdk版本最好是1.6以上,可以使用执行命令java -version查看当前JAVA版本号,如果报命令不存在或版本比较低,则需要安装一个高版本的JDK,并在/etc/profile的文件末尾,根据本机JDK实际的安装位置加上以下几行:
export JAVA_HOME=/usr/java/jdk1.7.0_25  
- JAVA进阶----分布式事务的一种简单处理方法
无量
多系统交互分布式事务
每个方法都是原子操作:
提供第三方服务的系统,要同时提供执行方法和对应的回滚方法
A系统调用B,C,D系统完成分布式事务
=========执行开始========
A.aa();
try {
B.bb();
} catch(Exception e) {
A.rollbackAa();
}
try {
C.cc();
} catch(Excep
- 安墨移动广 告:移动DSP厚积薄发 引领未来广 告业发展命脉
矮蛋蛋
hadoop互联网
“谁掌握了强大的DSP技术,谁将引领未来的广 告行业发展命脉。”2014年,移动广 告行业的热点非移动DSP莫属。各个圈子都在纷纷谈论,认为移动DSP是行业突破点,一时间许多移动广 告联盟风起云涌,竞相推出专属移动DSP产品。
到底什么是移动DSP呢?
DSP(Demand-SidePlatform),就是需求方平台,为解决广 告主投放的各种需求,真正实现人群定位的精准广
- myelipse设置
alafqq
IP
在一个项目的完整的生命周期中,其维护费用,往往是其开发费用的数倍。因此项目的可维护性、可复用性是衡量一个项目好坏的关键。而注释则是可维护性中必不可少的一环。
注释模板导入步骤
安装方法:
打开eclipse/myeclipse
选择 window-->Preferences-->JAVA-->Code-->Code
- java数组
百合不是茶
java数组
java数组的 声明 创建 初始化; java支持C语言
数组中的每个数都有唯一的一个下标
一维数组的定义 声明: int[] a = new int[3];声明数组中有三个数int[3]
int[] a 中有三个数,下标从0开始,可以同过for来遍历数组中的数
- javascript读取表单数据
bijian1013
JavaScript
利用javascript读取表单数据,可以利用以下三种方法获取:
1、通过表单ID属性:var a = document.getElementByIdx_x_x("id");
2、通过表单名称属性:var b = document.getElementsByName("name");
3、直接通过表单名字获取:var c = form.content.
- 探索JUnit4扩展:使用Theory
bijian1013
javaJUnitTheory
理论机制(Theory)
一.为什么要引用理论机制(Theory)
当今软件开发中,测试驱动开发(TDD — Test-driven development)越发流行。为什么 TDD 会如此流行呢?因为它确实拥有很多优点,它允许开发人员通过简单的例子来指定和表明他们代码的行为意图。
TDD 的优点:
&nb
- [Spring Data Mongo一]Spring Mongo Template操作MongoDB
bit1129
template
什么是Spring Data Mongo
Spring Data MongoDB项目对访问MongoDB的Java客户端API进行了封装,这种封装类似于Spring封装Hibernate和JDBC而提供的HibernateTemplate和JDBCTemplate,主要能力包括
1. 封装客户端跟MongoDB的链接管理
2. 文档-对象映射,通过注解:@Document(collectio
- 【Kafka八】Zookeeper上关于Kafka的配置信息
bit1129
zookeeper
问题:
1. Kafka的哪些信息记录在Zookeeper中 2. Consumer Group消费的每个Partition的Offset信息存放在什么位置
3. Topic的每个Partition存放在哪个Broker上的信息存放在哪里
4. Producer跟Zookeeper究竟有没有关系?没有关系!!!
//consumers、config、brokers、cont
- java OOM内存异常的四种类型及异常与解决方案
ronin47
java OOM 内存异常
OOM异常的四种类型:
一: StackOverflowError :通常因为递归函数引起(死递归,递归太深)。-Xss 128k 一般够用。
二: out Of memory: PermGen Space:通常是动态类大多,比如web 服务器自动更新部署时引起。-Xmx
- java-实现链表反转-递归和非递归实现
bylijinnan
java
20120422更新:
对链表中部分节点进行反转操作,这些节点相隔k个:
0->1->2->3->4->5->6->7->8->9
k=2
8->1->6->3->4->5->2->7->0->9
注意1 3 5 7 9 位置是不变的。
解法:
将链表拆成两部分:
a.0-&
- Netty源码学习-DelimiterBasedFrameDecoder
bylijinnan
javanetty
看DelimiterBasedFrameDecoder的API,有举例:
接收到的ChannelBuffer如下:
+--------------+
| ABC\nDEF\r\n |
+--------------+
经过DelimiterBasedFrameDecoder(Delimiters.lineDelimiter())之后,得到:
+-----+----
- linux的一些命令 -查看cc攻击-网口ip统计等
hotsunshine
linux
Linux判断CC攻击命令详解
2011年12月23日 ⁄ 安全 ⁄ 暂无评论
查看所有80端口的连接数
netstat -nat|grep -i '80'|wc -l
对连接的IP按连接数量进行排序
netstat -ntu | awk '{print $5}' | cut -d: -f1 | sort | uniq -c | sort -n
查看TCP连接状态
n
- Spring获取SessionFactory
ctrain
sessionFactory
String sql = "select sysdate from dual";
WebApplicationContext wac = ContextLoader.getCurrentWebApplicationContext();
String[] names = wac.getBeanDefinitionNames();
for(int i=0; i&
- Hive几种导出数据方式
daizj
hive数据导出
Hive几种导出数据方式
1.拷贝文件
如果数据文件恰好是用户需要的格式,那么只需要拷贝文件或文件夹就可以。
hadoop fs –cp source_path target_path
2.导出到本地文件系统
--不能使用insert into local directory来导出数据,会报错
--只能使用
- 编程之美
dcj3sjt126com
编程PHP重构
我个人的 PHP 编程经验中,递归调用常常与静态变量使用。静态变量的含义可以参考 PHP 手册。希望下面的代码,会更有利于对递归以及静态变量的理解
header("Content-type: text/plain");
function static_function () {
static $i = 0;
if ($i++ < 1
- Android保存用户名和密码
dcj3sjt126com
android
转自:http://www.2cto.com/kf/201401/272336.html
我们不管在开发一个项目或者使用别人的项目,都有用户登录功能,为了让用户的体验效果更好,我们通常会做一个功能,叫做保存用户,这样做的目地就是为了让用户下一次再使用该程序不会重新输入用户名和密码,这里我使用3种方式来存储用户名和密码
1、通过普通 的txt文本存储
2、通过properties属性文件进行存
- Oracle 复习笔记之同义词
eksliang
Oracle 同义词Oracle synonym
转载请出自出处:http://eksliang.iteye.com/blog/2098861
1.什么是同义词
同义词是现有模式对象的一个别名。
概念性的东西,什么是模式呢?创建一个用户,就相应的创建了 一个模式。模式是指数据库对象,是对用户所创建的数据对象的总称。模式对象包括表、视图、索引、同义词、序列、过
- Ajax案例
gongmeitao
Ajaxjsp
数据库采用Sql Server2005
项目名称为:Ajax_Demo
1.com.demo.conn包
package com.demo.conn;
import java.sql.Connection;import java.sql.DriverManager;import java.sql.SQLException;
//获取数据库连接的类public class DBConnec
- ASP.NET中Request.RawUrl、Request.Url的区别
hvt
.netWebC#asp.nethovertree
如果访问的地址是:http://h.keleyi.com/guestbook/addmessage.aspx?key=hovertree%3C&n=myslider#zonemenu那么Request.Url.ToString() 的值是:http://h.keleyi.com/guestbook/addmessage.aspx?key=hovertree<&
- SVG 教程 (七)SVG 实例,SVG 参考手册
天梯梦
svg
SVG 实例 在线实例
下面的例子是把SVG代码直接嵌入到HTML代码中。
谷歌Chrome,火狐,Internet Explorer9,和Safari都支持。
注意:下面的例子将不会在Opera运行,即使Opera支持SVG - 它也不支持SVG在HTML代码中直接使用。 SVG 实例
SVG基本形状
一个圆
矩形
不透明矩形
一个矩形不透明2
一个带圆角矩
- 事务管理
luyulong
javaspring编程事务
事物管理
spring事物的好处
为不同的事物API提供了一致的编程模型
支持声明式事务管理
提供比大多数事务API更简单更易于使用的编程式事务管理API
整合spring的各种数据访问抽象
TransactionDefinition
定义了事务策略
int getIsolationLevel()得到当前事务的隔离级别
READ_COMMITTED
- 基础数据结构和算法十一:Red-black binary search tree
sunwinner
AlgorithmRed-black
The insertion algorithm for 2-3 trees just described is not difficult to understand; now, we will see that it is also not difficult to implement. We will consider a simple representation known
- centos同步时间
stunizhengjia
linux集群同步时间
做了集群,时间的同步就显得非常必要了。 以下是查到的如何做时间同步。 在CentOS 5不再区分客户端和服务器,只要配置了NTP,它就会提供NTP服务。 1)确认已经ntp程序包: # yum install ntp 2)配置时间源(默认就行,不需要修改) # vi /etc/ntp.conf server pool.ntp.o
- ITeye 9月技术图书有奖试读获奖名单公布
ITeye管理员
ITeye
ITeye携手博文视点举办的9月技术图书有奖试读活动已圆满结束,非常感谢广大用户对本次活动的关注与参与。 9月试读活动回顾:http://webmaster.iteye.com/blog/2118112本次技术图书试读活动的优秀奖获奖名单及相应作品如下(优秀文章有很多,但名额有限,没获奖并不代表不优秀):
《NFC:Arduino、Andro