Medtronic CareLink-Fehler


Seit einigen Tagen quält mit der Fehlercode 99 von der CareLink Software.

Auch wenn der Medtronic Ordner laut Anleitung gelöscht wird, funktioniert es auch nicht.
Der Start vom Browser als Administrator zeigt ebenso keine Auswirkung…

Nach einigen weiteren Stunden fand ich eine Lösung für mein Problem.

Man muss zuerst manuel den Treiber für den Medtronic CareLink installieren, indem man unter C:\ProgramData\Medtronic\ddmsDTWusb\ComLink2\Jungo 10.10 die Install_MDTCLUSB-64.cmd für x64-Systeme oder Install_MDTCLUSB-64.cmd für x32/x86-Systeme Datei als Administrator ausführt.

Nach der erfolgreichen Installation muss man legendlich eine leere Textdatei mit dem Namen install-success (install-success.txt) erstellen. Nachdem sollte der “Hochladen”-Assistent von Medtronic funktionieren.

Website Screenshot mit Linux


Nach einer langen und qualvollen Suche mit Google, bin ich auf eine Lösung gestoßen wie man mit Linux eine Webseite screenen und als PNG (jpg, usw..) abspeichern lassen kann.

Der Screenshot kann unter den Bildformaten svg, png, jpeg, gif und bmp abgespeichert werden.

Um die nächsten Pakete zu installieren, müssen wir den Paketmanager aptitude installieren. Dies geht so:
apt-get install -y aptitude

Nun installieren wir weitere benötigte Pakete:
aptitude install g++ subversion build-essential libgl1-mesa-dri xvfb libqt4-webkit libqt4-dev xfonts-scalable xfonts-100dpi xfs

Nun laden wir uns das benötigte Programm, welches die Websiten screent, herunter, entpacken es und installieren es abschließend:
svn co https://cutycapt.svn.sourceforge.net/svnroot/cutycapt # Herunterladen
cd cutycapt/CutyCapt # In das Verzeichnis wechseln
qmake # Compilieren
make # Compilieren

Nach diesen Befehlen gibt es nun eine Datei namens “CutyCapt”.
Nun machen wir die Datei ausführbar:
chmod +x CutyCapt

Mit CutyCapt kann man jetzt ganz leicht – mit einem Befehl – eine Website screenen und als PNG abspeichern:
xvfb-run --server-args="-screen 0, 1366x768x24" ./CutyCapt --url=https://patrik.kernstock.net --out=pkern_at.png
Die Website “https://patrik.kernstock.net” wird nun als PNG unter den Namen pkern_at.png gespeichert.
Der Screenshot hat eine Auflösung von 1366×768.

Mit wenig PHP Kenntnissen und einem Webspace/Server wo SaveMode aus ist, kann man sich ein kleines Script schreiben.
Achtung: Das Script ist eine 3 Minuten Arbeit und nicht besonders sicher. Höchstens für Eigengebrauch.
[php collapse=”true”]<?php
if(isset($_POST[‘submit’]) && $_POST[‘check’]==true)
{
$screen_dir = "./screens"; # Without slash (/) at the end!
$size = $_POST[‘size’];

$size = explode("x", $size);
$width = $size[0];
$height = $size[1];

$link = $_POST[‘url’]; # Link of the page?
$name = str_replace("http://", "", $link);
$file = $screen_dir."/".$name.".png";

if(!file_exists($file)) shell_exec(‘xvfb-run –server-args="-screen 0, ‘.$width.’x’.$height.’x24" ./app/CutyCapt –url=’.$link.’ –out=’.$file);

}
?>
<html>
<head>
<title>Screener</title>
</head>
<body>
<?php
if(empty($file))
{
if(empty($_POST[‘url’])) $url = "http://www."; else $url = $_POST[‘url’];
echo ‘
<form action="" method="post">
<b>Homepage</b> <small>(URL)</small>:<br />
<input type="text" name="url" value="’.$url.’" size="50"><br />
<br />
<b>Screen-Size</b>:<br />
<select name="size">
<option value="1366×768">1366×768</option>
<option value="1024×768">1024×768</option>
</select>
<br />
<br />
<b>Notice</b><br />
A shot of a page may take some seconds! (~10seconds)<br />
<br />
<input type="checkbox" name="check"> I agree that my IP <small>(‘.$_SERVER[‘REMOTE_ADDR’].’)</small> will be saved.<br />
<br />
<input type="submit" name="submit" id="submit" value="Shot the page!">
</form>
‘;
}
else {
echo ‘<img src="’.$file.’">’;
}
?>
</body>
</html>[/php]

