• Hallo liebe Userinnen und User,

    nach bereits längeren Planungen und Vorbereitungen sind wir nun von vBulletin auf Xenforo umgestiegen. Die Umstellung musste leider aufgrund der Serverprobleme der letzten Tage notgedrungen vorverlegt werden. Das neue Forum ist soweit voll funktionsfähig, allerdings sind noch nicht alle der gewohnten Funktionen vorhanden. Nach Möglichkeit werden wir sie in den nächsten Wochen nachrüsten. Dafür sollte es nun einige der Probleme lösen, die wir in den letzten Tagen, Wochen und Monaten hatten. Auch der Server ist nun potenter als bei unserem alten Hoster, wodurch wir nun langfristig den Tank mit Bytes vollgetankt haben.

    Anfangs mag die neue Boardsoftware etwas ungewohnt sein, aber man findet sich recht schnell ein. Wir wissen, dass ihr alle Gewohnheitstiere seid, aber gebt dem neuen Board eine Chance.
    Sollte etwas der neuen oder auch gewohnten Funktionen unklar sein, könnt ihr den "Wo issn da der Button zu"-Thread im Feedback nutzen. Bugs meldet ihr bitte im Bugtracker, es wird sicher welche geben die uns noch nicht aufgefallen sind. Ich werde das dann versuchen, halbwegs im Startbeitrag übersichtlich zu halten, was an Arbeit noch aussteht.

    Neu ist, dass die Boardsoftware deutlich besser für Mobiltelefone und diverse Endgeräte geeignet ist und nun auch im mobilen Style alle Funktionen verfügbar sind. Am Desktop findet ihr oben rechts sowohl den Umschalter zwischen hellem und dunklem Style. Am Handy ist der Hell-/Dunkelschalter am Ende der Seite. Damit sollte zukünftig jeder sein Board so konfigurieren können, wie es ihm am liebsten ist.


    Die restlichen Funktionen sollten eigentlich soweit wie gewohnt funktionieren. Einfach mal ein wenig damit spielen oder bei Unklarheiten im Thread nachfragen. Viel Spaß im ngb 2.0.

PhantomJS - Script crasht nach ~170 Urls

Commodo

NGBler

Registriert
17 Mai 2014
Beiträge
151
/edit2 Kommando zurück, nach 3836 Links ohne Fehlermeldung abgestürzt.

/edit hab aus Verzweifelung mal die alte 1.9.8er Version ausprobiert statt der neuen 2.0.
Und es funktioniert, sogar mit 60% weniger RAM, kein Crash bei 500 oder 1000 Seiten, alles tutti :m.
Niemals eine .0er Version im Produktiveinsatz .....

Wenn ich meine Textdatei mit 500 Seiten starte, crasht das Script 100% reproduzierbar zwischen 160-180 Urls, meistens ohne Fehlermeldung und Dump, manchmal mit Dump, alle paar Jubeljahre sogar mit einer Fehlermeldung.

Bei Github ist tote Hose, da hab ich schon gepostet, ebenso bei Stackoverflow aber da weiss auch keiner so recht wieso weshalb warum bisher und ich häng an diesem Mist schon seit gut 2 Wochen, vielleicht weiss ja jemand von euch was.

PhantomJS has crashed. Please read the crash reporting guide at http://phantomjs.org/crash-reporting.html and file a bug report at https://github.com/ariya/phantomjs/issues/new. Unfortunately, no crash dump is available. (Is %TEMP% (C:\Users\XXX\AppData\Local\Temp) a directory you cannot write?)

PhantomJS has crashed. Please read the crash reporting guide at http://phantomjs.org/crash-reporting.html and file a bug report at https://github.com/ariya/phantomjs/issues/new. Please attach the crash dump file: C:\Users\XXX\AppData\Local\Temp\a4fd6af6-1244-44d3-8938-3aabe298c2fa.dmp
https://www.dropbox.com/s/i3qi5ed33mbblie/500 links -a4fd6af6-1244-44d3-8938-3aabe298c2fa.dmp?dl=1

https://www.dropbox.com/s/najdz9fhdexvav1/500 links- 95ebab5c-859b-40e9-936b-84967471779b.dmp?dl=1

