- Spring Cache的基本使用
奇怪的大象
面试学习路线阿里巴巴springjava后端
文章目录一、概述二、SpringCache的使用2.1环境搭建2.2缓存的读模式@Cacheable2.3自定义缓存配置
[email protected]@CacheEvict删除缓存2.6@Caching多个操作三、SpringCache的不足一、概述常见的缓存的框架有Redis、Memcached、Guava、Caffeine等等,各有各的优势。如果我们的程序想要使用缓存,就要与这些框架耦合。聪明
- 我与DeepSeek读《大型网站技术架构》(3)
诺亚凹凸曼
架构
大型网站架构的核心要素《大型网站技术架构:核心原理与案例分析》第三章聚焦于大型网站架构的核心要素,从技术维度剖析了构建高可用、高性能、可扩展系统的关键设计方向。1.五大核心架构要素(1)性能(Performance)目标:快速响应用户请求,优化用户体验。关键策略:前端优化:CDN加速静态资源、合并压缩JS/CSS、浏览器缓存。服务端优化:缓存(Redis/Memcached)、异步处理(消息队列)
- 如何实现集群中的session共享存储?思维导图 代码示例(java 架构)
用心去追梦
java架构开发语言
集群中Session共享存储的实现在分布式系统或集群环境中,确保用户会话(Session)能够在所有节点之间共享是一个关键问题。为了实现这一点,可以采用多种策略和技术。以下是关于如何在Java架构中实现集群中的Session共享存储的主要方面:1.使用集中式存储服务Memcached:轻量级、高性能的内存缓存系统,适用于存储短期的session数据。Redis:功能更强大的键值存储数据库,不仅支持
- 如何自定义协议
kshzhaohui
后端java
前言何为自定义协议,其实是相对标准协议来说的,这里主要针对的是应用层协议;常见的标准的应用层协议如http、ftp、smtp等,如果我们在网络通信的过程中不去使用这些标准协议,那就需要自定义协议,比如我们常用的RPC框架(dubbo,thrift),分布式缓存(redis,memcached)等都是自定义协议;本文就来讲讲如何去自定义私有协议,在此之前我们先考虑一下为什么要自定义协议。为什么要自定
- memcached的cache机制是怎样的?思维导图 代码示例(java 架构)
用心去追梦
memcachedjava架构
Memcached的缓存机制Memcached的缓存机制围绕着其作为高性能分布式内存对象缓存系统的核心功能展开。以下是关于Memcached缓存机制的主要方面:1.数据存储与检索键值对存储:所有数据都以键值对的形式存储,键是唯一的字符串标识符,值可以是任意类型的数据。SlabAllocator(分配器):Memcached使用SlabAllocator来管理内存,它将内存分割成不同大小的“slab
- 探索高效缓存:FastAPI-Cache 开源库解析与应用
韩烨琰
探索高效缓存:FastAPI-Cache开源库解析与应用项目地址:https://gitcode.com/gh_mirrors/fa/fastapi-cache在构建高性能的Web应用程序时,缓存机制是必不可少的一环。今天,我们要介绍一款专门为FastAPI框架设计的缓存工具——FastAPI-Cache。它提供了一种简单且灵活的方式,让你能够轻松地将Redis、Memcached或AmazonD
- 高效API开发:FastAPI中的缓存技术与性能优化
Switch616
PythonWebfastapi缓存性能优化负载均衡python
高效API开发:FastAPI中的缓存技术与性能优化目录使用缓存优化性能:Redis与Memcached设计合适的缓存策略基于请求结果的缓存与数据库缓存1.使用缓存优化性能:Redis与Memcached缓存技术在高并发Web应用中起着至关重要的作用,能够显著提高API的响应速度,降低数据库的压力,改善系统的整体性能。在PythonWeb开发中,常见的缓存技术包括Redis和Memcached,它
- Java必知必会系列:缓存技术与Memcached
AI天才研究院
Java实战编程实践大数据人工智能语言模型JavaPython架构设计
作者:禅与计算机程序设计艺术文章目录1.简介2.缓存技术及其相关概念2.1什么是缓存?2.2Memcached简介2.3Memcached核心机制2.4Memcached常见错误类型3.Memcached基本操作3.1安装Memcached3.2Memcached操作添加键值对删除键值对更新键值对查询多个键管理缓存空间4.Memcached应用场景4.1Session共享4.2全页缓存4.3对象缓
- 如何将memcached中item批量导入导出?思维导图 代码示例(java 架构)
用心去追梦
memcachedjava架构
Memcached中Item的批量导入导出Memcached本身并没有直接提供用于批量导入和导出数据的工具或命令。然而,通过编程手段可以实现这一功能。以下是关于如何将Memcached中的Item进行批量导入和导出的方法和技术:1.批量导出(Dump)遍历所有键:由于Memcached不支持直接枚举所有的键,因此需要事先记录下所有的键,或者在应用程序层面维护一个键的列表。逐个获取值:使用客户端库提
- 在CentOS7上部署Memcached高性能内存缓存对象
weixin_34138377
概述Memcached是一套开源的高性能分布式内存对象缓存系统,它将所有的数据都存储在内存中,因为在内存中会统一维护一张巨大的Hash表,所以支持任意存储类型的数据。Memcached是典型的C/S架构,因此需要安装Memcached服务端与MemcachedAPI客户端。Memcached服务端是用C语言编写的,而MemcachedAPI客户端可以用任何语言来编写。常用典型架构如图所示:当Web
- Java面试八股文:Memcached面试题专场(持续更新中......)
Java凤梨
Java金三银四面试题memcachedjava面试
全套Java金三银四面试题持续更新可文末自取,建议关注收藏不然下次找不到哟~目录1、Memcached是什么,有什么作用?memcached服务在企业集群架构中有哪些应用场景?一、作为数据库的前端缓存应用二、作业集群的session会话共享存储。2、Memcached服务分布式集群如何实现?3、Memcached服务特点及工作原理是什么?4、简述Memcached内存管理机制原理?SlabAllo
- Memcached服务器UDP反射放大攻击
weixin_30639719
memcached网络操作系统
1、前言2月28日,Memcache服务器被曝出存在UDP反射放大攻击漏洞。攻击者可利用这个漏洞来发起大规模的DDoS攻击,从而影响网络正常运行。漏洞的形成原因为Memcache服务器UDP协议支持的方式不安全、默认配置中将UDP端口暴露给外部链接。2、原理分析这个漏洞的攻击方式属于DRDOS(DistributedReflectionDenialofService)分布式反射拒绝服务攻击。DRD
- 出现几率比较大的Redis面试题(含答案)
着火点
后端redis数据库缓存java后端
本文的面试题如下:Redis持久化机制缓存雪崩、缓存穿透、缓存预热、缓存更新、缓存降级等问题热点数据和冷数据是什么Memcache与Redis的区别都有哪些?单线程的redis为什么这么快redis的数据类型,以及每种数据类型的使用场景,Redis内部结构redis的过期策略以及内存淘汰机制【~】Redis为什么是单线程的,优点如何解决redis的并发竞争key问题Redis集群方案应该怎么做?都
- 分布式数据库面试整理
Necther
数据库面试分布式
5.3.1redis面试专题1、redis和memcached什么区别?为什么高并发下有时单线程的redis比多线程的memcached效率要高?区别:mc可缓存图片和视频。rd支持除k/v更多的数据结构;rd可以使用虚拟内存,rd可持久化和aof灾难恢复,rd通过主从支持数据备份;3.rd可以做消息队列。原因:mc多线程模型引入了缓存一致性和锁,加锁带来了性能损耗。2、redis主从复制如何实现
- Redis 高频面试题与核心知识点解析
java
一、Redis基础概念Redis是什么?有哪些特点?Redis是一个开源的、基于内存的数据结构存储系统,可用于数据库、缓存和消息中间件。特点:高性能(10万+QPS)、单线程模型(6.0后支持多线程IO)、持久化、支持事务、发布订阅等。Redis与Memcached的区别?Redis支持更丰富的数据类型,Memcached仅支持字符串。Redis支持持久化,Memcached纯内存。Redis单线
- 【面试宝典】Java八股文之Redis面试题
SoftwareDevOps
面试宝典(持续更新中)redisjava面试八股文数据库
Redis面试题1、什么是Redis?2、Redis与其他key-value存储有什么不同?3、Redis的数据类型?4、使用Redis有哪些好处?5、Redis相比Memcached有哪些优势?6、Memcache与Redis的区别都有哪些?7、Redis是单进程单线程的?8、一个字符串类型的值能存储最大容量是多少?9、Redis持久化机制10、RDB11、AOF12、缓存雪崩13、缓存穿透14
- nginx+php+memcache高速缓存openresty)_nginx+php使用memcache
大厂在职_Xbg
nginxphpmemcached
- 分布式数据库缓存的基本概念?MemCache和redis的详细比较?
mischen520
软考高级系统架构师分布式缓存框架缓存redis数据库
分布式数据库缓存指的是在高并发环境下,为了减轻数据库压力和提高系统响应时间,在数据库系统和应用系统之间增加的独立缓存系统。目前市场上常见的数据库缓存系统是MemChace和Redis,他们的主要区别如下:MemChace:数据类型是简单的key/value结构,不支持持久性,分布式存储为客户端哈希分片/一致性哈希,支持多线程,内存管理为私有内存池/内存池,不支持事务管理Redis:丰富的数据结构,
- 《集群、权重、时间戳回眸一识》
杨晓风-linda
数据库
人物:王浩田时间:2016年9月11日地点:万达二楼玻璃屋主题:memcached分布式存储开篇之言通过演讲者王浩田在讲述的过程中,我发现有几个名词是之前听过但并未了解的新鲜事物,特写此篇来浅析集群、权重、时间戳三者✿集群✿一组相互独立的、通过高速的网络互联的计算机,都成一个组且以单一系统的模式加以管理。本质:计算机核心:任务调度调度方式:进程迁移类别:科学;负载均衡;高可用性;关键技术:网络层;
- web集群-负载均衡集群-Nginx
xx_01_2048769943
web集群
nginx简介Nginx的官网http://nginx.org/en/基本特性可针对静态资源高速高并发访问及缓存。可使用反向代理加速,并且可进行数据缓存。具有简单负载均衡、节点健康检查和容错功能。支持远程FastCGI服务的缓存加速。支持FastCGI、Uwsgi、SCGI、MemcachedServers的加速和缓存。支持SSL、TLS、SNI。具有模块化的架构:过滤器包括gzip压缩、rang
- 缓存的多种实现方式
养生编程大队长
Java学习缓存
1.谷歌的guava包下面的Cache,基于内存的缓存2.自定义缓存,例如使用静态Map实现3.分布式缓存redis,memcached4.EHcache
- 缓存技术有哪些实现的方法呢?【缓存技术汇总】
不起眼的Coder
scikit-learn
缓存技术是一种常用的提高系统性能和响应速度的方法。作为网站开发者,真的是必用的提速方法了。今天,我们总结下常用的缓存技术有哪些。以下是常见的缓存实现方法:内存缓存内存缓存是将数据缓存在内存中,以提高访问速度。常见的内存缓存技术包括Memcached、Redis等。文件缓存文件缓存是将数据缓存在文件中,以减轻数据库的负载。常见的文件缓存技术包括APC、ZendOptimizer、eAccelerat
- memcached是怎么工作的?思维导图 代码示例(java 架构)
用心去追梦
memcachedjava架构
Memcached是怎么工作的?Memcached的工作原理围绕着其作为高性能分布式内存对象缓存系统的核心功能展开。以下是关于Memcached工作流程的详细解析:1.客户端请求处理客户端连接:应用程序通过网络与一个或多个Memcached服务器建立TCP连接。命令执行:客户端发送简单的文本协议命令(如set,get,delete等)到Memcached服务器来存储或检索数据。2.数据存储机制Sl
- 如果缓存数据在导出导入之间过期了,您又怎么处理这些数据呢?思维导图 代码示例(java 架构)
用心去追梦
memcachedjava架构
处理导出导入之间缓存数据过期的问题当Memcached中的数据在导出和重新导入之间过期时,可能会导致恢复的数据不完整或丢失。为了确保数据的一致性和完整性,可以采取以下策略和技术来处理这种情况:1.记录TTL信息保存TTL:在导出数据时,不仅记录键值对本身,还应该同时保存每个键的生存时间(TTL),以便在恢复时能够正确设置。相对时间戳:使用相对的时间戳而不是绝对时间戳来表示TTL,这样即使系统时间不
- 【面试题】构建高并发、高可用服务架构:技术选型与设计
言之。
redispython面试架构
监控系统消息队列缓存层数据存储层应用层Web层负载均衡与流量分配GrafanaPrometheusAlertmanager消息队列Kafka/RabbitMQ集群/镜像队列缓存层Redis/Memcached数据库MySQL/PostgreSQL主从复制/主主复制应用服务器SpringBoot/Node.js应用服务器SpringBoot/Node.js应用服务器SpringBoot/Node.j
- 2024Java面试-Redis常见面试题(1)
修罗debug
2024年java面积集第一季面试redis职场和发展javajava面试
给大家介绍下目前市面上Java方面Redis常见的面试题哈!1、什么是Redis?简述它的优缺点?Redis的全称是:RemoteDictionary.Server,本质上是一个Key-Value类型的内存数据库,很像memcached,整个数据库统统加载在内存当中进行操作,定期通过异步操作把数据库数据flush到硬盘上进行保存。因为是纯内存操作,Redis的性能非常出色,每秒可以处理超过10万次
- memcached的内存分配器是如何工作的?为什么不适用malloc/free!?为何要使用slabs?思维导图 代码示例(java 架构)
用心去追梦
memcachedjava架构
Memcached内存分配器工作原理Memcached使用了一种称为SlabAllocator的内存分配机制,它与传统的malloc/free不同。以下是关于为什么Memcached选择使用SlabAllocator而不是标准的内存分配方式的原因,以及其工作原理的关键点:1.SlabAllocator的优点减少碎片化:SlabAllocator通过预先分配固定大小的内存块(称为slabs),并将相
- 运维之道 | Nginx反向代理常用模块
VillianTsang
Nginx
Nginx反向代理常用模块一、Nginx反向代理upstream模块1、概念Nginx反向代理(又称负载均衡)功能,依赖于ngx_http_upstream_module模块,支持的代理方式有proxy_pass(一般用于反向代理)、fastcgi_pass(一般用于动态程序交互)、memcached_pass(一般用于NOSQL缓存代理)。反向代理:代理服务器接收外部连接请求,然后将请求转发给内
- Haproxy 负载均衡集群
weixin_34348805
|br0router192.168.29.128vip:192.168.29.128192.168.29.128/32修改内核参数servicehttpdstart测试:找宿主机http://192.168.29.128找同学去访问:确保它的电脑没有192.168.29.0/24网络却把把网关指向宿主机10网段的IP再去访问http://192.168.29.128三、部署memcached把机器
- 运维笔记43 使用saltstack配置完整线上服务(haproxy+keepalived,nginx+php+memcache,mysql主从)
No_red
运维学习mysql数据库web服务phpsaltstack
概述:之前我们所介绍过了很多实用的服务,有负载均衡类的,web服务类的,数据库类的等等,这些服务有的配置容易,有的配置困难,那我们现在设想一下在生成环境中,有上百台,甚至上千台服务器的情况下,难道要我们去挨个去配置每一台服务器吗,这是无法想象的,所以有了saltstack这类自动化运维工具的出现,帮助我们高效快速的部署服务。线上服务拓扑这次的拓扑基本上已经可以胜任一个相当活跃的服务的后端架构了,但
- java杨辉三角
3213213333332132
java基础
package com.algorithm;
/**
* @Description 杨辉三角
* @author FuJianyong
* 2015-1-22上午10:10:59
*/
public class YangHui {
public static void main(String[] args) {
//初始化二维数组长度
int[][] y
- 《大话重构》之大布局的辛酸历史
白糖_
重构
《大话重构》中提到“大布局你伤不起”,如果企图重构一个陈旧的大型系统是有非常大的风险,重构不是想象中那么简单。我目前所在公司正好对产品做了一次“大布局重构”,下面我就分享这个“大布局”项目经验给大家。
背景
公司专注于企业级管理产品软件,企业有大中小之分,在2000年初公司用JSP/Servlet开发了一套针对中
- 电驴链接在线视频播放源码
dubinwei
源码电驴播放器视频ed2k
本项目是个搜索电驴(ed2k)链接的应用,借助于磁力视频播放器(官网:
http://loveandroid.duapp.com/ 开放平台),可以实现在线播放视频,也可以用迅雷或者其他下载工具下载。
项目源码:
http://git.oschina.net/svo/Emule,动态更新。也可从附件中下载。
项目源码依赖于两个库项目,库项目一链接:
http://git.oschina.
- Javascript中函数的toString()方法
周凡杨
JavaScriptjstoStringfunctionobject
简述
The toString() method returns a string representing the source code of the function.
简译之,Javascript的toString()方法返回一个代表函数源代码的字符串。
句法
function.
- struts处理自定义异常
g21121
struts
很多时候我们会用到自定义异常来表示特定的错误情况,自定义异常比较简单,只要分清是运行时异常还是非运行时异常即可,运行时异常不需要捕获,继承自RuntimeException,是由容器自己抛出,例如空指针异常。
非运行时异常继承自Exception,在抛出后需要捕获,例如文件未找到异常。
此处我们用的是非运行时异常,首先定义一个异常LoginException:
/**
* 类描述:登录相
- Linux中find常见用法示例
510888780
linux
Linux中find常见用法示例
·find path -option [ -print ] [ -exec -ok command ] {} \;
find命令的参数;
- SpringMVC的各种参数绑定方式
Harry642
springMVC绑定表单
1. 基本数据类型(以int为例,其他类似):
Controller代码:
@RequestMapping("saysth.do")
public void test(int count) {
}
表单代码:
<form action="saysth.do" method="post&q
- Java 获取Oracle ROWID
aijuans
javaoracle
A ROWID is an identification tag unique for each row of an Oracle Database table. The ROWID can be thought of as a virtual column, containing the ID for each row.
The oracle.sql.ROWID class i
- java获取方法的参数名
antlove
javajdkparametermethodreflect
reflect.ClassInformationUtil.java
package reflect;
import javassist.ClassPool;
import javassist.CtClass;
import javassist.CtMethod;
import javassist.Modifier;
import javassist.bytecode.CodeAtt
- JAVA正则表达式匹配 查找 替换 提取操作
百合不是茶
java正则表达式替换提取查找
正则表达式的查找;主要是用到String类中的split();
String str;
str.split();方法中传入按照什么规则截取,返回一个String数组
常见的截取规则:
str.split("\\.")按照.来截取
str.
- Java中equals()与hashCode()方法详解
bijian1013
javasetequals()hashCode()
一.equals()方法详解
equals()方法在object类中定义如下:
public boolean equals(Object obj) {
return (this == obj);
}
很明显是对两个对象的地址值进行的比较(即比较引用是否相同)。但是我们知道,String 、Math、I
- 精通Oracle10编程SQL(4)使用SQL语句
bijian1013
oracle数据库plsql
--工资级别表
create table SALGRADE
(
GRADE NUMBER(10),
LOSAL NUMBER(10,2),
HISAL NUMBER(10,2)
)
insert into SALGRADE values(1,0,100);
insert into SALGRADE values(2,100,200);
inser
- 【Nginx二】Nginx作为静态文件HTTP服务器
bit1129
HTTP服务器
Nginx作为静态文件HTTP服务器
在本地系统中创建/data/www目录,存放html文件(包括index.html)
创建/data/images目录,存放imags图片
在主配置文件中添加http指令
http {
server {
listen 80;
server_name
- kafka获得最新partition offset
blackproof
kafkapartitionoffset最新
kafka获得partition下标,需要用到kafka的simpleconsumer
import java.util.ArrayList;
import java.util.Collections;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.
- centos 7安装docker两种方式
ronin47
第一种是采用yum 方式
yum install -y docker
 
- java-60-在O(1)时间删除链表结点
bylijinnan
java
public class DeleteNode_O1_Time {
/**
* Q 60 在O(1)时间删除链表结点
* 给定链表的头指针和一个结点指针(!!),在O(1)时间删除该结点
*
* Assume the list is:
* head->...->nodeToDelete->mNode->nNode->..
- nginx利用proxy_cache来缓存文件
cfyme
cache
user zhangy users;
worker_processes 10;
error_log /var/vlogs/nginx_error.log crit;
pid /var/vlogs/nginx.pid;
#Specifies the value for ma
- [JWFD开源工作流]JWFD嵌入式语法分析器负号的使用问题
comsci
嵌入式
假如我们需要用JWFD的语法分析模块定义一个带负号的方程式,直接在方程式之前添加负号是不正确的,而必须这样做:
string str01 = "a=3.14;b=2.71;c=0;c-((a*a)+(b*b))"
定义一个0整数c,然后用这个整数c去
- 如何集成支付宝官方文档
dai_lm
android
官方文档下载地址
https://b.alipay.com/order/productDetail.htm?productId=2012120700377310&tabId=4#ps-tabinfo-hash
集成的必要条件
1. 需要有自己的Server接收支付宝的消息
2. 需要先制作app,然后提交支付宝审核,通过后才能集成
调试的时候估计会真的扣款,请注意
- 应该在什么时候使用Hadoop
datamachine
hadoop
原帖地址:http://blog.chinaunix.net/uid-301743-id-3925358.html
存档,某些观点与我不谋而合,过度技术化不可取,且hadoop并非万能。
--------------------------------------------万能的分割线--------------------------------
有人问我,“你在大数据和Hado
- 在GridView中对于有外键的字段使用关联模型进行搜索和排序
dcj3sjt126com
yii
在GridView中使用关联模型进行搜索和排序
首先我们有两个模型它们直接有关联:
class Author extends CActiveRecord {
...
}
class Post extends CActiveRecord {
...
function relations() {
return array(
'
- 使用NSString 的格式化大全
dcj3sjt126com
Objective-C
格式定义The format specifiers supported by the NSString formatting methods and CFString formatting functions follow the IEEE printf specification; the specifiers are summarized in Table 1. Note that you c
- 使用activeX插件对象object滚动有重影
蕃薯耀
activeX插件滚动有重影
使用activeX插件对象object滚动有重影 <object style="width:0;" id="abc" classid="CLSID:D3E3970F-2927-9680-BBB4-5D0889909DF6" codebase="activex/OAX339.CAB#
- SpringMVC4零配置
hanqunfeng
springmvc4
基于Servlet3.0规范和SpringMVC4注解式配置方式,实现零xml配置,弄了个小demo,供交流讨论。
项目说明如下:
1.db.sql是项目中用到的表,数据库使用的是oracle11g
2.该项目使用mvn进行管理,私服为自搭建nexus,项目只用到一个第三方 jar,就是oracle的驱动;
3.默认项目为零配置启动,如果需要更改启动方式,请
- 《开源框架那点事儿16》:缓存相关代码的演变
j2eetop
开源框架
问题引入
上次我参与某个大型项目的优化工作,由于系统要求有比较高的TPS,因此就免不了要使用缓冲。
该项目中用的缓冲比较多,有MemCache,有Redis,有的还需要提供二级缓冲,也就是说应用服务器这层也可以设置一些缓冲。
当然去看相关实现代代码的时候,大致是下面的样子。
[java]
view plain
copy
print
?
public vo
- AngularJS浅析
kvhur
JavaScript
概念
AngularJS is a structural framework for dynamic web apps.
了解更多详情请见原文链接:http://www.gbtags.com/gb/share/5726.htm
Directive
扩展html,给html添加声明语句,以便实现自己的需求。对于页面中html元素以ng为前缀的属性名称,ng是angular的命名空间
- 架构师之jdk的bug排查(一)---------------split的点号陷阱
nannan408
split
1.前言.
jdk1.6的lang包的split方法是有bug的,它不能有效识别A.b.c这种类型,导致截取长度始终是0.而对于其他字符,则无此问题.不知道官方有没有修复这个bug.
2.代码
String[] paths = "object.object2.prop11".split("'");
System.ou
- 如何对10亿数据量级的mongoDB作高效的全表扫描
quentinXXZ
mongodb
本文链接:
http://quentinXXZ.iteye.com/blog/2149440
一、正常情况下,不应该有这种需求
首先,大家应该有个概念,标题中的这个问题,在大多情况下是一个伪命题,不应该被提出来。要知道,对于一般较大数据量的数据库,全表查询,这种操作一般情况下是不应该出现的,在做正常查询的时候,如果是范围查询,你至少应该要加上limit。
说一下,
- C语言算法之水仙花数
qiufeihu
c算法
/**
* 水仙花数
*/
#include <stdio.h>
#define N 10
int main()
{
int x,y,z;
for(x=1;x<=N;x++)
for(y=0;y<=N;y++)
for(z=0;z<=N;z++)
if(x*100+y*10+z == x*x*x
- JSP指令
wyzuomumu
jsp
jsp指令的一般语法格式: <%@ 指令名 属性 =”值 ” %>
常用的三种指令: page,include,taglib
page指令语法形式: <%@ page 属性 1=”值 1” 属性 2=”值 2”%>
include指令语法形式: <%@include file=”relative url”%> (jsp可以通过 include