Viel Spaß beim Snapschüsse machen!

How to create a iso with linux


Auf Linux ist es sehr einfach, aus einem Ordner eine ISO Datei zu machen.
Dazu muss man folgendes Paket installieren:
apt-get install mkisofs

und dann gibt man ein:
mkisofs -o FILE.iso ISO_FOLDER/
Danach wird eine ISO namens “FILE.iso” mit dem Inhalt von “ISO_FOLDER/” erstellt.

Wenn man ein Linux Betriebssystem mit einem CD Laufwerk hat, kann man das auch direkt so machen:
dd if=/dev/cdrom of=/tmp/FILE.iso

nginx – Mein neuer Favourite (Tutorial)



NGINX ist ein schneller, effizienter und sparsamer Webserver gegenüber Lighttpd oder Apache.
Dieser Webserver wird bereits von vielen großen Internetseiten verwendet (z.B. von SourceForge und WordPress.com), da nginx um einiges weniger RAM und CPU Load benötigt als andere Server.

Ein weiterer Vorteil ist, dass nginx etwa jedes Monat aktualisiert wird was bei Lighttpd oder Apache nicht der Fall ist.

Zwei Zitate:

…in my simple stress tests cpu usage showed lighttpd at 98% while nginx was never more than 52%…

nginx performed almost the same as lighttpd but cpu load was much better with nginx. (LA never got more than 5 while lighttpd bumped it up to ~10, and apache to 20+ while testing with the wordpress setup) Btw, can’t even compare it to apache, which almost crashed my box when testing the sample wordpress install.( 10000 requests, 1000 concurrent)

Auch nginx ist nicht der perfekteste Webserver, da nginx nicht ein FastCGI-Modul mitinstalliert, welches man für PHP benötigt. Jedoch kann man diese Pakete leicht nachinstallieren.

Hier nun eine kleine Anleitung zum installieren von NGINX
Installieren der notwendigen Pakete

apt-get install -y gcc cpp make libatomic-ops-dev libbz2-dev libexpat1-dev libfontconfig1-dev libfreetype6-dev libgcrypt11-dev libgd2-xpm-dev libgeoip-dev libglib2.0-dev libgmp3-dev libgpg-error-dev libjpeg62-dev libpcre3-dev libpng12-dev libpthread-stubs0-dev libssl-dev libxalan110-dev libxerces-c2-dev libxml2-dev libxpm-dev libxslt1-dev linux-libc-dev zlib1g-dev

Der Parameter “-y” überspringt die Nachfrage, ob die Pakete wirklich installiert werden sollen.

Herunterladen und entpacken von nginx

wget # Herunterladen
tar xfz nginx-[cur-nginx-version].tar.gz # Entpacken

Vorbereiten auf das compilieren von nginx

cd nginx-[cur-nginx-version] # In das entpackte Verzeichnis wechseln

Sollte euer Server ein 64bit System sein, fügt folgenden Parameter an das Ende des Befehls unten hinzu:
–with-cpu-opt=amd64

./configure --user=www-data --group=www-data --with-http_image_filter_module --with-http_geoip_module --with-http_xslt_module --with-rtsig_module --with-poll_module --with-http_sub_module --with-http_dav_module --with-http_flv_module --with-http_gzip_static_module --with-http_random_index_module --with-http_secure_link_module --with-http_degradation_module --with-http_stub_status_module --with-file-aio --with-ipv6 --with-http_realip_module --with-http_addition_module --with-select_module --with-http_ssl_module --with-libatomic --with-debug --without-mail_pop3_module --without-mail_imap_module --without-mail_smtp_module --prefix=/srv/nginx

