• úvod
  • témata
  • události
  • tržiště
  • diskuze
  • nástěnka
  • přihlásit
    registrace
    ztracené heslo?
    ANGEL333node.js - Evented I/O for V8 JavaScript
    SUCZKER
    SUCZKER --- ---
    KOC256: process.on('unhandledRejection', (err) => { ... }) asi znas, to pisu jenom tak do foroty. Celou porceduru mas urcite oznaceno jako async, takze to problem nebude.

    Co ctu dokumentaci k waitforselector, tak pokud se proste neobjevi markup, kterej by odpovidal selectoru behem danyho timeout (defaultne asi tech 30000ms, ale nastavitelne pomci druhyho parameteru options), tak to proste throwne. Rekl bych, ze proste na strance se behem tech 30 sekund ten selektor neobjevi nebo tam proste nikdy nebyl.

    Je to prijatelne vysvetleni ?
    KOC256
    KOC256 --- ---
    Jinak ten chrome na linuxu oproti phantomu+casperu na widlich je 2x pomalejsi... (3 vs 7 minut).
    Nevim na kolik je to srovnatelne, protoze to muze byt klidne i vykonem.
    Win 10, 4 jadra i, 12GB RAM
    vs
    Debian jessie (VPS), 2 jadra, 1GB RAM (RAm je dost), procak obcas na 100%
    KOC256
    KOC256 --- ---
    
    for (loop of [2, 3, 5, 7]) {
    	try {
    		await page.goto('https://example.com/Tools/?name=' + nick + '&loop=' + loop + '&submit=Filter', {waitUntil: 'load'});
    	} catch (error) {
    		console.log('ERROR TU');
    		continue;
    	}
    console.log('17');
    	await page.waitForSelector('textarea:not(#support_body)');
    console.log('18');
    ...
    


    mám to v rámci webserveru a chci aby při nedostupnosti (timeout) jedné URL aby mi to skočilo na další... Takže otrocky takto všude dávám try+catch. Ale stává se mi, že i když mi to projde tím page.goto(), tak mi to spadne na:
    UnhandledPromiseRejectionWarning: Error: waiting failed: timeout 30000ms exceeded
    v page.waitForSelector().



    - Nějak jsem hloupě doufal, že waitUntil: 'load' se tam dává, aby se čekalo na load...
    - Mám nastaveno await page.setDefaultNavigationTimeout(3000);, což ale platí jen pro goto().

    Nějaké know-how k tomuto pls?
    KOC256
    KOC256 --- ---
    Jinak drobné zastavení nad rozdíly Puppeteer a CasperJS... ...pokud by to někoho zajímalo.


    C:
    var txt = casper.fetchText('textarea');
    P:
    const txt = await page.$eval('textarea:not(#support_body)', el => el.value);

    Protože ve stránce jsou dva prvky textarea a z toho ten #support_body je neviditelný a ten co chci použít nemá žádný identifikátor (ani nadřazený). Vyplývá z toho, že Chrome pracuje i s neviditelnými elementy.


    C:
    nicks.forEach(function(nick) {
    P:
    for (nick of nicks) {


    C:
    pageSettings: { loadImages: false, }
    P:
    await page.setRequestInterception(true);
    page.on('request', request => {
    	if (request.resourceType() === 'image')
    		request.abort();
    	else
    		request.continue();
    })



    const nicks = [
    	//'pepa'
    	,'koc256'
    	,'karel'
    ];

    C:
    projde
    P:
    hodí chybu - vadí mu ta první čárka


    U Chrome se mi líbí, že se nekonečně nezanořuje syntaxe...


    A jeden z hlavních je že PhantomJS je jeden velký problém s instalací a provozováním... :(
    KOC256
    KOC256 --- ---
    SUCZKER: code
    ...
    /code
    BULHI
    BULHI --- ---
    SUCZKER: to je nyx feature, syntax highlighting
    SUCZKER
    SUCZKER --- ---
    a ja se zeptam naprosto debilne a offtopic, jak sem dostavate ty barevny logy z terminalu ??
    KOC256
    KOC256 --- ---
    MARYO:
    zatim jsem si vzal od Forpsi VPS na 2 mesice zdarma. Jinak stoji 25kc/mesic. To na to hrani mi i stoji za to...
    MARYO
    MARYO --- ---
    KOC256: Nevim ale jestli to pujde nainstalovat na tom ARM :-)
    KOC256
    KOC256 --- ---
    MARYO:
    Díky.
    Dneska jsem si udělal základní kostru a zatím OK. Jelikož phantom byl fakt problém. Pořád něco nešlo a šel opakovaným rychlým refreshem shodit. Teď už jen přepsat aplikaci z caspera :)
    MARYO
    MARYO --- ---
    BTW já bych šel spíš do https://github.com/GoogleChrome/puppeteer od Googlu, ten běží na headless Chrome.
    MARYO
    MARYO --- ---
    Ten server bezi na ARM a ten phantomjs-prebuilt pro to nema binarku.
    Potom bych zkusil
    GitHub - fg2it/phantomjs-on-raspberry: Phantomjs for raspberry pi
    https://github.com/fg2it/phantomjs-on-raspberry
    nebo
    GitHub - ApioLab/phantomjs-2.1.1-linux-arm
    https://github.com/ApioLab/phantomjs-2.1.1-linux-arm
    KOC256
    KOC256 --- ---
    Myslím, že je problém, tu:
    Unexpected platform or architecture: linux/arm

    Ale našel jsem jen verzi pro PÍčku a ta mi nefungovala...
    KOC256
    KOC256 --- ---
    MARYO:
    Už jsem to zkoušel dříve a tedy výpis chyby...

    
    admin@NAS:/volume1/web/node$ npm install phantomjs-prebuilt -g
    npm WARN checkPermissions Missing write access to /volume1/@appstore/Node.js_v8/usr/local/lib/node_modules
    npm ERR! path /volume1/@appstore/Node.js_v8/usr/local/lib/node_modules
    npm ERR! code EACCES
    npm ERR! errno -13
    npm ERR! syscall access
    npm ERR! Error: EACCES: permission denied, access '/volume1/@appstore/Node.js_v8/usr/local/lib/node_modules'
    npm ERR!  { Error: EACCES: permission denied, access '/volume1/@appstore/Node.js_v8/usr/local/lib/node_modules'
    npm ERR!   stack: 'Error: EACCES: permission denied, access \'/volume1/@appstore/Node.js_v8/usr/local/lib/node_modules\'',
    npm ERR!   errno: -13,
    npm ERR!   code: 'EACCES',
    npm ERR!   syscall: 'access',
    npm ERR!   path: '/volume1/@appstore/Node.js_v8/usr/local/lib/node_modules' }
    npm ERR!
    npm ERR! Please try running this command again as root/Administrator.
    
    npm ERR! A complete log of this run can be found in:
    npm ERR!     /var/services/homes/admin/.npm/_logs/2018-02-06T08_13_18_993Z-debug.log
    admin@NAS:/volume1/web/node$ sudo npm install phantomjs-prebuilt -g
    Password:
    /volume1/@appstore/Node.js_v8/usr/local/bin/phantomjs -> /volume1/@appstore/Node.js_v8/usr/local/lib/node_modules/phantomjs-prebuilt/bin/phantomjs
    
    > phantomjs-prebuilt@2.1.16 install /volume1/@appstore/Node.js_v8/usr/local/lib/node_modules/phantomjs-prebuilt
    > node install.js
    
    PhantomJS not found on PATH
    Unexpected platform or architecture: linux/arm
    It seems there is no binary available for your platform/architecture
    Try to install PhantomJS globally
    npm ERR! code ELIFECYCLE
    npm ERR! errno 1
    npm ERR! phantomjs-prebuilt@2.1.16 install: `node install.js`
    npm ERR! Exit status 1
    npm ERR!
    npm ERR! Failed at the phantomjs-prebuilt@2.1.16 install script.
    npm ERR! This is probably not a problem with npm. There is likely additional logging output above.
    
    npm ERR! A complete log of this run can be found in:
    npm ERR!     /root/.npm/_logs/2018-02-06T08_14_29_381Z-debug.log
    admin@NAS:/volume1/web/node$
    
    KOC256
    KOC256 --- ---
    MARYO: zkusim jeste ale i ten prebuilt mi hazel nejake chyby.
    MARYO
    MARYO --- ---
    Prerequisites
    Node.js >= 0.8
    PhantomJS >= 1.9
    CasperJS >= 1.0

    npm install phantomjs-prebuilt
    npm install casperjs

    pripadne

    npm install phantomjs-prebuilt -g
    npm install casperjs -g
    KOC256
    KOC256 --- ---
    Zacal jsem si hrat s phantomjs a casperjs na lokale (windows). Chtel bych to dostat na server do prostredi webu a tak jsem si na Synology NAS nahral NODE.JS v8.

    Pak pres SSH
    npm init -y
    npm install express spookyjs

    Hello world! priklad z https://www.npmjs.com/package/express mi funguje. (node server.js)

    Ale pokud zkusim spustit priklad ze spookyho https://github.com/SpookyJS/SpookyJS/blob/master/examples/hello.js
    jako: node hello.js
    Tak dostanu chybu:
    
    admin@NAS:/volume1/web/node$ node hello.js
    events.js:182
          throw er; // Unhandled 'error' event
          ^
    
    Error: spawn casperjs ENOENT
        at exports._errnoException (util.js:1024:11)
        at Process.ChildProcess._handle.onexit (internal/child_process.js:192:19)
        at onErrorNT (internal/child_process.js:374:16)
        at _combinedTickCallback (internal/process/next_tick.js:138:11)
        at process._tickCallback (internal/process/next_tick.js:180:9)
        at Function.Module.runMain (module.js:607:11)
        at startup (bootstrap_node.js:158:16)
        at bootstrap_node.js:575:3
    admin@NAS:/volume1/web/node$
    


    Pokud si spookyho hodim do expressu, tak opet chyby...
    Na netu neco k tomu pisou ale nenasel jsem / nepochopil jsem co konkretne bych mel udelat. Rady jako restart pripadne npm install npm update vyzkouseny --> nic...

    Nejaky napad?
    FEDY
    FEDY --- ---
    ahoj, zase to zkusim, ve vire, ze si snad zachvili sam odpovim ... :-)

    stale stejny projekt - mereni SNMP. grafy uz funguji, jsou supr, jen jsem na nich odhalil, jak mi to blbe funguje ...

    pouzivam knihovnu net-snmp ( https://www.npmjs.com/package/net-snmp ) , generuju tisice requestu /s a chodi mi nazpet jen cast odpovedi. resp. na sitovku prijdou vsechny (vidim v nachytanem provozu ve wiresharku), ale uz zrejmne nejak nedorazi zpet do socketu. countery netstat -s "24392304 packets to unknown port received" docela dost naskakuji , coz bude jiste ona pricina. packety se vraci na port, ze ktereho sel request, ale zrejmne nektere nedorazi. tipuju, ze uz muze byt socket zavreny, ale je to takova rychlost, ze nevim jak to spravne hledat. vsechny mozne tweaky kernelu jsem zkousel (bezi to na linuxu)
    sysctl net.ipv4.ip_local_port_range="10000 61000"
    sysctl net.core.somaxconn=32768
    sysctl net.core.netdev_max_backlog=10000
    sysctl net.core.rmem_default=8388608
    sysctl net.core.wmem_default=8388608
    sysctl net.core.rmem_max=26214400
    sysctl net.core.wmem_max=26214400

    sitovka ma 0 erroru (musi , kdyz pozadovane odpovedi tcpdumpem chytim) , netstat counter vsak stale naskakuje. timeout pro SNMP mam v radech sekund, ve wiresharku vidim, ze odpoved prichazi nazpet po 200ms, ale zrejme je socket uz zavreny. nestalo se vam nekomu neco podobneho ?

    pripadne predem dik.
    FEDY
    FEDY --- ---
    FEDY: tohle auditko je supr ... pokazdy kdyz nevim, napisu sem, abych na to vzapeti prisel ... tentokrat se mazat nebudu a podelim se (treba to nekomu k necemu bude).

    reseni je jen v pridani * na konec coninuous query :-)

    CREATE CONTINUOUS QUERY cq_1day ON projectdb_2 BEGIN SELECT mean(rx) AS rx,mean(tx) AS tx INTO interface_1d FROM interface_4h GROUP BY time(5m),* END
    FEDY
    FEDY --- ---
    ahoj,

    nejni to primo nodejs, ale castecne to souvisi a asi nejni uplne kde jinde se na NYXyu ptat, tak to zkusim -

    zacal jsem , resp. snazim se zacit pouzivat InfluxDB na ukladani grafu. data ulozit a precist nejni problem, ovsem (logicky) potrebuju provadet downsampling starsich dat, od cehoz je v influx Retention Policy a Continuous query. to by take nebyl problem, ovsem nefunguje to presne jak bych rad aby to fungovalo nebo jsem si zvolil spatnou strukturu dat

    merim pomoci SNMP provoz na mnoha interfacech mnoha switchu (RX/TX Mbps, popr. posleze take pps). pozdeji to mohou byt take napr. mikrovlnne spoje (viz. typ signal, modulation) mam schema

    measurement: 'interface_4h',
    fields: {
    rx: Influx.FieldType.FLOAT,
    tx: Influx.FieldType.FLOAT
    },
    tags: [
    'type', // bandwidth, pps, signal, modulation
    'units', // mbps, gbps, pps, kpps, mpps, dbm, qam,
    'objectID' // ID of the interface
    ]

    ...pomoci objectID identifikuju zarizeni, tzn. ze v interface_4h jsou vsechny merene interfacy (tisice ks) a rozdeleny prave podle objectID. podle type je receno, zda jde o mereni bandwidth, packet per second, signal radia, modulace radia atp. units asi nejni potreba popisovat... tabulka (resp. measurement) se jmenuje _4h , protoze ma ukladat data za posledni 4 hodiny bez downsamplingu. z teto tabulky se ma pomoci continuous query vyrabet tabulka _1d , _30d, _1y (asi netreba vice popisovat) a v techto tabulkach stale opet potrebuju mit zachovany vsehny tagy (tzn. vsechny interfacy)

    CREATE CONTINUOUS QUERY cq_1day ON projectdb_2 BEGIN SELECT mean(rx) AS rx,mean(tx) AS tx INTO interface_1d FROM interface_4h GROUP BY time(5m) END

    ...mi udela prumer ze vsech interfacu v interface_4h a vypadne jen jedno zprumerovane rx + tx , namisto kyzenych tisicu "paru rx+tx". a je to tedy navic take bez tagu, ale to uz je celkem jedno, kdyz se sloucila vsechna data dohromady...

    otazka zni - je nutne delat na kazde mereni zvlast jednu continuous query ? (v mem pripade tisice ks) nelze to zaridit jednou query na celou tabulku ? (tim myslim jen jeden krok, napr. z 4hod na 1den )
    Kliknutím sem můžete změnit nastavení reklam