- 一个 tomcat 究竟能接收多少并发请求
热带鱼2020
java
对tomcat来说,每一个进来的请求都需要一个线程,直到该请求结束。如果同时进来的请求多于当前可用的请求处理线程数,额外的线程就会被创建,直到到达配置的最大线程数(maxThreads属性值)。如果仍就同时接收到更多请求,这些来不及处理的请求就会在Connector创建的ServerSocket中堆积起来,直到到达最大的配置值(acceptCount属性值)。至此,任何再来的请求将会收到conne
- python 多线程并发_python多线程并发实例及其优化
weixin_39926103
python多线程并发
单线程执行python的内置模块提供了两个内置模块:thread和threading,thread是源生模块,threading是扩展模块,在thread的基础上进行了封装及改进。所以只需要使用threading这个模块就能完成并发的测试实例创建并启动一个单线程importthreadingdefmyTestFunc():print("我是一个函数")t=threading.Thread(targ
- 多线程
拜拜的纸
java学习java多线程
多线程(java.thread)1.线程简介多线程指多条路径,每个线程都有自己的工作内存,负责和主内存进行交互方法间调用:普通方法调用,从哪里来到哪里去,闭合的一条路径,程序执行时必须等方法调用完才能往下执行多线程使用:开辟了多条路径,不需要等到方法执行完就可以往下执行2.线程实现实现线程的三种方式:继承Thread类(实现run()方法,调用时执行Thread类的start()方法)实现Runn
- 性能优化-Spring参数配置、数据库连接参数配置、JVM调优
经年小栈
Java基础性能优化spring数据库
SpringBoot配置参数server:tomcat:#线程池配置max-threads:200#最大工作线程数(建议:2~4倍CPU核心数,如16核设200-400)min-spare-threads:20#最小空闲线程(应对突发流量,建议:max-threads的10%~20%)#连接控制max-connections:10000#最大连接数(需结合系统句柄数ulimit-n设置,建议:系统
- XmlDocument和XDocument转String
weixin_33973600
1:XDocument转String直接使用ToString();XNode里面重写了ToString()方法2:XmlDocument转String需要写代码1usingSystem;2usingSystem.Collections.Generic;3usingSystem.Linq;4usingSystem.Text;5usingSystem.Threading.Tasks;6usingSys
- Unity中Socket_TCP异步连接,加入断线检测以及重连功能(服务端客户端源码)
杰尼杰尼丶
Socketunitytcp/ip服务器
1、服务端usingSystem;usingSystem.Collections.Generic;usingSystem.Text;#region命名空间usingSystem.Net;usingSystem.Net.Sockets;usingSystem.Threading;usingUnityEngine;#endregionnamespaceAsynServerConsole{//////T
- python 并发函数
逃夭丶
github_pagepython开发语言
python并发函数前言工作需要向几十万表写入亿级别数据,想使用pyhon的并发执行。才开始使用ThreadPoolExecutor发现奇慢无比,大佬说这其实是串行,并发得用multiprocessing,立帖研究。本文以python3.10为例,学习一下python的并发执行。并发执行python并发执行分三个方面:多线程(threading)、多进程(multiprocessing)、多协程(
- python 并发执行
huguangshanse00
pythonpythonthread并发
(1)需要执行python程序如下:#!/usr/bin/envpythonimportos,sysimportthreadingfromtimeimportsleep,ctimeIpFileName='iplist.txt'shellFileName='shell.sh'iplist=[]classThreadFunc(object):def__init__(self,func,args,nam
- Python系列之Python并发执行实现方法
solihawk
pythonpython
1、Python中并发执行实现方法1.1Python中并发执行实现在Python中,有几种主要的并发执行实现方法,包括多线程、多进程和异步编程。1.1.1多线程(Threading)Python标准库中的threading模块支持多线程编程。然而,由于Python的全局解释器锁(GIL),Python的多线程在CPU密集型任务上并不能实现真正的并行执行。但在I/O密集型任务(如网络请求、文件读写等
- Java多线程与高并发入门到精通(带视频讲解)
hweiyu00
分享java开发语言
概述Java多线程与高并发是构建高性能、高可用系统的核心技术,涉及的知识点广泛且深入。以下是其主要内容的系统梳理。一、多线程基础线程创建与生命周期•线程创建的三种方式:继承Thread类、实现Runnable接口、使用Callable和Future。•线程状态:新建(New)、就绪(Runnable)、运行(Running)、阻塞(Blocked)、等待(Waiting)、超时等待(TimedWa
- [Python]锁
思则变
python开发语言
目录1.什么是锁?2.互斥锁的使用3.为何要使用锁?4.可重入锁(RLock)5.饱受争议的GIL(全局锁)1.什么是锁?在开发中,锁可以理解为通行证。当你对一段逻辑代码加锁时,意味着在同一时间有且仅能有一个线程在执行这段代码。在Python中的锁可以分为两种:互斥锁可重入锁2.互斥锁的使用来简单看下代码,学习如何加锁,获取钥匙,释放锁。importthreading#生成锁对象,全局唯一lock
- Python基础系列讲解——线程锁Lock的使用介绍
Python-Jack
Python入门教程100天
我们知道Python的线程是封装了底层操作系统的线程,在Linux系统中是Pthread(全称为POSIXThread),在Windows中是WindowsThread。因此Python的线程是完全受操作系统的管理的。但是在计算密集型的任务中多线程反而比单线程更慢。这是为什么呢?在CPython解释器中执行线程时,每一个线程开始执行时,都会锁住GIL,以阻止别的线程执行。同样的,每一个线程执行完一
- Python中锁的常见用法
今晚务必早点睡
Pythonpython开发语言
在Python中,可以使用线程锁来控制多个线程对共享资源的访问。以下是一些常见的Python中锁的用法:创建线程锁在Python中,可以使用threading模块中的Lock类来创建线程锁。例如:importthreading#创建线程锁lock=threading.Lock()获取锁要访问共享资源,需要先获取锁。如果当前锁已经被占用,那么acquire()方法将会阻塞当前线程,直到锁被释放。例如
- 【Python】锁(Lock)的类型详解
彬彬侠
Python基础线程锁进程锁可重入锁信号量条件变量事件python
在Python中,锁(Lock)是threading和multiprocessing模块提供的同步机制,用于防止多个线程或进程同时访问共享资源,从而避免数据竞争和不一致问题。1.threading.Lock()(线程锁)用于在多线程环境下防止多个线程同时访问共享资源。示例:多个线程访问共享变量importthreadingimporttimecounter=0#共享变量lock=threading
- C语言编写线程池的简单实现方法
weixin_33755554
c/c++数据结构与算法python
2019独角兽企业重金招聘Python工程师标准>>>好文章,一起分享——有时我们会需要大量线程来处理一些相互独立的任务,为了避免频繁的申请释放线程所带来的开销,我们可以使用线程池。下面是一个C语言实现的简单的线程池。头文件:1:#ifndefTHREAD_POOL_H__2:#defineTHREAD_POOL_H__3: 4:#include5: 6:/*要执行的任务链表*/7:typedef
- Python 封装 socket 为 [TCP/UDP/MULTICAST] 服务端
one-ccs
Pythonpythontcp/ipudpsocket
在新线程中创建TCP/UDP/MULTICAST协议的服务端套接字,接收客户端的连接请求或数据,并调用on_recv回调函数处理数据。#!/usr/bin/envpython#-*-coding:utf-8-*-importsocketimportthreadingimportmultiprocessingclassServerSocket:def__init__(self,*,protocol:
- 在 JMeter 中,Active Threads Over Time 是一个非常有用的监听器(Listener)
噔噔噔噔@
软件测试面试题专栏软件测试基础及工具分享jmeter
在JMeter中,ActiveThreadsOverTime是一个非常有用的监听器(Listener),它可以帮助你实时观察测试过程中活跃线程数(并发用户数)的变化趋势,从而分析系统的并发处理能力和负载情况。1.ActiveThreadsOverTime的作用实时监控并发用户数:显示测试过程中活跃线程(VirtualUsers)的数量变化。分析负载模式:检查线程启动、稳定期、关闭阶段的并发情况。结
- 复现deep_sort_yolov3--demo.py
聿默
目标跟踪tensorflowkeras
0.环境opencv-python==4.1.0.25/4.1.2.30Pillowscikit-learn==0.19.2numpy==1.15.0keras==2.2.4tensorflow==1.12.0imutils1.修改1.1在deep_sort添加videocaptureasync.pyimportthreadingimportcv2classVideoCaptureAsync:de
- CPU工作方式、多核心、超线程技术详解[转贴]
十飞我谁
计算机硬件超线程多线程
转自:https://www.cnblogs.com/taiyonghai/p/7244878.htmlCPU是一台电脑的灵魂,决定电脑整体性能。现在的主流CPU都是多核的,有的运用了多线程技术(Hyper-threading,简称HT)。多核可能还容易理解些,相信不少玩家都能说出个所以然。但超线程是个什么东西,究竟有什么实际意义,一个支持超线程的CPU开启和关闭HT有什么不同,能解释清楚的人可能
- springboot 集成ThreadPoolTaskExecutor
IT_Octopus
springboot后端java
@ConfigurationpublicclassThreadPoolsConfig{@Value("${thread.pool.core-size.add:5}")//默认值5privateintcorePoolSizeAdd;@Value("${thread.pool.max-size.add:10}")//默认值10privateintmaxPoolSizeAdd;@Value("${thr
- mysql查看连接池最大连接数以及连接使用情况
Cold_Blooder
数据库
12showvariableslike'%max_connection%';查看最大连接数setglobalmax_connections=1000;重新设置最大连接数1234567891011mysql>showstatuslike'Threads%';+-------------------+-------+|Variable_name|Value|+-------------------+-
- 【Muduo源码分析】 解读muduo如何断开连接 TcpConnection
hello_ape
MuduoMuduoLinux网络编程
在muduo中只有一种连接断开方式,就是被动关闭,也就是套接字上read返回0.(当然现在也加上了主动关闭),本文探讨被动关闭的流程。首先TcpConnection::handleRead中,如果read返回0,去执行handleClose。voidTcpConnection::handleRead(TimestampreceiveTime){loop_->assertInLoopThread()
- 【并发编程】多线程安全问题,如何避免死锁
阿Q说代码
并发专栏java并发编程线程安全多线程死锁
文章目录概念进程线程对比代码使用进程线程线程创建方式线程的生命周期和状态停止线程方法介绍sleep()/wait()为什么wait()不被定义在Thread中?sleep()定义在Thread中?run()/start()为什么使用多线程?线程安全问题线程死锁如何避免死锁?总结从今天开始阿Q将陆续更新java并发编程专栏,期待您的订阅。在系统学习线程之前,我们先来了解一下它的概念,与经常提到的进程
- 中职网络安全 MSF 漏洞 自动利用脚本 Python C模块
qq3332129724(中职生)
web安全python安全
importosimportipaddressimportqueueimportsocketimportthreadingimportrandomfromscapy.layers.inetimportIP,ICMP,sr1q=queue.Queue()q2=queue.Queue()port=1000defget_ip(host):ip=ipaddress.ip_network(host).hos
- KiActivateWaiterQueue函数和Queue->Header.WaitListHead队列等待列表的关系
sitelist
nt4源代码分析ActivateWaiterQWaiterQueueWaitListHead
第一部分:if(Thread->ApcState.KernelApcPending&&(Thread->SpecialApcDisable==0)&&(Thread->WaitIrqlHeader.WaitListHead,&WaitBlock->WaitListEntry);VOIDFORCEINLINEInsertTailList(INPLIST_ENTRYListHead,INPLIST_E
- Java之多线程(6个demo)
nuist__NJUPT
JavaSEjavajvm开发语言多线程线程同步
本文主要介绍Java中多线程,在Java中启动多线程的方法包括:继承Thread类或者实现Runnable接口,介绍了设置线程名称,设置线程优先级,设置守护线程等,介绍了线程同步,使用synchronized关键字和lock锁分别实现线程同步,解决线程安全问题,介绍了生产者和消费者模式,涉及线程延迟,等待,唤醒的方法。目录1-继承Thread类并重写run()方法实现多线程2-线程控制(设置主线程
- Linux 自旋锁
南风与鱼
Linuxlinux自旋锁
目录一、什么是自旋锁?工作原理优点与缺点二、自旋锁的实现三、内核APIpthread_spin_lockpthread_spin_trylockpthread_spin_unlockpthread_spin_initpthread_spin_destroy四、自旋锁的适用场景一、什么是自旋锁?自旋锁是一种多线程同步机制,用于保护共享资源免受并发访问的影响。它的核心思想是:当一个线程尝试获取锁时,如
- LangGraph异步化sqlite checkpoint
花开终为谢
sqlitelanggraphpython
安装pipinstalllanggraph-checkpoint-sqlite异步checkpiont初始化:fromlanggraph.checkpoint.sqlite.aioimportAsyncSqliteSaverconn=aiosqlite.connect(":memory:",check_same_thread=False)memory=AsyncSqliteSaver(conn)如
- 线程局部存储(TLS)
唯独失去了从容
开发语言etl工程师
很多时候,我们可能想存储一些线程的私有数据,属于线程的私有变量有局部变量,函数的参数,假如我们要在线程中存储全局变量,多个线程访问都对这个变量有自己的一个副本。一、隐式实现__threadinta;//linux__declspecinta;//windowswindows的tls实现原理,编译器会把a变量放到PE文件的.tls段中,当系统启动一个线程时候,会从进程的堆中分配一块足够的大小空间,然
- Java多线程入门指南
小白的一叶扁舟
Java开发java开发语言多线程springboot
一、Thread和ThreadLocal区别ThreadLocal和Thread是Java中两个与线程相关的概念,它们在多线程编程中有不同的作用和使用场景。1.ThreadThread是Java中表示一个线程的类。每个Thread对象表示一个单独的执行路径,即程序中的一个执行流。Java中的多线程是通过创建Thread对象来实现的。每个Thread可以拥有自己的执行逻辑,通常是通过继承Thread
- 312个免费高速HTTP代理IP(能隐藏自己真实IP地址)
yangshangchuan
高速免费superwordHTTP代理
124.88.67.20:843
190.36.223.93:8080
117.147.221.38:8123
122.228.92.103:3128
183.247.211.159:8123
124.88.67.35:81
112.18.51.167:8123
218.28.96.39:3128
49.94.160.198:3128
183.20
- pull解析和json编码
百合不是茶
androidpull解析json
n.json文件:
[{name:java,lan:c++,age:17},{name:android,lan:java,age:8}]
pull.xml文件
<?xml version="1.0" encoding="utf-8"?>
<stu>
<name>java
- [能源与矿产]石油与地球生态系统
comsci
能源
按照苏联的科学界的说法,石油并非是远古的生物残骸的演变产物,而是一种可以由某些特殊地质结构和物理条件生产出来的东西,也就是说,石油是可以自增长的....
那么我们做一个猜想: 石油好像是地球的体液,我们地球具有自动产生石油的某种机制,只要我们不过量开采石油,并保护好
- 类与对象浅谈
沐刃青蛟
java基础
类,字面理解,便是同一种事物的总称,比如人类,是对世界上所有人的一个总称。而对象,便是类的具体化,实例化,是一个具体事物,比如张飞这个人,就是人类的一个对象。但要注意的是:张飞这个人是对象,而不是张飞,张飞只是他这个人的名字,是他的属性而已。而一个类中包含了属性和方法这两兄弟,他们分别用来描述对象的行为和性质(感觉应该是
- 新站开始被收录后,我们应该做什么?
IT独行者
PHPseo
新站开始被收录后,我们应该做什么?
百度终于开始收录自己的网站了,作为站长,你是不是觉得那一刻很有成就感呢,同时,你是不是又很茫然,不知道下一步该做什么了?至少我当初就是这样,在这里和大家一份分享一下新站收录后,我们要做哪些工作。
至于如何让百度快速收录自己的网站,可以参考我之前的帖子《新站让百
- oracle 连接碰到的问题
文强chu
oracle
Unable to find a java Virtual Machine--安装64位版Oracle11gR2后无法启动SQLDeveloper的解决方案
作者:草根IT网 来源:未知 人气:813标签:
导读:安装64位版Oracle11gR2后发现启动SQLDeveloper时弹出配置java.exe的路径,找到Oracle自带java.exe后产生的路径“C:\app\用户名\prod
- Swing中按ctrl键同时移动鼠标拖动组件(类中多借口共享同一数据)
小桔子
java继承swing接口监听
都知道java中类只能单继承,但可以实现多个接口,但我发现实现多个接口之后,多个接口却不能共享同一个数据,应用开发中想实现:当用户按着ctrl键时,可以用鼠标点击拖动组件,比如说文本框。
编写一个监听实现KeyListener,NouseListener,MouseMotionListener三个接口,重写方法。定义一个全局变量boolea
- linux常用的命令
aichenglong
linux常用命令
1 startx切换到图形化界面
2 man命令:查看帮助信息
man 需要查看的命令,man命令提供了大量的帮助信息,一般可以分成4个部分
name:对命令的简单说明
synopsis:命令的使用格式说明
description:命令的详细说明信息
options:命令的各项说明
3 date:显示时间
语法:date [OPTION]... [+FORMAT]
- eclipse内存优化
AILIKES
javaeclipsejvmjdk
一 基本说明 在JVM中,总体上分2块内存区,默认空余堆内存小于 40%时,JVM就会增大堆直到-Xmx的最大限制;空余堆内存大于70%时,JVM会减少堆直到-Xms的最小限制。 1)堆内存(Heap memory):堆是运行时数据区域,所有类实例和数组的内存均从此处分配,是Java代码可及的内存,是留给开发人
- 关键字的使用探讨
百合不是茶
关键字
//关键字的使用探讨/*访问关键词private 只能在本类中访问public 只能在本工程中访问protected 只能在包中和子类中访问默认的 只能在包中访问*//*final 类 方法 变量 final 类 不能被继承 final 方法 不能被子类覆盖,但可以继承 final 变量 只能有一次赋值,赋值后不能改变 final 不能用来修饰构造方法*///this()
- JS中定义对象的几种方式
bijian1013
js
1. 基于已有对象扩充其对象和方法(只适合于临时的生成一个对象):
<html>
<head>
<title>基于已有对象扩充其对象和方法(只适合于临时的生成一个对象)</title>
</head>
<script>
var obj = new Object();
- 表驱动法实例
bijian1013
java表驱动法TDD
获得月的天数是典型的直接访问驱动表方式的实例,下面我们来展示一下:
MonthDaysTest.java
package com.study.test;
import org.junit.Assert;
import org.junit.Test;
import com.study.MonthDays;
public class MonthDaysTest {
@T
- LInux启停重启常用服务器的脚本
bit1129
linux
启动,停止和重启常用服务器的Bash脚本,对于每个服务器,需要根据实际的安装路径做相应的修改
#! /bin/bash
Servers=(Apache2, Nginx, Resin, Tomcat, Couchbase, SVN, ActiveMQ, Mongo);
Ops=(Start, Stop, Restart);
currentDir=$(pwd);
echo
- 【HBase六】REST操作HBase
bit1129
hbase
HBase提供了REST风格的服务方便查看HBase集群的信息,以及执行增删改查操作
1. 启动和停止HBase REST 服务 1.1 启动REST服务
前台启动(默认端口号8080)
[hadoop@hadoop bin]$ ./hbase rest start
后台启动
hbase-daemon.sh start rest
启动时指定
- 大话zabbix 3.0设计假设
ronin47
What’s new in Zabbix 2.0?
去年开始使用Zabbix的时候,是1.8.X的版本,今年Zabbix已经跨入了2.0的时代。看了2.0的release notes,和performance相关的有下面几个:
:: Performance improvements::Trigger related da
- http错误码大全
byalias
http协议javaweb
响应码由三位十进制数字组成,它们出现在由HTTP服务器发送的响应的第一行。
响应码分五种类型,由它们的第一位数字表示:
1)1xx:信息,请求收到,继续处理
2)2xx:成功,行为被成功地接受、理解和采纳
3)3xx:重定向,为了完成请求,必须进一步执行的动作
4)4xx:客户端错误,请求包含语法错误或者请求无法实现
5)5xx:服务器错误,服务器不能实现一种明显无效的请求
- J2EE设计模式-Intercepting Filter
bylijinnan
java设计模式数据结构
Intercepting Filter类似于职责链模式
有两种实现
其中一种是Filter之间没有联系,全部Filter都存放在FilterChain中,由FilterChain来有序或无序地把把所有Filter调用一遍。没有用到链表这种数据结构。示例如下:
package com.ljn.filter.custom;
import java.util.ArrayList;
- 修改jboss端口
chicony
jboss
修改jboss端口
%JBOSS_HOME%\server\{服务实例名}\conf\bindingservice.beans\META-INF\bindings-jboss-beans.xml
中找到
<!-- The ports-default bindings are obtained by taking the base bindin
- c++ 用类模版实现数组类
CrazyMizzz
C++
最近c++学到数组类,写了代码将他实现,基本具有vector类的功能
#include<iostream>
#include<string>
#include<cassert>
using namespace std;
template<class T>
class Array
{
public:
//构造函数
- hadoop dfs.datanode.du.reserved 预留空间配置方法
daizj
hadoop预留空间
对于datanode配置预留空间的方法 为:在hdfs-site.xml添加如下配置
<property>
<name>dfs.datanode.du.reserved</name>
<value>10737418240</value>
- mysql远程访问的设置
dcj3sjt126com
mysql防火墙
第一步: 激活网络设置 你需要编辑mysql配置文件my.cnf. 通常状况,my.cnf放置于在以下目录: /etc/mysql/my.cnf (Debian linux) /etc/my.cnf (Red Hat Linux/Fedora Linux) /var/db/mysql/my.cnf (FreeBSD) 然后用vi编辑my.cnf,修改内容从以下行: [mysqld] 你所需要: 1
- ios 使用特定的popToViewController返回到相应的Controller
dcj3sjt126com
controller
1、取navigationCtroller中的Controllers
NSArray * ctrlArray = self.navigationController.viewControllers;
2、取出后,执行,
[self.navigationController popToViewController:[ctrlArray objectAtIndex:0] animated:YES
- Linux正则表达式和通配符的区别
eksliang
正则表达式通配符和正则表达式的区别通配符
转载请出自出处:http://eksliang.iteye.com/blog/1976579
首先得明白二者是截然不同的
通配符只能用在shell命令中,用来处理字符串的的匹配。
判断一个命令是否为bash shell(linux 默认的shell)的内置命令
type -t commad
返回结果含义
file 表示为外部命令
alias 表示该
- Ubuntu Mysql Install and CONF
gengzg
Install
http://www.navicat.com.cn/download/navicat-for-mysql
Step1: 下载Navicat ,网址:http://www.navicat.com/en/download/download.html
Step2:进入下载目录,解压压缩包:tar -zxvf navicat11_mysql_en.tar.gz
- 批处理,删除文件bat
huqiji
windowsdos
@echo off
::演示:删除指定路径下指定天数之前(以文件名中包含的日期字符串为准)的文件。
::如果演示结果无误,把del前面的echo去掉,即可实现真正删除。
::本例假设文件名中包含的日期字符串(比如:bak-2009-12-25.log)
rem 指定待删除文件的存放路径
set SrcDir=C:/Test/BatHome
rem 指定天数
set DaysAgo=1
- 跨浏览器兼容的HTML5视频音频播放器
天梯梦
html5
HTML5的video和audio标签是用来在网页中加入视频和音频的标签,在支持html5的浏览器中不需要预先加载Adobe Flash浏览器插件就能轻松快速的播放视频和音频文件。而html5media.js可以在不支持html5的浏览器上使video和audio标签生效。 How to enable <video> and <audio> tags in
- Bundle自定义数据传递
hm4123660
androidSerializable自定义数据传递BundleParcelable
我们都知道Bundle可能过put****()方法添加各种基本类型的数据,Intent也可以通过putExtras(Bundle)将数据添加进去,然后通过startActivity()跳到下一下Activity的时候就把数据也传到下一个Activity了。如传递一个字符串到下一个Activity
把数据放到Intent
- C#:异步编程和线程的使用(.NET 4.5 )
powertoolsteam
.net线程C#异步编程
异步编程和线程处理是并发或并行编程非常重要的功能特征。为了实现异步编程,可使用线程也可以不用。将异步与线程同时讲,将有助于我们更好的理解它们的特征。
本文中涉及关键知识点
1. 异步编程
2. 线程的使用
3. 基于任务的异步模式
4. 并行编程
5. 总结
异步编程
什么是异步操作?异步操作是指某些操作能够独立运行,不依赖主流程或主其他处理流程。通常情况下,C#程序
- spark 查看 job history 日志
Stark_Summer
日志sparkhistoryjob
SPARK_HOME/conf 下:
spark-defaults.conf 增加如下内容
spark.eventLog.enabled true spark.eventLog.dir hdfs://master:8020/var/log/spark spark.eventLog.compress true
spark-env.sh 增加如下内容
export SP
- SSH框架搭建
wangxiukai2015eye
springHibernatestruts
MyEclipse搭建SSH框架 Struts Spring Hibernate
1、new一个web project。
2、右键项目,为项目添加Struts支持。
选择Struts2 Core Libraries -<MyEclipes-Library>
点击Finish。src目录下多了struts