- 【大模型】triton inference server
idiotyi
大模型自然语言处理语言模型人工智能
前言:tritoninferenceserver常用于大模型部署,可以采用http或GRPC调用,支持大部分的backend,单GPU、多GPU都可以支持,CPU也支持。本文主要是使用tritoninferenceserver部署大模型的简单流程示例。目录1.整体流程2.搭建本地仓库3.服务端代码4.启动服务5.客户端调用1.整体流程搭建模型仓库模型配置服务端调用代码docker启动服务客户端调用
- 天下苦英伟达久矣!PyTorch官方免CUDA加速推理,Triton时代要来?
诗者才子酒中仙
物联网/互联网/人工智能/其他pytorch人工智能python
在做大语言模型(LLM)的训练、微调和推理时,使用英伟达的GPU和CUDA是常见的做法。在更大的机器学习编程与计算范畴,同样严重依赖CUDA,使用它加速的机器学习模型可以实现更大的性能提升。虽然CUDA在加速计算领域占据主导地位,并成为英伟达重要的护城河之一。但其他一些工作的出现正在向CUDA发起挑战,比如OpenAI推出的Triton,它在可用性、内存开销、AI编译器堆栈构建等方面具有一定的优势
- windows系统下配置Mamba环境
ls077
windows
最近在学习AI知识,试图在安装最近爆火的mamba模型时遇到困难。参考网上各位达人,经过努力,终于在win11系统anaconda中成功编译安装了mamba包。我用的是visualstudio20191.在windows下构建Mamba使用环境:condacreate-nmambapython=3.10condaactivatemamba注:Mamba需要triton,然而triton没有wind
- 深度学习部署:Triton(Triton inference server)【旧称:TensorRT serving,专门针对TensorRT设计的服务器框架,后来变为Triton,支持其他推理后端】
u013250861
#LLM/部署深度学习人工智能
triton作为一个NVIDIA开源的商用级别的服务框架,个人认为很好用而且很稳定,API接口的变化也不大,我从2020年的20.06切换到2022年的22.06,两个大版本切换,一些涉及到代码的工程变动很少,稍微修改修改就可以直接复用,很方便。本系列讲解的版本也是基于22.06。本系列讲解重点是结合实际的应用场景以及源码分析,以及写一些triton周边的插件、集成等。非速成,适合同样喜欢深入的小
- Linux 环境下本地测试stable diffusion v2.1出错
Branton_Zhenyuan
Debuglinuxpython运维
从huggingface上,把stabeldiffusion装到本地linux上面时,遇到三个错误:一、ErrorcaughtWas:Nomodulenamed"triton"直接安装也出错Errorcaughtwas:module'triton.language'hasnoattribute'constexpr'卸载后更新pip再安装也不行解决方法是:pipinstalltriton==2.0.
- wespeaker项目grpc-java客户端开发
weixin_43870390
java开发语言
非常重要的原始参考资料:链接:triton-inference-server/clientgithub/grpcjavaps:使用grpc协议的其它项目python/go可以参考github目录client/tree/main/src/grpc_generated下的其它项目其它链接:想要系统了解triton-inference-server可以查看主页想要了解server可以查看server想要
- tritonserver学习之一:triton使用流程
liupenglove
深度学习
tritonserver学习之二:tritonserver编译tritonserver学习之三:tritonserver运行流程tritonserver学习之四:命令行解析tritonserver学习之五:backend实现机制1、triton环境搭建1.1docker安装以Ubuntu为例:curl-fsSLhttps://test.docker.com-otest-docker.shsudos
- tritonserver学习之二:tritonserver编译
liupenglove
学习c++
tritonserver学习之一:triton使用流程tritonserver学习之三:tritonserver运行流程tritonserver学习之四:命令行解析过程tritonserver学习之五:backend实现机制1.编译脚本生成流程triton的编译脚本位于server代码库,文件为:build.pytriton编译参数众多,很多参数也没搞清楚是什么用处,建议直接使用--enable-
- tritonserver学习之三:tritonserver运行流程
liupenglove
学习
tritonserver学习之一:triton使用流程tritonserver学习之二:tritonserver编译tritonserver学习之四:命令行解析tritonserver学习之五:backend实现机制1、triton启动运行流程triton功能设计全面,而且复杂,下面是triton(2.41.0)启动的整个流程,在整个pipeline中,每个节点都需要去仔细的研究和学习,不仅能够学
- tritonserver学习之五:backend实现机制
liupenglove
学习
tritonserver学习之一:triton使用流程tritonserver学习之二:tritonserver编译tritonserver学习之三:tritonserver运行流程tritonserver学习之四:命令行解析1、预备知识1.1backend概念backend是triton中的核心部件,它负责处理来自客户端的推理请求,并将请求转发给相应的模型进行推理。每个backend都对应一个特
- 【BBuf的CUDA笔记】十三,OpenAI Triton 入门笔记一
just_sort
笔记
0x0.前言2023年很多mlsys工作都是基于Triton来完成或者提供了Triton实现版本,比如现在令人熟知的FlashAttention,大模型推理框架lightllm,diffusion第三方加速库stable-fast等灯,以及很多mlsys的paper也开始使用Triton来实现比如最近刚报道的这个新一代注意力机制LightningAttention-2:无限序列长度、恒定算力开销、
- triton教程2:跑resnet50
孤高丶逛侠
人工智能
一、前言不知从何时起,resnet50就成了很多场景下的basemodel,以后我们想要在triton-server部署我们自己研发的模型,那么咱就可以从部署resnet50开始。二、
- triton教程1:前言、安装、跑官方例子与推荐视频
孤高丶逛侠
人工智能
一、为啥用triton?之前部署使用过tensorrt+视频流硬解码+前后处理硬件(cuda)加速,已经是工业化、商业化的一套标准流程了,现在面临的挑战是:多模型管理(一个小公司所有算法工程师的模型推理都在我这)、多机多卡(如何统一调度)、最大化硬件资源利用(需要保证硬件吞吐量达到高水准)等等;如果还是用之前的标准流程,其实也能够做到这些,比如多模型管理,每个模型独立作为一个进程启动即可达到类似效
- Triton Inference Serve调研
georgeguo
1TritonInferenceServe简介Tritoninferenceserve是NVIDA开源的推理框架,官网TritonInferenceServer,具有如下特点:支持常见深度学习框架导出模型的推理,如TensorRT,TensorFlowGraphDef,TensorFlowSavedModel,ONNX,PyTorchTorchScriptandOpenVINO等格式。支持机器学习
- Triton + HF + Qwen 推理经验总结
Charles_yy
大语言模型
1.简介Triton介绍参考:GitHub-triton-inference-server/tutorials:ThisrepositorycontainstutorialsandexamplesforTritonInferenceServer2.实现方案2.1.docker部署#拉取docker镜像gitclone-br23.10https://github.com/triton-inferen
- 深度学习部署架构:以 Triton Inference Server(TensorRT)为例
禅与计算机程序设计艺术
什么是模型部署?模型训练只是DeepLearning的一小部分,如《HiddenTechnicalDebtinMachineLearningSystems》机器学习系统的技术债书中所说。现有几种搭建框架:Python:TF+Flask+Funicorn+NginxFrameWork:TFserving,TorchServe,ONNXRuntimeIntel:OpenVINO,NVNN,QNNPAC
- 科研汪的日常 03 混乱
007木子
进入课题组后的每一天都有新的实验要学习,从PCR到WesternBlot,再到切片和免疫荧光染片,刚开始还能记得清要用的东西放在了哪里,也记得清WesternBlot是用TBST(TBS+Tween20)来进行清洗,免疫荧光染片是用PBST(PBS+Triton),后来两个实验一同进行的时候,脑子已经放弃了思考,完全就是凭手感,拿到什么用什么。这天,当我顶着满脑袋糨糊,手拿TBST准备去洗涤免疫荧
- Nautilus Chain 现已推出测试网“Triton ”,有哪些潜在的机会?
金马1988
区块链
NautilusChain是ZebecChian的先行链,从特点上看,作为领先的EVM扩展解决方案,它是Web3中最快的EVM环境,将Solana的速度与以太坊的可靠性和分散性结合起来。NautilusChain也从VitalikButerin设计的L3视野出发,L2可以通过批处理交易来帮助扩展以太坊等L1链,从而分离共识层和执行层。NautilusChain作为一个L3链,将这一原理提升到更高的
- Triton部署mmdeploy导出的TensorRT模型失败篇
gy-7
docker容器运维
记录一下历程,最终没有部署成功,应该是Ubantu系统版本的问题。现在没有时间搞了,先记录一下,后续用到再填坑。Tritondemogitclone-br22.06https://github.com/triton-inference-server/server.gitcdserver/docs/examples./fetch_models.sh#构建并启动容器1的服务dockerrun--gpu
- 【建议收藏】这个工具专门用于寻找路由器中的安全漏洞
H_00c8
关于工具现有工具现在,现成的污点分析工具已经有很多了。其中,我最感兴趣的是Triton和bincat,因为两者已经相当成熟。然而,我们却无法使用这两种工具,因为它们不支持目标设备所使用的MIPS架构。使用angr进行符号执行测试因此,我们把工作重点放在利用angr打造自己的工具上;angr是一个基于Python的二进制分析框架。我们之所以选择angr,是因为它支持大多数架构,包括我们所针对的MIP
- 使用Triton部署chatglm2-6b模型 | 京东云技术团队
一、技术介绍NVIDIATritonInferenceServer是一个针对CPU和GPU进行优化的云端和推理的解决方案。支持的模型类型包括TensorRT、TensorFlow、PyTorch(meta-llama/Llama-2-7b)、Python(chatglm)、ONNXRuntime和OpenVino。NVIDIATritonServer是一个高性能的推断服务器,具有以下特点:1.高性
- Multi-Framework Serving Runtimes-How to write a custom predictor-KServe
蓝净云
KserveKserve
Multi-FrameworkServingRuntimes-Howtowriteacustompredictor用TorchScript模型预测Triton推理服务设置导出为Torchscript模型将您在GCS上训练的模型存储在模型库中使用HTTP端点推断创建推理服务使用curl运行预测运行性能测试gRPC端点推断创建推理服务使用grpcurl运行预测将Transformer添加到推理服务实现
- triton 客戶端用https协议访问服务
Melody2050
AI与MLhttps网络协议http
背景平时调用模型服务,都是用http+IP的链接调用。但由于笔者环境的特殊性,访问模型必须经过一个https的公网URL,所以,如何用tritonclient访问https链接成为了一个问题参考TensorRT&Triton学习笔记(一):triton和模型部署+client调研首先,nvidiatritonclient访问url的原理是什么?从infer函数的内容可知,tritonclient访
- stable diffusion model训练遇到的问题【No module named ‘triton‘】
Leafing_
stablediffusiondiffusersloratriton训练扩散模型
一天早晨过来,发现昨天还能跑的diffusion代码,突然出现了【Nomodulenamed‘triton’】的问题,导致本就不富裕的显存和优化速度雪上加霜,因此好好探究了解决方案。首先是原因,由于早晨过来发现【电脑重启】导致了【训练终止】(美好的心情从看到windows更新结束),基本可以判定是由于windows更新,以及所编译的triton的windows版本的原因,最终解决方案如下:1、第一
- Fledermaus处理背向散射数据(backscatter)的工具FMGT
xiaokcehui
多波束背散射数据
最近网友问除了CARIS,还有什么软件可以处理多波束的背散射数据。bing搜索一下,QPSFledermaus的FMGT模块可以用来处理背向散射数据,其实,这个模块早就和Fledermaus、DMagic等模块一样已经安装在电脑中,但之前从来没有使用过。下面就讲一下这个软件的使用。1、新建项目,导入.all数据。导入的数据如下图所示。2、数据处理。处理方式有两种方式:自动处理和人工处理。我们来先看
- triton客户端使用
山西茄子
deepstream人工智能
model_analyzer简介:TritonModelAnalyzerisaCLItoolwhichcanhelpyoufindamoreoptimalconfiguration,onagivenpieceofhardware,forsingle,multiple,ensemble,orBLSmodelsrunningonaTritonInferenceServer.ModelAnalyzerw
- 直播观看指南|Triton Meetup 2023
SOFAStack
人工智能
“TritonMeetup2023“活动将于2023年2月25日14:00,在北京BCos共享办公(北京WFC环球金融中心办公店)举行!本篇文章将为大家带来线上直播观看指南本次活动是Triton社区首次正式举办的线下技术交流活动,对模型推理领域具有里程碑意义。活动将专注于AIInfra、推理引擎相关的主题分享,打造Triton社区开放共享的技术生态,共同推进Triton在国内的推广和应用落地!活动
- Triton Inference Server
The Straggling Crow
项目笔记深度学习视觉检测边缘计算
githubaddressinstallmodelanalysisyolov4性能分析例子中文博客介绍关于服务器延迟,并发性,并发度,吞吐量经典讲解clientpyexamples用于模型仓库管理,性能测试工具1、性能监测,优化ModelAnalyzersection帮助你了解model的GPU内存使用率—youcandecidehowtorunmultipemodelsonasingleGPU.
- ubuntu 22.04 LTS openai triton 安装
Eloudy
ubuntupythonlinux
第一种方法:pipinstalltriton第二种方法,安装最新的版本:pipinstall-U--index-urlhttps://aiinfra.pkgs.visualstudio.com/PublicPackages/_packaging/Triton-Nightly/pypi/simple/triton-nightly第三种方法:gitclonehttps://github.com/ope
- 6.跑一下Triton官方教程
qq_38196982
tritonneo4j
1.模型部署首先拉取官方示例代码gitclone--recursivehttps://github.com/triton-inference-server/tutorials.gitcdtutorials/Conceptual_Guide/Part_1-model_deployment1.下载文本检测模型wgethttps://www.dropbox.com/s/r2ingd0l3zt8hxs/f
- jQuery 跨域访问的三种方式 No 'Access-Control-Allow-Origin' header is present on the reque
qiaolevip
每天进步一点点学习永无止境跨域众观千象
XMLHttpRequest cannot load http://v.xxx.com. No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://localhost:63342' is therefore not allowed access. test.html:1
- mysql 分区查询优化
annan211
java分区优化mysql
分区查询优化
引入分区可以给查询带来一定的优势,但同时也会引入一些bug.
分区最大的优点就是优化器可以根据分区函数来过滤掉一些分区,通过分区过滤可以让查询扫描更少的数据。
所以,对于访问分区表来说,很重要的一点是要在where 条件中带入分区,让优化器过滤掉无需访问的分区。
可以通过查看explain执行计划,是否携带 partitions
- MYSQL存储过程中使用游标
chicony
Mysql存储过程
DELIMITER $$
DROP PROCEDURE IF EXISTS getUserInfo $$
CREATE PROCEDURE getUserInfo(in date_day datetime)-- -- 实例-- 存储过程名为:getUserInfo-- 参数为:date_day日期格式:2008-03-08-- BEGINdecla
- mysql 和 sqlite 区别
Array_06
sqlite
转载:
http://www.cnblogs.com/ygm900/p/3460663.html
mysql 和 sqlite 区别
SQLITE是单机数据库。功能简约,小型化,追求最大磁盘效率
MYSQL是完善的服务器数据库。功能全面,综合化,追求最大并发效率
MYSQL、Sybase、Oracle等这些都是试用于服务器数据量大功能多需要安装,例如网站访问量比较大的。而sq
- pinyin4j使用
oloz
pinyin4j
首先需要pinyin4j的jar包支持;jar包已上传至附件内
方法一:把汉字转换为拼音;例如:编程转换后则为biancheng
/**
* 将汉字转换为全拼
* @param src 你的需要转换的汉字
* @param isUPPERCASE 是否转换为大写的拼音; true:转换为大写;fal
- 微博发送私信
随意而生
微博
在前面文章中说了如和获取登陆时候所需要的cookie,现在只要拿到最后登陆所需要的cookie,然后抓包分析一下微博私信发送界面
http://weibo.com/message/history?uid=****&name=****
可以发现其发送提交的Post请求和其中的数据,
让后用程序模拟发送POST请求中的数据,带着cookie发送到私信的接入口,就可以实现发私信的功能了。
- jsp
香水浓
jsp
JSP初始化
容器载入JSP文件后,它会在为请求提供任何服务前调用jspInit()方法。如果您需要执行自定义的JSP初始化任务,复写jspInit()方法就行了
JSP执行
这一阶段描述了JSP生命周期中一切与请求相关的交互行为,直到被销毁。
当JSP网页完成初始化后
- 在 Windows 上安装 SVN Subversion 服务端
AdyZhang
SVN
在 Windows 上安装 SVN Subversion 服务端2009-09-16高宏伟哈尔滨市道里区通达街291号
最佳阅读效果请访问原地址:http://blog.donews.com/dukejoe/archive/2009/09/16/1560917.aspx
现在的Subversion已经足够稳定,而且已经进入了它的黄金时段。我们看到大量的项目都在使
- android开发中如何使用 alertDialog从listView中删除数据?
aijuans
android
我现在使用listView展示了很多的配置信息,我现在想在点击其中一条的时候填出 alertDialog,点击确认后就删除该条数据,( ArrayAdapter ,ArrayList,listView 全部删除),我知道在 下面的onItemLongClick 方法中 参数 arg2 是选中的序号,但是我不知道如何继续处理下去 1 2 3
- jdk-6u26-linux-x64.bin 安装
baalwolf
linux
1.上传安装文件(jdk-6u26-linux-x64.bin)
2.修改权限
[root@localhost ~]# ls -l /usr/local/jdk-6u26-linux-x64.bin
3.执行安装文件
[root@localhost ~]# cd /usr/local
[root@localhost local]# ./jdk-6u26-linux-x64.bin&nbs
- MongoDB经典面试题集锦
BigBird2012
mongodb
1.什么是NoSQL数据库?NoSQL和RDBMS有什么区别?在哪些情况下使用和不使用NoSQL数据库?
NoSQL是非关系型数据库,NoSQL = Not Only SQL。
关系型数据库采用的结构化的数据,NoSQL采用的是键值对的方式存储数据。
在处理非结构化/半结构化的大数据时;在水平方向上进行扩展时;随时应对动态增加的数据项时可以优先考虑使用NoSQL数据库。
在考虑数据库的成熟
- JavaScript异步编程Promise模式的6个特性
bijian1013
JavaScriptPromise
Promise是一个非常有价值的构造器,能够帮助你避免使用镶套匿名方法,而使用更具有可读性的方式组装异步代码。这里我们将介绍6个最简单的特性。
在我们开始正式介绍之前,我们想看看Javascript Promise的样子:
var p = new Promise(function(r
- [Zookeeper学习笔记之八]Zookeeper源代码分析之Zookeeper.ZKWatchManager
bit1129
zookeeper
ClientWatchManager接口
//接口的唯一方法materialize用于确定那些Watcher需要被通知
//确定Watcher需要三方面的因素1.事件状态 2.事件类型 3.znode的path
public interface ClientWatchManager {
/**
* Return a set of watchers that should
- 【Scala十五】Scala核心九:隐式转换之二
bit1129
scala
隐式转换存在的必要性,
在Java Swing中,按钮点击事件的处理,转换为Scala的的写法如下:
val button = new JButton
button.addActionListener(
new ActionListener {
def actionPerformed(event: ActionEvent) {
- Android JSON数据的解析与封装小Demo
ronin47
转自:http://www.open-open.com/lib/view/open1420529336406.html
package com.example.jsondemo;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;
impor
- [设计]字体创意设计方法谈
brotherlamp
UIui自学ui视频ui教程ui资料
从古至今,文字在我们的生活中是必不可少的事物,我们不能想象没有文字的世界将会是怎样。在平面设计中,UI设计师在文字上所花的心思和功夫最多,因为文字能直观地表达UI设计师所的意念。在文字上的创造设计,直接反映出平面作品的主题。
如设计一幅戴尔笔记本电脑的广告海报,假设海报上没有出现“戴尔”两个文字,即使放上所有戴尔笔记本电脑的图片都不能让人们得知这些电脑是什么品牌。只要写上“戴尔笔
- 单调队列-用一个长度为k的窗在整数数列上移动,求窗里面所包含的数的最大值
bylijinnan
java算法面试题
import java.util.LinkedList;
/*
单调队列 滑动窗口
单调队列是这样的一个队列:队列里面的元素是有序的,是递增或者递减
题目:给定一个长度为N的整数数列a(i),i=0,1,...,N-1和窗长度k.
要求:f(i) = max{a(i-k+1),a(i-k+2),..., a(i)},i = 0,1,...,N-1
问题的另一种描述就
- struts2处理一个form多个submit
chiangfai
struts2
web应用中,为完成不同工作,一个jsp的form标签可能有多个submit。如下代码:
<s:form action="submit" method="post" namespace="/my">
<s:textfield name="msg" label="叙述:">
- shell查找上个月,陷阱及野路子
chenchao051
shell
date -d "-1 month" +%F
以上这段代码,假如在2012/10/31执行,结果并不会出现你预计的9月份,而是会出现八月份,原因是10月份有31天,9月份30天,所以-1 month在10月份看来要减去31天,所以直接到了8月31日这天,这不靠谱。
野路子解决:假设当天日期大于15号
- mysql导出数据中文乱码问题
daizj
mysql中文乱码导数据
解决mysql导入导出数据乱码问题方法:
1、进入mysql,通过如下命令查看数据库编码方式:
mysql> show variables like 'character_set_%';
+--------------------------+----------------------------------------+
| Variable_name&nbs
- SAE部署Smarty出现:Uncaught exception 'SmartyException' with message 'unable to write
dcj3sjt126com
PHPsmartysae
对于SAE出现的问题:Uncaught exception 'SmartyException' with message 'unable to write file...。
官方给出了详细的FAQ:http://sae.sina.com.cn/?m=faqs&catId=11#show_213
解决方案为:
01
$path
- 《教父》系列台词
dcj3sjt126com
Your love is also your weak point.
你的所爱同时也是你的弱点。
If anything in this life is certain, if history has taught us anything, it is
that you can kill anyone.
不顾家的人永远不可能成为一个真正的男人。 &
- mongodb安装与使用
dyy_gusi
mongo
一.MongoDB安装和启动,widndows和linux基本相同
1.下载数据库,
linux:mongodb-linux-x86_64-ubuntu1404-3.0.3.tgz
2.解压文件,并且放置到合适的位置
tar -vxf mongodb-linux-x86_64-ubun
- Git排除目录
geeksun
git
在Git的版本控制中,可能有些文件是不需要加入控制的,那我们在提交代码时就需要忽略这些文件,下面讲讲应该怎么给Git配置一些忽略规则。
有三种方法可以忽略掉这些文件,这三种方法都能达到目的,只不过适用情景不一样。
1. 针对单一工程排除文件
这种方式会让这个工程的所有修改者在克隆代码的同时,也能克隆到过滤规则,而不用自己再写一份,这就能保证所有修改者应用的都是同一
- Ubuntu 创建开机自启动脚本的方法
hongtoushizi
ubuntu
转载自: http://rongjih.blog.163.com/blog/static/33574461201111504843245/
Ubuntu 创建开机自启动脚本的步骤如下:
1) 将你的启动脚本复制到 /etc/init.d目录下 以下假设你的脚本文件名为 test。
2) 设置脚本文件的权限 $ sudo chmod 755
- 第八章 流量复制/AB测试/协程
jinnianshilongnian
nginxluacoroutine
流量复制
在实际开发中经常涉及到项目的升级,而该升级不能简单的上线就完事了,需要验证该升级是否兼容老的上线,因此可能需要并行运行两个项目一段时间进行数据比对和校验,待没问题后再进行上线。这其实就需要进行流量复制,把流量复制到其他服务器上,一种方式是使用如tcpcopy引流;另外我们还可以使用nginx的HttpLuaModule模块中的ngx.location.capture_multi进行并发
- 电商系统商品表设计
lkl
DROP TABLE IF EXISTS `category`; -- 类目表
/*!40101 SET @saved_cs_client = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `category` (
`id` int(11) NOT NUL
- 修改phpMyAdmin导入SQL文件的大小限制
pda158
sqlmysql
用phpMyAdmin导入mysql数据库时,我的10M的
数据库不能导入,提示mysql数据库最大只能导入2M。
phpMyAdmin数据库导入出错: You probably tried to upload too large file. Please refer to documentation for ways to workaround this limit.
- Tomcat性能调优方案
Sobfist
apachejvmtomcat应用服务器
一、操作系统调优
对于操作系统优化来说,是尽可能的增大可使用的内存容量、提高CPU的频率,保证文件系统的读写速率等。经过压力测试验证,在并发连接很多的情况下,CPU的处理能力越强,系统运行速度越快。。
【适用场景】 任何项目。
二、Java虚拟机调优
应该选择SUN的JVM,在满足项目需要的前提下,尽量选用版本较高的JVM,一般来说高版本产品在速度和效率上比低版本会有改进。
J
- SQLServer学习笔记
vipbooks
数据结构xml
1、create database school 创建数据库school
2、drop database school 删除数据库school
3、use school 连接到school数据库,使其成为当前数据库
4、create table class(classID int primary key identity not null)
创建一个名为class的表,其有一