On 19 December 2017 at 00:35, Andreas Brodbeck <da...@mindclue.ch> wrote:

> Hi all!
>
> I have a performance problem with Fuel (latest stable) on a Pharo 6.1
> (32bit) on Ubuntu 16.04.3 LTS. The serialization and storage to disk of
> 70MB of data takes more than 6 minutes! While the same task on an
> equally powerful Mac takes only 1.5 minutes.
>
> My observation was, that on Linux it is very very slow while writing the
> file. The first 30MB of the file are written very fast, but after that
> the writing speed drops dramatically.
>
> On the same Linux server, but the application running on an old Pharo
> 1.4, the serialization was always as fast as on the Mac.
>
> Attached you see an excerpt of the Pharo Time profiler output for the
> serialization. The profiling tree looks the same on the Mac, just with
> faster times.
>
> What could be the hidden speed eating secret on Linux for Pharo6.1? I
> have absolutely no idea where to search! Memory? Streams? File writing
> support? Something inside Fuel?
>


On 19 December 2017 at 03:45, Henrik-Nergaard <draag...@outlook.com> wrote:

> Hi Andreas,
>
> It looks like you may have problems with hash collisions
> FLLargeIdentityDictionary.
> What are the tally sizes of the FLLargeIdentityDicitonary used when you
> serialize? (If these have a tally larger than ~ 75% of the available size
> (4096 items), then there may well be some performance loss).
>
> You could check if file writing is the problem by measuring the time it
> takes to only serialize in memory.
> You can try to use: "FLSerializer serializeToByteArray: " and see if it
> gives better performance?
>


side comment:
I wonder what could be the performance of hooking  #serializeToByteArray:
up directly to mmap ?
  *
http://forum.world.st/Pharo-Shared-Memory-with-C-executable-td4921928.html
  *
http://forum.world.st/ANN-CPPBridge-One-Ring-to-rule-them-ALL-td4922275.html#a4922302

cheers -ben

Reply via email to