https://www.dropbox.com/s/1d2t8rtev85yf96/500 links - d450c8e1-9728-41c7-ba52-dfef466f0222.dmp?dl=1

QThread::start: Failed to create thread ()

Code:
console.log('Hello, world!');
var fs = require('fs');
var stream = fs.open('500sitemap.txt', 'r');
var webPage = require('webpage');
var i = 1;
var hasFound = Array();
var hasonLoadFinished = Array();

function handle_page(line) {
var page = webPage.create();
page.settings.loadImages = false;
page.open(line, function() {});

page.onResourceRequested = function(requestData, request) {
    var match = requestData.url.match(/example.de\/ac/g)
    if (match != null) {
        hasFound[line] = true;
        var targetString = decodeURI(JSON.stringify(requestData.url));
        var klammerauf = targetString.indexOf("{");
        var jsonobjekt = targetString.substr(klammerauf,     (targetString.indexOf("}") - klammerauf) + 1);
        targetJSON = (decodeURIComponent(jsonobjekt));
        var t = JSON.parse(targetJSON);
        console.log(i + "   " + t + "       " + t['id']);
        request.abort;
    } else {
        //hasFound = false;
        return;
    }

};
page.onLoadFinished = function(status) {    
    if (!hasonLoadFinished[line]) {
        hasonLoadFinished[line] = true;
        if (!hasFound[line]) {
            console.log(i + " :NOT FOUND: " + line);
            console.log("");
        }
        i++;
        setTimeout(page.close, 200);
        nextPage();
    }
}
};

function nextPage() {
var line = stream.readLine();
if (!line) {
    end = Date.now();
    console.log("");
    console.log(((end - start) / 1000) + " Sekunden");
    phantom.exit(0);
}
hasFound[line] = false;
hasonLoadFinished[line] = false;
handle_page(line);
}

start = Date.now();
nextPage();
 
Zuletzt bearbeitet:

Larius

OutOfOrder

Registriert
12 Juli 2013
Beiträge
5.792
Vl hält die Version 2.0 die Session zur Website offen und benötigt explizit ein Close? Das würde zumindest erklären warum du so einen hohen Speicherbedarf hast.
 

Commodo

NGBler

Registriert
17 Mai 2014
Beiträge
151
  • Thread Starter Thread Starter
  • #3
Das soll ja eigentlich mit setTimeout(page.close, 200); gemacht werden?

Lass die beiden grade nochmal mit

Code:
else {
	    request.abort;
            //return;
        }

Code:
page.close();
ohne Timeout

durchlaufen.

1.9.8 hat 130Mb bei ~200 Links, 2.0 hat 350Mb bei 40 Links und steigt bis auf 850, irgendwas hakt da in der neuen Version.

Nachtrag - teste grade nochmal mit 12500 Links:
1.9.8 stabil mit ~690Mb bei 3500 Links soweit.

--- [2015-09-11 12:32 CEST] Automatisch zusammengeführter Beitrag ---

Kommando zurück, nach 3836 Links ohne Fehlermeldung abgestürzt.
 
Zuletzt bearbeitet:

Commodo

NGBler

Registriert
17 Mai 2014
Beiträge
151
  • Thread Starter Thread Starter
  • #4
SlimerJS und CasperJS das gleiche, 1000-4000 Links und sie crashen.
Stackoverflow und die offiziellen IRC Channels nützen auch nichts.

Ich biete 10-20€ wenn mir jemand das zum laufen bringt (Banküberweisung, Visa Prepaid, Paysafecard, Cash wenn ihr im Ruhrpott wohnt), ich weiss nicht mehr weiter :(.
 

Commodo

NGBler

Registriert
17 Mai 2014
Beiträge
151
  • Thread Starter Thread Starter
  • #6
Weil ich einen Headless Browser mit Javascript-Unterstützung brauche, da der Request den ich matchen will per JS gefeuert wird.

Und da ist PhantomJS halt #1.

Wenn du irgendeine Idee hast wie ich die Info für 12500 Links sonst bekomme immer her damit :beer:.
 
Oben