Achtung! Mit diesen Befehl wird nginx nach /srv/nginx installiert.
Wollt ihr nginx woanders installieren, müsst ihr den Parameter –prefix=/srv/nginx anpassen!

Zur Sicherheit sollte nginx nicht unter root laufen. Ich verwende daher den User und die Gruppe www-data.

Compilieren von nginx

make
make install

Hinweis: Das Compilieren kann je nach Geschwindigkeit des Systems einige Minuten dauern!

Aufräumen

cd ../
rm nginx-[cur-nginx-version].tar.gz
rm nginx-[cur-nginx-version] -R

Starten von nginx

cd /srv/nginx/sbin # Zu nginx wechseln
./nginx # nginx starten

Nun sollte nginx laufen. Jedoch unterstützt nginx noch kein PHP.
Deshalb weiter mit dem Tutorial…

Installieren von PHP

apt-get install -y php5-cgi # Installieren von php5-cgi
wget http://ftp.de.debian.org/debian/pool/main/s/spawn-fcgi/spawn-fcgi_1.6.3.orig.tar.gz # Herunterladen
tar spawn-fcgi_*.orig.tar.gz # entpacken
cd spawn-fcgi*
./configure
make
make install

Anlegen und starten der benötigen Startdatei

cd /srv/nginx/sbin # Wechseln in das Inst.verzeichnis von nginx
echo "spawn-fcgi -d /etc/php5/ -f /usr/bin/php-cgi -a 127.0.0.1 -p 9000 -C 2 -F 2 > /dev/null &" > php
chmod +x php
./php

Hinweis: Die Parameter -C und -F geben die Anzahl der Prozesse an, welche die PHP Dateien verarbeiten.

Schlussendlich eine Beispielconfig für /srv/nginx/conf/nginx.conf:
root-dir/public-dir/html-dir: /var/www

[sourcecode language=”plain” collapse=”true”]user www-data;
worker_processes 2;

events {
worker_connections 256;
multi_accept on;
use epoll;
}

http {
sendfile on;
tcp_nopush off;
tcp_nodelay off;
types_hash_max_size 2048;
charset win-utf;
source_charset win-utf;
ignore_invalid_headers on;

include /srv/nginx/conf/mime.types;
default_type application/octet-stream;

access_log /var/log/nginx/access.log;
error_log /var/log/nginx/error.log;

gzip on;
gzip_disable "msie6";
gzip_static on;
gzip_vary on;
gzip_proxied any;
gzip_comp_level 6;
gzip_buffers 16 8k;
gzip_http_version 1.1;
gzip_types application/x-httpd-php text/plain text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript;

add_header Cache-Control public;
add_header Vary Accept-Encoding;

client_body_buffer_size 64M;
client_header_buffer_size 64M;
client_max_body_size 64M;
large_client_header_buffers 32 32k;
client_body_timeout 30;
client_header_timeout 30;
keepalive_timeout 30;
send_timeout 30;

server {
autoindex on;
listen 80;
server_name patrik.kernstock.net www.patrik.kernstock.net;
location / {
root /var/www;
index index.php index.html index.htm;
fastcgi_read_timeout 1280;
}
location ~ \.(php)$ {
root /var/www;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /var/www/$fastcgi_script_name;
include fastcgi_params;
}
}

#Automatische Domains#
# server {
# autoindex on;
# listen 80;
# server_name $host www.$host;
# location / {
# root /var/www/$host;
# index index.php index.html index.htm;
# fastcgi_read_timeout 1280;
# }
# location ~ \.(php|tpl)$ {
# root /var/www/$host;
# fastcgi_pass 127.0.0.1:9000;
# fastcgi_index index.php;
# fastcgi_param SCRIPT_FILENAME /var/www/$host/$fastcgi_script_name;
# include fastcgi_params;
# }
# }

}[/sourcecode]

