Comments (3)
Also note that if instead of:
c2 := getCompiledModule(ctx, r)
c1.Close(ctx)
doAdd(ctx, r, c2)
I change the order and do this:
c1.Close(ctx)
c2 := getCompiledModule(ctx, r)
doAdd(ctx, r, c2)
Then it works - but there's a problem with that approach. In my real app I have these compiled modules saved in a map and accessed by an independent goroutine. So between closing c1 and loading c2, there's no compiled module ready to instantiate.
I think perhaps something in the runtime instance is stateful with regard to all modules? Thinking it might be the module name, I tried giving them different module names in their configurations - but with the same results.
from wazero.
the underlying issue is that both compiled modules resolve to the same hash
wazero/internal/wasm/module.go
Lines 168 to 170 in 5c70d8b
so when you close the first we are also deleting the cache entry:
wazero/internal/engine/compiler/engine_cache.go
Lines 18 to 26 in 99c057b
a workaround is setting up a disk cache, this way when the key is deleted from the in-memory cache we will reload it from disk; e.g.:
ctx := context.Background()
cc, _ := wazero.NewCompilationCacheWithDir("/tmp/wazerocache")
r := wazero.NewRuntimeWithConfig(ctx,
wazero.NewRuntimeConfig().WithCompilationCache(cc))
this only occurs when you are closing and reloading a module with the same hash; if the module has been actually updated, then the hash should change, and deletion should not affect its cache entry.
from wazero.
// Works first time no problem
c1 := getCompiledModule(ctx, r)
doAdd(ctx, r, c1)
// Fails second time because first module is closed - why?
c2 := getCompiledModule(ctx, r)
c1.Close(ctx) // I want to close c1, but keep c2 ready for use
yeah this patter simply doesn't make sense - why when the binary if the same you want to close the previous one? basically the variable c1 and c2 points to exactly the same objects and you essentially closed the compiled object.
from wazero.
Related Issues (20)
- dirfs.OpenFile can return ENAMETOOLONG even if that is not defined FS.OpenFile in the interface documentation HOT 3
- flaky test: Test_pathOpen_Errors/trailing_slash_on_file on Windows HOT 1
- [Question] How to handle importing memory HOT 4
- compiler(arm64) overflow in call relocations HOT 8
- Can a Runtime be reused in parallel and across multiple mutually-untrusted modules? HOT 2
- Please tell me how to properly handle stdio HOT 3
- GOOS=wasip1 embedding wazero succeeds with wasmtime but fails with wazero on arm64 HOT 5
- Make compilation faster HOT 9
- Support dialing sockets, udp, tcp, unix. HOT 3
- Race condition during module compilation engine HOT 7
- `wazero.NewCompilationCache` creates a `CompilationCache` instance that's not really caching anything HOT 8
- Race condition during module interpretation with `interpreter` engine HOT 1
- When using `Instantiate` & `InstantiateWithConfig` modules are removed implicitly from the in-memory cache
- Binary built with simd128 works with arm64 but fails with amd64 HOT 12
- Plans to support component model? HOT 4
- wasm debug build crashes HOT 9
- performance issue in browser environment HOT 3
- [help want] the program is hangup when read my net file system HOT 1
- [Question] Compilation cache over different versions HOT 1
- `unreachable` error and stack trace if compiled and extra memory, not otherwise HOT 4
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from wazero.