- 【Elasticsearch】dfsPhase
`dfsPhase`(即DFS阶段)是在每个数据节点本地执行的,而不是在协调节点执行的。在Elasticsearch的查询流程中,`dfsPhase`是为了在进行“评分”时更准确地计算全局的term频率(TF-IDF),它需要先在每个数据节点上执行一次本地的DFS操作,收集该节点上每个字段的term统计信息(如docFreq、totalTermFreq),然后将这些信息回传给协调节点。协调节点再合
- 用ELK日志分析平台分析常见的系统登录问题
通过ELK(Elasticsearch、Logstash、Kibana)日志分析平台,除了登录超时问题,还可深入分析以下常见的系统登录问题,并结合实际场景提供解决方案:一、认证失败分析1.问题定位场景:用户输入错误密码、账户锁定、服务端认证模块故障等。ELK实现:日志解析:通过Logstash的Grok插件提取关键字段(如用户名、IP、错误类型),例如解析/var/log/auth.log中的Fa
- 【Elasticsearch】IndexService
risc123456
Elasticsearchelasticsearch
一句话:IndexService就是“一个索引在单个节点里的运行时总管”,负责把这个索引在本节点托管的所有分片(主/副)以及它们要用到的资源、配置、线程池、缓存、监听等全部管理起来。---✅IndexService的核心职责(节点维度)模块作用分片生命周期创建/删除/关闭本地IndexShard实例(每个分片一个)。线程池提供`index`,`search`,`refresh`,`flush`,`
- Docker安装Elasticsearch 7.17.0和Kibana 7.17.0并配置基础安全
1.准备工作确保已安装Docker并启动服务创建必要的目录结构:mkdir-p/opt/es/{config,data,plugins}mkdir-p/opt/kibana/configchmod-R777/opt/es/opt/kibana2.安装Elasticsearch拉取镜像:dockerpullelasticsearch:7.17.0创建配置文件/opt/es/config/elasti
- 绝佳组合 SpringBoot + Lua + Redis = 王炸!
Java精选面试题(微信小程序):5000+道面试题和选择题,真实面经,简历模版,包含Java基础、并发、JVM、线程、MQ系列、Redis、Spring系列、Elasticsearch、Docker、K8s、Flink、Spark、架构设计、大厂真题等,在线随时刷题!前言曾经有一位魔术师,他擅长将SpringBoot和Redis这两个强大的工具结合成一种令人惊叹的组合。他的魔法武器是Redis的
- Elasticsearch 聚合查询源码解读与架构方法论
北漂老男人
Elasticsearchelasticsearch架构大数据搜索引擎全文检索
Elasticsearch聚合查询源码解读与架构方法论01.引言Elasticsearch的聚合查询(Aggregation)是大规模分布式数据分析的核心能力。理解其源码结构与设计方法论,不仅有助于高效使用聚合,也能为自定义扩展、性能优化、集群运维等提供理论与实践基础。本文将从源码结构、核心模块、关键实现、行级注释与方法论出发,系统剖析聚合查询的底层原理。02.源码结构与核心模块2.1聚合相关源码
- filebeat改造支持rocketmq
余很多之很多
goJavarocketmq
继续分享下以前在gitchat上发布的文章:filebeat改造支持rocketmq1.概述1.1问题概述现在越来越多的日志采集使用FileBeat,FileBeat是个轻量型日志采集器,采用Go语言实现,性能稳健,占用资源少。FileBeat现在支持采集的日志内容发送到Redis、Elasticsearch、Kafka、Logstash。那么我们如果想通过FileBeat采集日志到RocketM
- 【SpringCloud微服务实战09】Elasticsearch 搜索引擎
李维山
Javaelasticsearchspringcloud搜索引擎
一、Elasticsearch安装1、Docker安装ES#创建一个网络dockernetworkcreatees-net#拉取ES镜像(这里使用7.17.18版本)dockerpullelasticsearch:7.17.18#新建一个目录存放es数据mkdirescdes#docker运行单机启动esdockerrun-d\--namees\-e"ES_JAVA_OPTS=-Xms512m-X
- Filebeat + Logstash + ES进行Nginx日志采集
一个只会喊666的菜比
简易架构图service.png架构图比较简单,日志收集大同小异,这次不添加任何中间服务比如:rediskafka后端只是存储进ES使用的版本jdk-8u161-linux-x64.rpmelasticsearch-6.7.2.rpmlogstash-6.7.2.rpmfilebeat-6.7.2-x86_64.rpm安装比较简单,只用进行rpm-ivh即可,接下来直接贴配置文件:Elastics
- Elasticsearch数据库的数据同步机制
数据库管理艺术
elasticsearch数据库jenkinsai
Elasticsearch数据库的数据同步机制关键词:Elasticsearch、数据同步、近实时搜索、倒排索引、translog、refresh、flush、副本同步摘要:本文深入探讨Elasticsearch数据库的数据同步机制,从底层原理到实际应用进行全面解析。文章首先介绍Elasticsearch的基本架构和数据模型,然后详细分析其近实时搜索的实现原理,包括索引刷新(Refresh)、事务
- docker run elasticsearch 报错
EmpressBoost
dockerelasticsearch容器
谷粒商城p103前提条件:下载镜像文件#存储和检索数据dockerpullelasticsearch:7.4.2#可视化检索数据dockerpullkibana:7.4.2创建挂载的文件和配置mkdir-p/mydata/elasticsearch/configmkdir-p/mydata/elasticsearch/dataecho"http.host:0.0.0.0">>/mydata/ela
- 分布式系统中优化ELK日志采集性能
Alex艾力的IT数字空间
elk微服务中间件架构ux安全性测试可用性测试
架构设计、组件调优、资源分配等多维度入手一、架构优化:分布式与解耦设计分层采集与缓冲Filebeat轻量级采集:在每台服务器部署Filebeat替代Logstash作为日志收集器,降低资源占用(CPU/内存减少70%以上)。引入缓冲队列:通过Redis或Kafka作为日志缓冲池,缓解Logstash或Elasticsearch的突发流量压力,避免数据丢失(如Logstash异常时Redis暂存数据
- Elasticsearch搜索引擎存储:从原理到实践的全景解析
Python×CATIA工业智造
搜索引擎elasticsearch大数据
引言在大数据时代,数据规模呈指数级增长,传统数据库的模糊查询、实时分析能力逐渐成为瓶颈。Elasticsearch(简称ES)凭借其分布式架构、实时搜索和灵活的数据分析能力,成为企业级搜索与存储的核心引擎。截至2025年,ES在全球日志分析、电商搜索、实时监控等场景的市场占有率超过60%。本文将从存储架构、核心技术、应用场景及优化策略四个维度,深入解析Elasticsearch的设计哲学与实践价值
- Elasticsearch混合搜索深度解析(下):执行机制与完整流程
GeminiJM
ES学习笔记elasticsearchjenkins大数据
引言在上篇中,我们发现了KNN结果通过SubSearch机制被保留的关键事实。本篇将继续深入分析混合搜索的执行机制,揭示完整的处理流程,并解答之前的所有疑惑。深入源码分析1.SubSearch的执行机制1.1KnnScoreDocQueryBuilder的实现KNN结果被转换为KnnScoreDocQueryBuilder,这个类负责在查询阶段重新执行KNN搜索://server/src/main
- SkyWalking + Logstash全链路追踪系统详细实施方案
@淡 定
skywalking
SkyWalking+Logstash全链路追踪系统详细实施方案一、系统架构与数据流向核心流程:数据采集:SkyWalkingAgent埋点收集调用链路数据日志增强:应用程序通过MDC注入TraceID日志收集:Logstash采集应用日志并发送至Elasticsearch数据存储:SkyWalking指标数据与日志数据分别存储可视化分析:SkyWalkingUI展示链路追踪,Kibana分析日志
- 自建ELK vs 云商日志服务:成本对比分析
亲爱的非洲野猪
elk
在当今数据驱动的时代,日志管理已成为企业IT基础设施中不可或缺的一部分。面对日益增长的日志数据,许多团队都在纠结:是自建ELK(Elasticsearch、Logstash、Kibana)堆栈,还是直接使用云服务商提供的日志服务?本文将从成本角度对这两种方案进行详细对比分析。自建ELK方案成本分析1.硬件/基础设施成本服务器成本:至少需要3个节点(生产环境推荐)实现高可用中等规模部署:3台16核6
- 【spring boot】三种日志系统对比:ELK、Loki+Grafana、Docker API
ladymorgana
日常工作总结springbootelkgrafana
文章目录**方案1:使用ELK(Elasticsearch+Logstash+Kibana)****适用场景****搭建步骤****1.修改SpringBoot日志输出****2.创建DockerCompose文件****3.配置Logstash****4.启动服务****方案2:使用Loki+Grafana****适用场景****搭建步骤****1.修改SpringBoot日志驱动****2.配
- Semantic text 就是那么强大,还附带一包( BBQ )薯片!配有可配置的分块设置和索引选项。
Elastic 中国社区官方博客
ElasticsearchAI大数据elasticsearch搜索引擎全文检索人工智能ai图搜索
作者:来自ElasticKathleenDeRusso语义文本搜索现在可以自定义,支持可配置的分块设置和索引选项,用于自定义向量量化,使semantic_text在专业用例中更强大。Elasticsearch拥有大量新功能,帮助你为你的用例构建最佳搜索解决方案。深入查看我们的示例笔记本以了解更多信息,开始免费云试用,或者立即在本地机器上体验Elastic。随着Elasticsearch8.18和9
- Elasticsearch 高可用实战:架构设计与场景化解决方案
辣呼呼的哈哈
Elasticsearch入门到精通elasticsearchwpf大数据全文检索搜索引擎restfuljava
Elasticsearch高可用实战:架构设计与场景化解决方案本文深入探讨Elasticsearch在高并发、大数据量场景下的高可用架构设计,结合电商搜索、日志分析等真实案例,提供可落地的技术方案与Java实现。一、高可用架构设计原则1.分布式架构核心要素客户端负载均衡层协调节点数据节点-分片1数据节点-分片2数据节点-分片3副本分片副本分片副本分片2.高可用黄金法则冗余设计:至少3节点集群+1副
- Elasticsearch RESTful API入门:基础搜索与查询DSL
辣呼呼的哈哈
Elasticsearch入门到精通elasticsearchrestful大数据搜索引擎全文检索springboot
ElasticsearchRESTfulAPI入门:基础搜索与查询DSL本文为Elasticsearch初学者详细解析RESTfulAPI的核心操作与查询DSL语法,包含大量实战示例及最佳实践。一、Elasticsearch与RESTfulAPI简介Elasticsearch(ES)作为分布式搜索分析引擎,其RESTfulAPI是与集群交互的核心方式。通过HTTP协议实现:✅索引文档的CRUD操作
- Elasticsearch入门(二):document数据格式 、简单的es restful api
m0_50134014
Elasticsearchelasticsearchjava
目录一、document数据格式1.1面向文档的搜索分析引擎1.1.1对象数据存储到数据库中1.1.2对象数据存储到ES中二、电商网站商品管理案例背景介绍2.1简单的集群管理2.1.1快速检查集群的健康状况:`GET/_cat/health?v`2.1.2快速查看集群中有哪些索引:`GET/_cat/indices?v`2.1.3创建索引:`PUT/test_index?pretty`2.1.4删
- Elasticsearch RESTful API入门:全文搜索实战(Java版)
辣呼呼的哈哈
Elasticsearch入门到精通elasticsearchrestfuljava大数据搜索引擎全文检索
ElasticsearchRESTfulAPI入门:全文搜索实战(Java版)本文结合Java客户端API,深入讲解Elasticsearch全文搜索的实现。包含10+个实战示例及对应的Java代码,涵盖match、multi_match、高亮显示等核心功能。一、环境准备1.添加Maven依赖org.elasticsearch.clientelasticsearch-rest-high-level
- 【Elasticsearch】function_score
risc123456
Elasticsearchelasticsearch
如果你希望在Elasticsearch查询中降低某些特定`id`的文档评分,可以通过`function_score`查询结合`script_score`函数来实现。`script_score`允许你使用自定义脚本对文档的评分进行调整。以下是一个示例,展示如何降低某些特定`id`的文档评分:示例场景假设我们有一个索引`my_index`,其中包含一些文档,每个文档都有一个`id`字段。我们希望降低某
- Elasticsearch RESTful API入门:索引的增删改查完全指南
辣呼呼的哈哈
Elasticsearch入门到精通elasticsearchrestful大数据java架构搜索引擎全文检索
ElasticsearchRESTfulAPI入门:索引的增删改查完全指南本文专为Java开发初学者设计,将手把手教你掌握Elasticsearch索引的核心操作一、环境准备与基本概念1.1安装Elasticsearch(Windows版) 1.访问官网下载ZIP包 2.解压后进入bin目录,双击elasticsearch.bat启动 3.验证安装:浏览器访问http://localhost
- Docker快速单点部署Elasticsearch
❀͜͡傀儡师
dockerelasticsearch
x86架构dockerpullregistry.cn-hangzhou.aliyuncs.com/qiluo-images/elasticsearch:8.17.4arm架构dockerpullregistry.cn-hangzhou.aliyuncs.com/qiluo-images/linux_arm64_elasticsearch:8.17.43、elasticsearch安装mkdir-p
- ES 压缩包安装
思静鱼
#elasticsearchelasticsearch大数据
以下是Elasticsearch(ES)通过.tar.gz压缩包安装的详细步骤(适用于Linux/macOS系统):1.准备工作1.1检查系统依赖Java环境:ES需要JDK,推荐OpenJDK11/17(ES7.x/8.x兼容版本)。java-version#检查是否已安装如果未安装,使用以下命令安装(以Ubuntu为例):sudoaptupdatesudoaptinstallopenjdk-1
- 云原生时代的日志管理:ELK、Loki、Fluentd 如何选型?
一、引言在微服务和Kubernetes普及的今天,传统的日志管理方式已经难以应对高并发、分布式架构带来的挑战。随着容器化应用数量激增,日志数据量呈指数级增长,如何高效地收集、存储、查询和分析日志,成为每个团队必须面对的问题。在这样的背景下,ELK(Elasticsearch+Logstash+Kibana)、Loki和Fluentd成为当前主流的日志解决方案。它们各有特色,适用于不同规模和技术栈的
- 自动化运维工程师实操面试题
以下是针对Ansible、Zabbix、ElasticsearchLogstashKibana(ELK)设计的2道综合实操题,难度适中且结合实际应用场景:实操题1:Ansible自动化部署Zabbix监控平台并集成ELK日志分析题目背景某企业需要通过Ansible自动化部署Zabbix监控服务器(含Agent)、Elasticsearch、Logstash、Kibana(ELK)日志分析系统,并实
- 怎么安装自定义分词器
思静鱼
#elasticsearches
安装自定义分词器的完整步骤在Elasticsearch中安装自定义分词器,通常需要修改索引配置或开发插件。以下是详细方法:一、基于配置实现自定义分词器(无需插件)适用于通过组合Elasticsearch内置的CharacterFilters、Tokenizers和TokenFilters实现的分词器。1.定义分词规则在创建索引时,通过settings.analysis配置自定义分词器:PUT/my
- 【容器】优质文章分享
文章目录加速器Docker教程安装坑volumn网络配置踩坑其他dockerfiledocker-compose手册教程网络坑docker使用dockermysqldockermongoredisdocker-rabbitmqnginxtomcatnacoszookeeperelasticsearch加速器现在docker镜像站真的不好找了。阿里什么的加速目前只能给阿里自己的容器用了。且用且珍惜D
- 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