- Redis 持久化之 AOF 策略
1.什么是AOFAOF是appendonlyfile,AOF文件中记录了每次的操作指令,在启动Redis时,会将AOF文件中的数据读取出来以恢复数据。2.开启AOFRedis默认关闭AOF,可以通过将Redis配置文件中的appendonly设置为yes,这样就开启了AOF,此时RDB就会关闭,只能使用AOF和RDB中的一个。3.AOF的工作流程用户执行指令后,会将该指令写入到AOF缓冲区(aof
- pgsql14自动创建表分区
健康马m
pgsql数据库
最近有pgsql的分区表功能需求,没想到都2025年了,pgsql和mysql还是没有自身支持自动创建分区表的功能现在pgsql数据库层面还是只能用老三样的办法来处理这个问题,每个方法各有优劣1.触发器这是最传统的方法,通过创建一个触发器来检查数据并创建新分区缺点是每次插入数据都会执行触发器,当数据量大时可能影响性能,现在基本很少用这个方案在生产环境上操作2.pg_partmanPostgreSQ
- Java 中 DataSource-数据源 的基础介绍
Java中DataSource-数据源的基础介绍一、核心概念解析1.1数据源(DataSource)1.2数据库连接池(ConnectionPool)1.3二者关系1.4DataSource接口二、DataSource解决的问题与优势2.1DataSource的作用2.2传统方式的局限性2.3使用连接池DataSource的改进三、SpringBoot中DataSource的配置与使用3.1自动配
- SpringBoot + MyBatis 事务管理全解析:从 @Transactional 到 JDBC Connection 的旅程
coderzpw
MybatisSpring系列springbootmybatisjava
SpringBoot+MyBatis事务管理全解析:从@Transactional到JDBCConnection的旅程一、JDBCConnection:事务操作的真正执行者1.1数据库事务的本质1.2Spring与Connection的协作流程二、从@Transactional到JDBCConnection的完整链路2.1Spring中TransactionInterceptor的核心逻辑2.2T
- Java--SpringBoot使用@Transactional注解添加事务
m0_54883970
面试学习路线阿里巴巴android前端后端
一、Java事务1、通常的观念认为,事务仅与数据库相关。事务必须服从ISO/IEC所制定的ACID原则。ACID是原子性(atomicity)、一致性(consistency)、**隔离性(isolation)和持久性(durability)**的缩写。事务的原子性:表示事务执行过程中的任何失败都将导致事务所做的任何修改失效。事务的一致性:表示当事务执行失败时,所有被该事务影响的数据都应该恢复到事
- springboot使用@Transactional失效问题排查
1、排查数据库引擎是不是InnoDB2、启动类是否开启@EnableTransactionManagement3、重点在使用@Transactional(rollbackFor=Exception.class)这个注解的类或者方法中是否有trycatch如果有,要在catch中设置手动回滚//设置手动回滚TransactionAspectSupport.currentTransactionStat
- Java 接口性能优化二
hqxstudying
数据库oraclesql
三、数据库层面:优化数据交互的「最后一公里」数据库是接口性能的「重灾区」——超过60%的接口响应慢问题可追溯至低效的数据交互。优化需从「SQL执行效率」「索引设计」「连接管理」三个维度突破。SQL优化:让查询「少走弯路」核心原则:减少无效数据扫描,让数据库「只做必要的工作」。常见问题与优化:**避免SELECT***:问题:返回冗余字段,增加数据传输量,无法利用覆盖索引。优化:明确指定需要的字段,
- 每天一个前端小知识 Day 16 - 前端性能优化全流程指南
蓝婷儿
前端面试前端性能优化
前端性能优化全流程指南(从加载到交互)目标概览:前端性能优化四大核心维度阶段优化目标加载阶段首屏速度、资源压缩、请求优化渲染阶段减少回流重绘、避免布局抖动交互阶段保持高帧率、避免卡顿持久运行阶段内存泄露处理、缓存命中策略一、加载性能优化(首屏速度为王)✅核心策略:资源体积优化JS/CSS/图片压缩(如gzip,brotli)Tree-shaking(去除无用代码)图片压缩(webp优先)合理拆包(
- Redis可视化管理工具选型指南:7款主流软件深度对比测评
redis
Redis作为高性能的内存数据库,在现代应用开发中扮演着重要角色。为了更好地管理和监控Redis实例,选择一款合适的可视化工具至关重要。本文将为您推荐7款优秀的Redis可视化管理软件,帮助您提升开发和运维效率。RedisInsightRedisInsight是Redis官方推出的免费可视化工具,提供了全面的数据库管理功能。该工具支持多种数据结构的可视化展示,包括字符串、哈希、列表、集合和有序集合
- 时序数据库IoTDB可实现的基本操作及命令汇总
时序数据说
时序数据库iotdb数据库物联网大数据开源
一、数据写入、删除与导出1.1数据写入在物联网场景下,元件产生的数据通常会自动写入。但有时,需要修改过去的数据,可以使用INSERT语句插入修改后的值,覆盖原数据。示例:INSERTINTOroot.BHSFC.Q1.W003(timestamp,speed)VALUES(1657472400000,2);1.2数据删除1.2.1SQL语句删除删除整个时间序列:DELETEFROMroot
- JavaEE:分布式session
一、使用Redis存储分布式session:1.SpringBoot整合Redis,见如下地址:JavaEE:SpringBoot整合Redis_a526001650a-CSDN博客2.代码实现分布式session存储(此处以token为例):@AutowiredprivateRedisTemplateredisTemplate;//Redis数据操作类//登录接口,存储token到redis中@
- 数据库领域下的时序数据库并发控制
数据库管理艺术
数据库专家之路大数据AI人工智能MCP&Agent数据库时序数据库ai
时序数据库并发控制:原理、实现与最佳实践关键词:时序数据库、并发控制、MVCC、时间戳排序、乐观并发控制、分布式事务、性能优化摘要:本文深入探讨时序数据库中的并发控制机制,从基本原理到实际实现进行全面剖析。文章首先介绍时序数据库的特点和并发控制挑战,然后详细分析MVCC、时间戳排序等核心算法原理,并通过代码示例展示实现细节。接着探讨分布式环境下的特殊考量,提供性能优化策略和实际应用案例。最后展望未
- GORM 更新操作:深入探索 Go 语言中的数据库记录修改
code--cat
jvmoraclegolanggo数据库
在Go语言的Web开发中,GORM是一个广泛使用的ORM(Object-RelationalMapping)框架。它提供了一种流畅的方式来处理数据库的交互,其中包括记录的更新操作。在本篇博客中,我们将一起探索GORM的更新操作,了解如何使用GORM来修改数据库中的记录。一、基础概念:更新操作的准备在GORM中,更新操作是通过Model接口的Update方法来实现的。这个方法接受一个指针,该指针指向
- Day32 Web自动化进阶
lookout99
软件测试python自动化测试工具
系列文章目录Day01软件测试基础总结Day02测试用例知识点总结(上)Day03测试用例知识点总结(下)Day04禅道-从安装到卸载Day05MySql的基础使用Day06MySql知识点总结Day07MySql知识点再总结与多表查询Day08redis的基础知识Day08VMware的安装、Linux系统安装和Linux基础命令Day09Linux常用命令总结Day10Linux环境部署和项目
- Day33 PO模型
lookout99
软件测试python自动化测试工具
系列文章目录Day01软件测试基础总结Day02测试用例知识点总结(上)Day03测试用例知识点总结(下)Day04禅道-从安装到卸载Day05MySql的基础使用Day06MySql知识点总结Day07MySql知识点再总结与多表查询Day08redis的基础知识Day08VMware的安装、Linux系统安装和Linux基础命令Day09Linux常用命令总结Day10Linux环境部署和项目
- 探索GORM:Go语言中的开发友好型ORM库
探索GORM:Go语言中的开发友好型ORM库gormThefantasticORMlibraryforGolang,aimstobedeveloperfriendly项目地址:https://gitcode.com/gh_mirrors/gor/gorm在Go语言的生态系统中,有一颗璀璨的明星——GORM,为开发者们带来了高效且直观的对象关系映射(ORM)体验。这是一篇专为那些寻求数据库操作简便性
- 探索Octillery:Go语言中的数据库分片利器
余纳娓
探索Octillery:Go语言中的数据库分片利器octilleryGopackageforshardingdatabases(SupportseveryORMorrawSQL)项目地址:https://gitcode.com/gh_mirrors/oc/octillery在现代应用开发中,随着数据量的增长,数据库分片成为了提升性能和扩展性的关键技术。今天,我们将深入介绍一个强大的Go语言库——O
- mysql锁机制
weixin_45990219
教程mysql数据库
深入解析MySQL锁机制:从原理到实战场景前言在数据库高并发场景中,锁机制是保障数据一致性和事务隔离性的核心。然而,MySQL中锁的类型繁多,概念抽象,容易让人望而生畏。本文将通过通俗的语言和实际场景,带你彻底理解MySQL中的各种锁机制及其应用。一、锁的由来与分类1.1为什么需要锁?多个事务并发执行时,可能出现脏写、脏读、不可重复读、幻读等问题。例如:场景:A事务修改了某条数据但未提交,B事务读
- 织梦DedeCMS转WordPress
asqq8
最近,有个用户找模板兔迁移网站,源站用的dede,需要转成wp,文章数量大概7000-8000篇,其中有个需求是保证旧文章的链接有效,在wp上的新文章与旧文章的链接类型不一样,所以这涉及到伪静态来处理跳转。虽然网上都很多教程,但是在这次导入过程中还是遇到过一些问题。以下教程是dede的数据表得与wp的数据表在同一个数据库下!要是不在,可以将dede_archives先导入到wp的数据库里。一般流程
- MySQL5.7评估数据库层binlog过滤写入
颖妍--唯爱
数据库mysql
binlog-do-db参数的影响本次测试均为binlog_format=row格式,因为binlog_format=statement格式在复制场景下,对函数和存储过程使用不友好,很容易导致主从数据不一致,生产环境很少有使用statement格式。使用use指定库在test库进行ddl操作和dml操作[root@localhost]15:17:10[test]>flushbinarylogs;Q
- 深入浅出Node.js后端开发
jghhh01
node.js
让我们来理解Node.js的核心——事件循环和异步编程模型。在Node.js中,所有的I/O操作都是非阻塞的,这意味着当一个请求开始等待I/O操作完成时(如读取文件或数据库操作),Node.js不会阻塞后续操作,而是继续执行其他任务。这种机制大大提高了应用的性能和吞吐量。constfs=require('fs');fs.readFile('file.txt','utf8',(err,data)=>
- PCIe学习笔记(26)
IC纯小白
学习笔记网络
ErrorForwarding(错误转发)错误转发(也称为数据中毒),通过设置EP位表示。下面是一些使用错误转发的例子:•例#1:从主存读取遇到不可纠正的错误•例#2:PCI写到主存的奇偶校验错误•例#3:内部数据缓冲区或缓存上的数据完整性错误错误转发使用模型•错误转发仅用于读取完成数据,AtomicOp完成数据,AtomicOp请求数据或写数据,从不用于错误在“头”(请求阶段,地址/命令等)的情
- Tomcat性能调优指南
文章目录一、Tomcat性能调优概述为什么需要调优Tomcat?二、Tomcat架构与性能关键点三、JVM调优1.内存配置优化2.垃圾回收优化3.其他JVM优化参数四、连接器(Connector)调优1.NIOvsAPR/Native2.高级NIO配置五、线程池优化六、会话管理优化1.会话超时配置2.会话持久化选择七、静态资源处理优化1.启用Sendfile2.配置静态资源缓存八、其他优化措施1.
- 数据库设计三范式详解与注意事项
步行cgn
数据库数据库oracle服务器
数据库设计三范式详解与注意事项数据库设计三范式(NormalForms)是关系型数据库设计的核心理论,用于减少数据冗余、提高数据一致性和完整性。下面我将详细解释三范式的概念、应用场景和实际注意事项。一、三范式核心概念1.第一范式(1NF):原子性定义:每个列都是不可再分的原子值每行有唯一标识(主键)示例:--不符合1NFCREATETABLEorders(order_idINTPRIMARYKEY
- 数据库 DML 语句详解:语法与注意事项
步行cgn
数据库数据库oracle
数据库DML语句详解:语法与注意事项DML(DataManipulationLanguage,数据操作语言)用于操作数据库中的数据,主要包括SELECT、INSERT、UPDATE、DELETE等语句。下面我将详细说明每种操作的语法、使用场景和关键注意事项。一、SELECT查询语句基本语法SELECT[DISTINCT]column1,column2,...FROMtable_name[WHERE
- 数据库级联操作详解:级联删除、更新与置空
步行cgn
数据库数据库oraclesql
数据库级联操作详解:级联删除、更新与置空在数据库设计中,级联操作(CASCADE)是管理关联数据的关键机制,它能自动处理主表与从表之间的数据一致性。下面详细介绍级联删除、更新和置空的语法、使用场景及注意事项。一、级联操作语法1.级联删除(ONDELETECASCADE)--创建表时定义CREATETABLEorders(order_idINTPRIMARYKEY,customer_idINT,FO
- 100W QPS 短链系统怎么设计
Java程序员 拥抱ai
电商架构大数据
看上去业务简单,其实,覆盖的知识点非常多:高并发、高性能分布式IDRedisBloomFilter高并发、低内存损耗的过滤组件知识分库、分表海量数据存储多级缓存的知识HTTP传输知识二进制、十六进制、六十二进制知识总体来说,高并发、高性能系统的核心领域,都覆盖了。所以,分析下来,得到一个结论:是一个超级好的问题。1、短URL系统的背景短网址替代长URL,在互联网网上传播和引用。例如QQ微博的url
- 前端基础知识JavaScript系列 - 25(Javascript本地存储)
前端小白从0开始
前端javascript开发语言
一、方式javaScript本地缓存的方法我们主要讲述以下四种:cookiesessionStoragelocalStorageindexedDBcookieCookie,类型为「小型文本文件」,指某些网站为了辨别用户身份而储存在用户本地终端上的数据。是为了解决HTTP无状态导致的问题作为一段一般不超过4KB的小型文本数据,它由一个名称(Name)、一个值(Value)和其它几个用于控制cooki
- 一个 new 操作耗时1秒?用原型模式,性能提升100倍!
java干货
Springboot原型模式
你是否也曾深陷在对象创建的性能泥潭,当new一个对象的成本极其高昂(例如,需要复杂的数据库查询、网络IO或大量计算),导致你的SpringBoot应用响应缓慢,资源消耗巨大?是时候用原型设计模式(PrototypeDesignPattern)来解脱了!这是一种创建型设计模式,它允许你通过复制现有的实例来创建新的对象,而不是从头开始创建,从而大幅提升性能和灵活性。在SpringBoot中,这个模式的
- AWTK:一键切换皮肤,打造个性化UI
ZLG 致远电子
个人开发
想让你的应用在不同场景下都能完美呈现吗?皮肤切换功能必不可少!本文将介绍AWTK,一款强大的GUI框架,它通过内置资源管理和优化缓存,轻松实现皮肤切换功能。 前言当今的UI应用中,为了满足不同使用场景和用户的个性化需求,许多软件都加入了切换皮肤的功能。例如,当夜晚使用手机时,屏幕亮度可能会让人感到刺眼,此时用户可以将APP切换为夜间模式;而在户外强光环境下,则需要切换到高亮度
- 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