Automatische Installation per Script
Wär sich nginx + PHP automatisch installieren lassen will, kann folgendes Script verwenden:

wget https://patrik.kernstock.net/nginx-install.sh
chmod +x nginx-install.sh
./nginx-install.sh

Ich übernehme keine Haftung!

Danke an q23p.de für die Beispielconfig und die Auflistung der notwendigen Pakete!

Tutorial darf nur mit Copyright und Link zu diesem Artikel kopiert werden!

LCD Display an DockStar


Meine DockStar besitzt nun einen LCD Display mit den wichtigsten Informationen.
Verwende folgenden DPF (Digital Photo Frame = Digitaler Fotorahmen):
http://www.pearl.de/a-HPM1184-5618.shtml bzw. http://www.pearl.de/a-PX1184-5618.shtml
Die Lieferung nach Österreich dauerte 4 Werktage.

So sieht es dann fertig aus:
Bilder

Installieren der notwendigen Pakete
apt-get install libgd2-noxpm
Der Download des Debian Paketes zum Hacken des Displays, kann direkt über den Hersteller oder über meinen Server erfolgen.
Mein Server: https://patrik.kernstock.net/wp-content/uploads/lcd4linux/lcd4linux_0.11.0-svn_armel.deb
Hersteller: http://geekparadise.de/wp-content/uploads/lcd4linux_0.11.0-svn_armel.deb

Herunterladen des Paketes:
wget https://patrik.kernstock.net/wp-content/uploads/lcd4linux/lcd4linux_0.11.0-svn_armel.deb
Installieren des Paketes:
dpkg -i lcd4linux_0.11.0-svn_armel.deb

Hacken des Displays

Hacken des Displays

wget https://patrik.kernstock.net/wp-content/uploads/lcd4linux/dpfhack-0.1alpha.tgz # Herunterladen
cd dpf/src # In den richtigen Ordner wechseln
python hackit.py /dev/sg1 # Let's hack!

Nun ist das Display erfolgreich gehackt. Trennt nun das DPF vom USB und steckt es erneut an. Nun haltet den MENU Knopf ca 2-3 Sekunden lang. Das Display ist nun fertig.

Jetzt benötigen wir noch eine richtige Konfiguration für das Display.
Die Configdatei findet ihr unter:
/etc/lcd4linux.conf
Die Datei lcd4linux.conf muss unbedingt dem Benutzer root zugewiesen sein und die Rechte 600 besitzen!
Dies geht wie folgt:
chown root:root /etc/lcd4linux.conf
chmod 600 /etc/lcd4linux.conf

Wer das gleiche Display wie ich haben möchte, gibt folgende Befehle ein:
Letzte Aktualisierung meiner Config: 24.05.2011 17:00
cd /etc
rm lcd4linux.conf
wget https://patrik.kernstock.net/wp-content/uploads/lcd4linux/lcd4linux.conf
chown root:root lcd4linux.conf
chmod 600 lcd4linux.conf
mkdir /root/lcd
cd /root/lcd
wget https://patrik.kernstock.net/wp-content/uploads/lcd4linux/dockstar-320x240.png

Das Bild dockstar-320×240.png ist der Hintergrund vom Display. Es werden nur PNG-Bilder unterstützt!
Diese Grafik kann zu jeden beliebigen Bild ersetzt werden. Es muss nur das Format beibehalten werden.

Nach jeden Änderungen in lcd4linux.conf muss lcd4linux neugestartet werden:
kill lcd4linux && sleep 1 && lcd4linux
Hersteller des Debian Paketes ist: GeekParadise.de
Ein detailliertes Tutorial findet ihr unter:
http://geekparadise.de/2011/04/digitaler-bilderrahmen-von-pearl-als-statusdisplay-fur-dockstar/
Dort findet ihr unter Punkt 3, wie man lcd4linux automatisch starten lassen kann.

Ich hafte für keine Schäden, Fehler oder Sonstiges!