1.Spring-loaded项目核心作者Andy Clement github主页: https://github.com/aclement 可以看到是一个开源大神.2.往来邮件,其中有很多东西值得学习:尤其是红色部分2015年6月26日Hi,Really all the docs is what I wrote in that bug report: https://github.com/spring-projects/spring-loaded/issues/70
Yes you need javaagent (and noverify), the -Dspringloaded=watchJars=foo.jar:bar.jar part is just the options that get passed to the agent to configure the behavior.There are a couple of regression tests in the class: SpringLoadedTestsInSeparateJVMRemember that you only need the short part of the jar name (foo.jar), I’m not sure what will happen if you fully qualify the path to the jar.You could turn on -Dspringloaded=verbose to check spring loaded is basically functioning (can’t recall if I added extra verbose output specifically for jar reloading).cheers,AndyOn Jun 23, 2015, at 5:09 AM, landon <340706410@qq.com> wrote:Hi, I'm a software engineer in china.I'm interested in spring-loaded recently.But pre 1.2.3,it's only reload calsses.In github,i saw you said 1.2.4 can do reload class files in jar. eg,with -Dspringloaded=watchJars parameters. My question is: 1.Can you give a detail examples,it's also need -javaagent? 2.I build a jar using the master code in github,but i test it's no effect to reload jar files.I want to know when the 1.2.4 version can support the function. _____________________ Thanks very much. Best Regards.2015年6月29日Hi,Possibly it could be a windows thing I suppose. This works perfectly for me:Code.java===public class Code { public static void main(String []argv) { while (true) { new Bar().run(); try { Thread.sleep(2000); } catch (Exception e) {} } }}===Bar.java===public class Bar { public void run() { System.out.println(“one"); }}===javac *.javajar -cvMf spring-load-example-main.jar Code.classjar -cvMf spring-load-example-extra.jar Bar.classjava -classpath spring-load-example-main.jar:spring-load-example-extra.jar -Dspringloaded="verbose;watchJars=spring-load-example-extra.jar" -javaagent:/Users/aclement/gits/spring-loaded/springloaded/build/libs/springloaded-1.2.4.BUILD-SNAPSHOT.jar -noverify CodeThis will print ‘one’ every second.Then I change Bar, edit the ‘one’ and replace with ‘two’. Then:javac Bar.javajar -cvMf newjar.jar Bar.classmv newjar.jar spring-load-example-extra.jarThis triggers some trace output and then it starts printing two:INFO: Observed last modification time change for /Users/aclement/gits/spring-loaded/springloaded/build/libs/play/spring-load-example-extra.jar (lastScanTime=1435594228140)Jun 29, 2015 9:10:29 AM org.springsource.loaded.agent.Watcher determineChangesSinceINFO: Firing file changed event /Users/aclement/gits/spring-loaded/springloaded/build/libs/play/spring-load-example-extra.jar…Reloading: Loading new version of Bar [PH0x0kq]…twotwotwoThis is on a mac. Can you look at the timestamps of your files inside the jar? Confirm it is changing to something more recent inside the jar? That is what is being used to determine if an update occurred.> can the spring-loaded used to the production environment?Nothing prevents it but it does add significant overhead to running code because it introduces a lot of indirection to make the reloading work.cheers,AndyOn Jun 28, 2015, at 7:29 PM, landon <340706410@qq.com> wrote:Hi, I'm so excited to receive your reply.Thanks very much. I say my example: I have two jars,spring-load-example-main.jar,spring-load-example-extra.jar,The former depends on the latter.The classes in spring-loaded-example-extra.jar often changes,so i want to reload the jar using spring-loaded. My Launch script is: @echo off cd /d %~dp0 java -Dspringloaded=verbose;explain;watchJars=spring-load-example-extra.jar -javaagent:springloaded-1.2.4.BUILD-SNAPSHOT.jar -noverify -cp spring-load-example-main.jar;spring-load-example-extra.jar com.mavsplus.example.springloaded.SpringLoadedExample The spring-load-example-main.jar,spring-load-example-extra.jar,springloaded-1.2.4.BUILD-SNAPSHOT.jar are in the same directory.When i want to reload the spring-load-example-extra.jar,i repackage the jar and replace to the directory and override it,but it has no effect.That's all.I also used jrebel,it can reload ja,but must assign the monitor reload jar classes dirctory,i also cannot to ovverride the reload jar to reache the reload goal. And Finally i want to ask: can the spring-loaded used to the production environment?2015年6月30日Hi,Sorry about that - I made the change you noticed to correctly use File.separator and committed that (thanks for telling me about it). I notice a TODO had been left there saying to sort it out for windows! ->I ask another question,i know if used to production environment,it maybe has some performance loss.To avoid it,i suggest,when we decide to reload the jar,we can send a message to notice to reload,and to avoid must be monitor the jar change every seconds. ->can extract a mini-framework only to reload jars. ->or can add a switch,by the switch,we can reload jars manually? if above can reduce the performance loss?It isn’t the act of watching the jar that is expensive or the act of loading the jar changes into the system. Basically for code to support reloading it goes through a massive transformation process at loadtime, this transformed byte code is slower, but it needs to be done up front just in case you reload anything. To minimize the performance impact you would reduce what is made reloadable - so in the jar watching case watch as few jars as possible. Maybe break big jars into smaller ones so you can watch only a subset of the jars.cheers,AndyOn Jun 30, 2015, at 3:00 AM, landon <340706410@qq.com> wrote:Hi, First,Thanks very much to reply me. Okay,I Got the reason,you are right,it's the os environment problem.I Browse the source code,i find the code,{@link org.springsource.loaded.TypeRegistry#private boolean couldBeReloadable(String slashedName)},The method 689L: int lastSlashPos = slashedName.lastIndexOf('/'); The Seperator is unix seperator,not windows.I change it to the cross-platform code: int lastSlashPos = slashedName.lastIndexOf(File.separator); And finally,I rebuild the source code and got the new jar.I tested,it can reload jars perfectly! ->I ask another question,i know if used to production environment,it maybe has some performance loss.To avoid it,i suggest,when we decide to reload the jar,we can send a message to notice to reload,and to avoid must be monitor the jar change every seconds. ->can extract a mini-framework only to reload jars. ->or can add a switch,by the switch,we can reload jars manually? if above can reduce the performance loss?
2015-7-2
Hey,Actually email is probably the best way to communicate on this, I don’t work on spring loaded all that much, only occasionally.
->two jars,main.jar and patch.jar,when launch main,i used a classloader load classes in patch.jar and put them to a Map,and some logic used the class intance...when some logic changes,i send a message(eg.use http) to the main process(it's a network program,can listen),when receive the message,i used another classloader to load the new patch.jar and re-fill the Map.By this method,i can implement some hot-swap logics,new request can used the new classes from Map...
I think there are use cases where that can work fine and you don’t need the full flexibility of a general purpose reloading system like spring loaded. You just have to make sure those instances don’t leak into other places where you can’t keep track of them as you’ll want to get rid of all of them when loading a new version.
->another question is:i think the hot-loaded has a deadly problem is : the Data in the class instance or in the memory...when reload the new class,the data in the old class instance was lost...
to avoid it,in the class implemention,only have method/logic,not has property/data...put all data to a common place...but in my opinion,in oop,data and actions in fact ,they are together...so this is the confict.
->so can you give me some suggestion or give me a good practice?
With spring loaded the class instances remain around, they change on the fly to support new fields and methods are not rebuilt. This can cause issues because constructors are not re-run for pre-existing instances and so new fields added to existing objects may not be set. I think, in your case, you can break encapsulation by keeping state separation to behaviour if it is necessary and helpful for your use case - don’t be forced to keep them together if it makes your system less flexible than you need. I don’t see why you can’t have a bean that keeps state and then a class something like XXXOperator that operates on those state objects. Or perhaps you could have a constructor on your objects that takes in one of the older objects and copies the state into the new instance before you discard the older object.
cheers,
Andy
Hi,
So excited to reply me.Thank you.
Here, i have two questions want to interchange with you.
->I write a function used to reload jar.The implementation is:
->two jars,main.jar and patch.jar,when launch main,i used a classloader load classes in patch.jar and put them to a Map,and some logic used the class intance...when some logic changes,i send a message(eg.use http) to the main process(it's a network program,can listen),when receive the message,i used another classloader to load the new patch.jar and re-fill the Map.By this method,i can implement some hot-swap logics,new request can used the new classes from Map...
->how would you evaluate my way?
->another question is:i think the hot-loaded has a deadly problem is : the Data in the class instance or in the memory...when reload the new class,the data in the old class instance was lost...
to avoid it,in the class implemention,only have method/logic,not has property/data...put all data to a common place...but in my opinion,in oop,data and actions in fact ,they are together...so this is the confict.
->so can you give me some suggestion or give me a good practice?
->finally,can you give a contact way the except email.i think it's low efficiency.
Cherrs.
3.感受 1.开源的力量真是伟大! 2.开源大神的回复真是给力! 3.我也会加入开源的大军中!
posted on 2015-07-01 21:06
landon 阅读(6687)
评论(3) 编辑 收藏 所属分类:
JVM 、
HotSwap